如何用Java和nginx编写文件权限控制的具体代码示例?
- 内容介绍
- 文章标签
- 相关推荐
本文共计258个文字,预计阅读时间需要2分钟。
我们知道,使用nginx作为文件下载服务器,能有效降低对后端Java服务器的负载冲击。但nginx本身并不提供权限控制。最佳方案是由后端服务器实现权限控制,通过直接返回授权结果。
我们知道,使用nginx作为文件下载服务器,可以极大地降低对后端Java服务器的负载冲击,但是nginx本身并不提供授权控制,因此好的方案是由后端服务器实现权限控制,最好的方式是直接复用应用的认证体系,最大化的降低成本。因此,可借助localhost:8081; #tomcat等web容器 proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; break; }
java后台代码如下:
httpResponse.setHeader("Content-Disposition", "attachment; filename=\""+filename+"\""); httpResponse.setHeader("Content-Type", "application/octet-stream"); httpResponse.setHeader("X-Accel-Redirect", "/bookres/"+resource.get("res_url")); //给nginx返回实际文件存在的地址
相比采用其他文件服务器方案如ftp/fastdfs/mongodb而言,该方案明显轻量非常多。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。
本文共计258个文字,预计阅读时间需要2分钟。
我们知道,使用nginx作为文件下载服务器,能有效降低对后端Java服务器的负载冲击。但nginx本身并不提供权限控制。最佳方案是由后端服务器实现权限控制,通过直接返回授权结果。
我们知道,使用nginx作为文件下载服务器,可以极大地降低对后端Java服务器的负载冲击,但是nginx本身并不提供授权控制,因此好的方案是由后端服务器实现权限控制,最好的方式是直接复用应用的认证体系,最大化的降低成本。因此,可借助localhost:8081; #tomcat等web容器 proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; break; }
java后台代码如下:
httpResponse.setHeader("Content-Disposition", "attachment; filename=\""+filename+"\""); httpResponse.setHeader("Content-Type", "application/octet-stream"); httpResponse.setHeader("X-Accel-Redirect", "/bookres/"+resource.get("res_url")); //给nginx返回实际文件存在的地址
相比采用其他文件服务器方案如ftp/fastdfs/mongodb而言,该方案明显轻量非常多。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

