因浏览器未发送Referer HTTP头导致Django项目CSRF验证失败的原因

问题

前段时间,做了一次服务器减负的同时,也把所有的遗留网站都加上了 HTTPS 支持,让客户免受推荐 HTTPS 证书销售公司的电话骚扰(他们的话术很吓人,客户听了以后会害怕地找我,这就很让我烦心了)。

因为遗留的都是企业官网,很少人会登陆更新内容,所以很久以后,客户才来联系我说后台登陆不上了。我一试,发现出现了 403 错误:

复制代码
禁止访问 (403)

CSRF验证失败. 请求被中断.

您看到此消息是由于HTTPS站点需要浏览器发送 'Referer HTTP头',但是目前没有被发送。出于安全考虑,浏览器必须发送该HTTP头,以确保您的浏览器没有被第三方劫持。

如果您已经设置浏览器禁用 'Referer' 头,请重新启用,至少针对这个站点,全部HTTPS请求,或者同源请求(same-origin)启用发送该HTTP头。

更多信息请设置选项DEBUG=True。

探索

奇哉!我记得我们的Django项目一直是有做 CSRF 验证的。但不管三七二十一,先爬上服务器看看。配置文件里的corsheaders.middleware.CorsMiddlewarecorsheaders都好好地躺在MIDDLEWAREINSTALLED_APPS配置项里。

重新看出错信息,有一段如果您已经设置浏览器禁用 'Referer' 头,请重新启用,这很是奇怪。都不知道浏览器还能禁用 Referer 头,搜索也找不到相关配置。搞得一头雾水,好不头大!

复制CSRF验证失败. 请求被中断.去搜索,也是一些关于开启Cookies和需要在form表单中增加{% csrf_token %}字段之类的常规方法,根据没有和Referer HTTP头 相关的片段,而这些提及的方向我们都已经做好了。

端倪

看来只能使用找Bug的根本大法:看源代码了。打开目录发现重载了页码模板,打开页面模板搜索referer关键字,并无收获。再仔细看,发现还重载了base.html这个基础页面,再找开就发现里面有一行:

html 复制代码
<meta name="referrer" content="never">

一看这行,就知道是控制了当发送 HTTP 请求的时候,不要发送Referer头了!

把这一行去掉,再测试,果然解决问题。然后查阅参考文档,发现这个 meta 项的默认值是:strict-origin-when-cross-origin,于是重新改回:

html 复制代码
<meta name="referrer" content="strict-origin-when-cross-origin">

测试可用,提交代码。收工。

小结

不知道为什么会出现这样的错误,想来可能是之前的同事从别处直接复制了一个文件,遗留了快十年吧。估计也不会有其他人遇到同样的情况,在此记之以自娱矣。

相关推荐
奥特曼_ it10 小时前
【机器学习】python旅游数据分析可视化协同过滤算法推荐系统(完整系统源码+数据库+开发笔记+详细部署教程)✅
python·算法·机器学习·数据分析·django·毕业设计·旅游
Cherry的跨界思维11 小时前
10、Python词语排序与查找效率优化终极指南:指定顺序+O(1)查找
开发语言·数据库·python·django·beautifulsoup·pyqt·pygame
会头痛的可达鸭12 小时前
Reqwest 库详细使用指南
http·rust·reqwest
橘子真甜~14 小时前
C/C++ Linux网络编程11 - 数据加密与https协议
linux·服务器·网络·http·https·密码学·加密解密
YANshangqian17 小时前
电脑系统优化Advanced SystemCare Pro
django
B站计算机毕业设计之家18 小时前
基于python京东商品销售数据分析可视化系统 Django框架 爬虫 大数据(源码)
大数据·爬虫·python·selenium·机器学习·数据分析·django
编程大师哥18 小时前
如何快速上手Django?3 小时从 0 到 1 做出第一个 Web 项目(小白友好版)
前端·django·sqlite
jinxinyuuuus19 小时前
抖音在线去水印:HTTP/2流量分析、反爬虫的对称与非对称加密
爬虫·网络协议·http
2501_9160074719 小时前
iOS 应用上架流程的工程化拆解 从签名体系到提交审核的全过程管控
android·ios·小程序·https·uni-app·iphone·webview
计算衎19 小时前
Python的FastAPI,Flask,Django Web框架的区别
python·django·flask·fastapi