位置: 编程技术 - 正文

Python的Flask框架及Nginx实现静态文件访问限制功能(flask框架官方文档)

编辑:rootadmin

推荐整理分享Python的Flask框架及Nginx实现静态文件访问限制功能(flask框架官方文档),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:flask框架图,python flask框架 web服务器,python flask框架 web服务器,flask框架官方文档,python flask框架 web服务器,flask框架官方文档,flask 框架,Python的flask框架教程,内容如对您有帮助,希望把文章链接给更多的朋友!

Nginx配置

Ngnix,一个高性能的web服务器,毫无疑问它是当下的宠儿。卓越的性能,灵活可扩展,在服务器领域里攻城拔寨,征战天下。

静态文件对于大多数website是不可或缺的一部分。使用Nginx来处理静态文件也是常见的方式。然而,一些静态文件,我们并不像任何情况下都公开给任何用户。例如一些提供给用户下载的文件,一些用户上传的涉及用户隐私的图片等。我们我希望用户登录的情况下可以访问,未登录的用户则不可见。

粗略的处理,在后端程序可以做过滤,渲染页面的时候,在视图逻辑里面验证用户登录,然后返回对应的页面。例如下面的flask代码(伪代码)

可是这样的处理,还有一个问题,静态文件是交给 nginx 处理的,如果hacker找到了文件的绝对地址,直接访问 Nginx 的一个小功能----XSendfile。 其原理也比较简单,大概就是使用了请求重定向。

我们知道,如果用Nginx做服务器前端的反向代理,一个请求进来,nginx先补捉到,然后再根据规则转发给后端的程序处理,或者直接处理返回。前者处理一些动态逻辑,后者多是处理静态文件。因此上面那个例子中,直接访问静态文件的绝对地址,Nginx就直接返回了,并没有调用后端的 user_idcard_page做逻辑限制。

为了解决这个问题,nginx提供的 XSendfile功能,简而言之就是用 internal 指令。该指令表示只接受内部的请求,即后端转发过来的请求。后端的视图逻辑中,需要明确的写入X-Accel-Redirect这个headers信息。

伪代码如下:

Python的Flask框架及Nginx实现静态文件访问限制功能(flask框架官方文档)

经过这样的处理,就能将静态资源进行重定向。这样的用法还是比较常见的,很多下载服务器可以通过这样的手段针对用户的权限做下载处理。

Flask

Flask是我喜欢的web框架,Flask甚至实现了一个 sendfile的方法,比上面的做法还简单。我用vagrant作了一个虚拟机,用Flask实现了上面的需求,具体代码如下:

项目结构

nginx的配置 nginx conf

web.conf

Flask 代码

app.py

简单部署

Python的string模块中的Template类字符串模板用法 string.Template()string.Template()内添加替换的字符,使用"$"符号,或在字符串内,使用"${}";调用时使用string.substitute(dict)函数.可以通过继承"string.Template",覆盖变量d

Python中的字符串替换操作示例 字符串的替换(interpolation),可以使用string.Template,也可以使用标准字符串的拼接.string.Template标示替换的字符,使用"$"符号,或在字符串内,使用"${}";调用时使

Python实现带百分比的进度条 大家在安装程序或下载文件时,通常都能看到进度条,提示你当前任务的进度。其实,在python中实现这个功能很简单,下面是具体代码。在实际应用中

标签: flask框架官方文档

本文链接地址:https://www.jiuchutong.com/biancheng/387650.html 转载请保留说明!

上一篇:总结网络IO模型与select模型的Python实例讲解(总结网络io模型的特点)

下一篇:Python的string模块中的Template类字符串模板用法(python string包)

  • 期末应交税费有余额吗
  • 电子承兑被退回在哪里
  • 用现金支付需要附哪些单据
  • 生产工人工资和福利费是产品成本项目对吗
  • 财务担保费计入什么科目
  • 购入的固定资产
  • 私人车辆油费可以报销吗
  • 企业收到政府补助资金怎么做账
  • 保险公司营销人员个人先进事迹材料
  • 国有资产报废如何委托拍卖公司
  • 公司接受投资会计科目
  • 计提工资和应付职工薪酬怎么不一样
  • 汽车行业保险丝
  • 机械租赁费发票图片
  • 农副产品收购发票申请
  • 金税三期能查几年前的发票
  • 固定资产清理的借方
  • 利润表有盈利能力吗
  • 金三接口调用失败怎么办?
  • 装修费可以作为开办费吗
  • 企业购入的固定资产,均要先计入在建工程
  • 3联收据
  • bios密码忘记了怎么清除,放电不行
  • 计算工业总产值指数
  • 营业外收入怎么做会计凭证
  • 历史时间线怎么写
  • PHP:Memcached::prepend()的用法_Memcached类
  • PHP:pg_consume_input()的用法_PostgreSQL函数
  • PHP:imagepsloadfont()的用法_GD库图像处理函数
  • 以前年度损益调整属于哪类科目
  • 优先股转化
  • 分期收款销售账务处理及税务处理
  • 经营租入的设备为什么不属于资产
  • 金融服务机构
  • php时间戳转换中国标准时间
  • 合伙企业分红个税税率表
  • flex的作用及设置
  • php sdk使用教程
  • 收到承兑汇票怎么操作
  • 织梦一直显示上一页和下一页
  • 收到税务局退回税款会计分录
  • 运费发票如何做分录
  • 产品出口认证
  • 外贸企业的退税可以转出来吗
  • 隔月红票怎么开
  • 技术服务收入如何纳税
  • 异地缴纳增值税和附加税的区别
  • 补交增值税如何转管理费用
  • 日常费用报销流程是什么样的?
  • 会计什么情况下不用继续教育
  • 特殊事项税务处理
  • 史上最简单的飞镖
  • sqlserver数据库怎么导出
  • microsoft onedrive怎么关闭
  • mac系统命名规律
  • mac osx 10.12
  • Ubuntu14.04 的 SSH 无密码登录的设置方法
  • hda linux
  • 如何设置电脑开机密码
  • Win7 64位操作系统怎么使用DVD刻录光驱复制软件
  • win10 2020h1
  • 桌面的word
  • win10总连不上网
  • [置顶]bilinovel
  • 小地图的主要作用是观察队友的大概位置
  • shell脚本tr
  • python多线程操作
  • jquery操作html代码
  • js鼠标点击事件监听
  • jquery json对象
  • 严苛认证
  • python文件描述符
  • python multinomial
  • bootstrap steps
  • python利用range产生列表
  • python3模拟登录
  • 各国进口汽车综合税率表
  • 税务局诉讼
  • 补交以前年度城建税费怎么做账
  • 请问在哪里可以看到
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设