美文网首页
使用bottle结合nginx实现静态文件访问重新认知

使用bottle结合nginx实现静态文件访问重新认知

作者: 小钟钟同学 | 来源:发表于2018-02-27 09:36 被阅读87次

    之前在实现静态文件访问限制的时候,留存有一个问题,实现文件下载的访问还是交给了bottle进行实现!
    文:https://www.jianshu.com/p/39831eeafed1

    后来重新认识了一下关于nginx实现内部的重定向!才知道认知上有一点点的错误。

    关于nginx实现内部的重定向主要还是利用internal来实现只允许内部访问的机制。
    对于配置了internal访问路径,表示这个反向代理只被内部使用,用户直接访问这个uri,会404。

    实现的主要流程应该是:
    1:访问相关web应用服务器接口做动态的下载权限的验证。
    2:进行相关鉴权后,然后在接口处把下载处理转交给nginx去做,既nginx内部重定向。

    上述方式主要优点有:
    1:web应用服务器可以对文件访问进行鉴权
    2:屏蔽真实的下载文件地址,对用户侧进行透明

    整个流程主要核心点主要是:
    利用nginx提供的X-Accel-Redirect的关键字,
    用户发起静态文件访问请求的时候

    server {
        listen 80;
        server_name 192.168.182.155;
        root /data/app/html/; #静态文件项目的目录
            
        location / {
            
            index  Index.html index.html;
            #proxy_pass http://192.168.182.155:8089;
        }
    
         
           location ~* ^/(filedown)/{
            internal; # 限制内部访问的关键字段
            alias /data/app/html2/static/$1;    //文件可以放到别的目录    
        }
    
        location ~* ^/(upload)/{
            proxy_set_header Host  $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_pass http://192.168.182.155:8089;
        }
    }
    

    经过鉴权后,web应用服务器在响应处理的时候再header中加上X-Accel-Redirect字段,

    @get('/upload/<filepath:path>')
    @login_required
    def upload(filepath):
       response['Content-Disposition: attachment; filename='] = 'asjjshdha'
       response.headers['X-asdas'] = 'asasaaa'
       response.headers['X-Accel-Redirect'] = '/data/app/xianzhi'+'/filedown/%s' % filepath
       response.headers['Content-Disposition'] = 'attachment; filename=asasas'
    
    

    值为跳转的uri

    response.headers['X-Accel-Redirect'] = '/data/app/xianzhi'+'/filedown/%s' % filepath

    当nginx收到有返回X-Accel-Redirect头部时会自动拦截这个http响应请求,然后在内部重定向到这个uri的位置【 '/data/app/xianzhi'+'/filedown/%s' % filepath】。

    相关文章

      网友评论

          本文标题:使用bottle结合nginx实现静态文件访问重新认知

          本文链接:https://www.haomeiwen.com/subject/bykpxftx.html