位置: 编程技术 - 正文

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包)

  • 个人应纳税所得额20万交多少税
  • 公司账户转账给个人怎么合理避税?
  • 房产税计税依据是什么
  • 股票印花税是多少最新
  • 房产税的征收范围包括农村吗
  • 无偿调入的固定资产
  • 厂区地面硬化属于土建还是市政
  • 一般纳税人支付给小规模纳税人的税率
  • 增值税零申报附加税费情况表没发保存
  • 停车费收入增值税申报表怎么填
  • 物料耗用
  • 资产减值损失有二级科目吗
  • 小企业会计准则以前年度损益调整
  • 个人出口货物到国外
  • 定额中税金包含什么
  • 企业为员工租房账务处理
  • 年折旧额怎么计算公式直线法
  • 工程管理费如何使用
  • 非广告公司可以开广告费发票吗?
  • 工程收到收据没有发票的会计分录怎么做?
  • 负债减少在什么方
  • 非经营活动界定,主要说明哪些情形不交增值税
  • 输入开票码开具电子发票
  • 网上办税服务厅app下载
  • 招待客户产生的住宿费
  • 土地抵扣进项税,,能调回来吗
  • windows10无法打开图片
  • 净资产收益率摊薄
  • 会计分录中结转是什么意思
  • 暂估入库材料分录
  • 预收账款是
  • centos6.5下载
  • win7如何禁用wifi
  • 进程调度算法例题分析
  • 采用销售百分比法预测对外
  • 哪些收入需要交消费税
  • php aop
  • php zmq
  • php代码规范七大原则
  • php.ini详解
  • 股东分红会计分录案例
  • phpcms文档
  • 生产车间的辅助记录
  • python中如何创建文件
  • sql性能优化方法
  • 购买的固定资产退回账务处理
  • 小规模企业没有进项票能开发票吗
  • 管理费用处理的是
  • sql 语法树
  • 销售费用主要账户包括
  • 未认证的进项税发票入账
  • 物流辅助服务属于
  • 社平工资调整补差能补多少
  • 工程款发票怎么做分录
  • 购买空调做账分录
  • 电子承兑汇票接收不了怎么办
  • 企业会计制度怎么写
  • mysql 5.6新特性
  • 怎么制作win7系统u盘装系统教程
  • win7系统怎么把桌面文件放到d盘
  • 怎么删除swapfile
  • centos6.5关闭休眠
  • linux如何使用gcc编程
  • windows8.1更新windows10
  • 如何注销windows账户登录
  • win8无法使用内置管理员账户打开ie
  • post installation
  • gnome版本
  • 如何下载安装windows10
  • win10系统更改
  • 编写注册表文件
  • python中数字运算
  • unity3d模型怎么制作
  • shell脚本cut -d
  • python中的命名规范
  • 济宁税务局王燕利
  • 欧美 房产税
  • 企业信息公示在哪里打印
  • 亏损可以结转吗
  • 手机的海关税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设