首页
学习
活动
专区
圈层
工具
发布

Django 安全之跨站点请求伪造(CSRF)保护

Django 安全之跨站点请求伪造(CSRF)保护 by:授客 QQ:1033553122 测试环境 Win7 Django 1.11 跨站点请求伪造(CSRF)保护 中间件配置 默认的CSRF中间件在...',并且其位置位于其它会对CSRF攻击进行处理的中间件之前,假设要禁用CSRF中间件,去掉列表中的'django.middleware.csrf.CsrfViewMiddleware',或者采用注释方式...MIDDLEWARE = [ ……, 'django.middleware.csrf.CsrfViewMiddleware', …… ] 如果CSRF中间件被禁用(不推荐),又想对特定视图启用中间件保护...相反的,如果中间件已经开启,但是又不想针对特定视图使用中间件保护,则可以针对特定视图使用csrf_exempt() 修饰器 from django.views.decorators.csrf import...前端js脚本 注意:如果已开启CSRF 的情况下,需要给请求添加X_CSRFTOKEN 请求头,否则会报403错误 /** * 验证不需要CSRF保护的HTTP方法名(GET|HEAD|OPTIONS

1.4K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    谈谈Django的CSRF插件的漏洞

    今年十月份我的第二本书《基于Django的电子商务网站设计》出版了,在这本书中我不仅介绍了如何利用Django框架搭建电子商务网站,也论述了如何利用python的requests类对所创建的电子商务产品进行接口测试...在书写极乐口测试代码过程中,我遇到的最大的困难就是如何通过测试程序绕过Django的防止CSRF攻击的插件,通过近一个多月的努力我终于解决了这个问题,但是同时也揭露了Django框架的防止CSRF攻击的插件的漏洞...这个就是CSRF攻击。 2、Django的CSRF插件是如何解决CSRF攻击的 下面让我们来看一下Django的CSR插件是如何解决CSRF攻击的。...Django利用了一个名为django.middleware.csrf.CsrfViewMiddleware的中间件(可以在Django的settings.py中设置)利用CSRF令牌的方式来控制。...3、Django的CSRF插件的漏洞 3.1通过requests类破解 但是这个CSRF插件是有漏洞的,在页面login.html页面载入后,黑客可以通过某种手段(比如正则表达式)获得这个CSRF令牌

    1.4K10

    关于Django上线后的CSRF问题

    首先在宝塔上安装Python项目管理器,采用如下配置,能够快速搭建Django项目。 然后进行映射域名,启动项目,发现只要含有表单的页面都出现CSRF错误的信息。...由于Django的防CSRF是默认开启的,所以如果表单内没有添加{% csrf_token %}会导致报错。...对于CSRF报错,最简单的方法就是注释掉上面的代码,然后所有的表单都不添加{% csrf_token %}。...但这又会引出一个新问题,因为Django系统自带的admin应用是包含{% csrf_token %}的,所以还要改系统生成的代码会十分麻烦。...{% csrf_token %}就是为了防止跨域请求的,而https与http并不是同一个域(可以去搜索跨域相关的知识),因此猜测是开启了https的问题,解决办法如下: 打开站点设置->反向代理->配置文件

    34220

    GET 请求和 POST 请求的区别

    ① get 请求用来从服务器上获取资源;而 post 请求通常是用来向服务器提交数据的; ② get 请求是将表单中的数据按 name=value 的形式,添加到 action 所指向的 URL 后面,...的方式连接,而各个变量之间使用 "&" 连接;post 是将表单中的数据放在 HTTP 协议的请求头或消息体中,传递到 action 所指向 URL; ③ get 传输的数据受到 URL 长度的限制(因浏览器不同最大字符长度也有所不同...),而 post 请求则没有这方面的约束; ④ 使用 get 发送请求时,参数会显示在地址栏上,如果这些数据不是敏感数据,那么允许使用 get,但对于敏感数据,还是建议使用 post; ⑤ get 使用...MIME 类型为 application/x-www-form-urlencoded 的 URL 编码(也叫百分号编码)文本格式进行传递参数,保证被传送的参数遵循规范的文本组成,例如:一个空格的编码是

    3.2K30

    GET请求和POST请求的区别

    二者在传输上基本没有区别,二者都是HTTP请求中的两种。HTTP协议是基于TCP/IP的应用层协议,所以无论GET还是POST,用的都是同一个传输层协议,所以在传输上可以认为基本无差别。...,安全性比GET请求高一点,但是也是不安全的; 3.是否被缓存的区别 GET请求可以被缓存,也会保留在浏览器的历史记录中; POST请求一般不会被缓存,也不会保留在浏览器的历史记录中;...通常HTTP请求只适用于不改变服务端数据的请求,比如查询类的请求,因为GET通常是用于获取数据,一般不做更新服务器数据的操作,所以符合HTTP缓存适用于不改变服务器数据的请求的原则,所以说GET请求可以被缓存...4.请求长度的区别: GET请求传递的参数一般显示在地址栏上,由于浏览器对url的长度有限制,所以GET请求发送数据有长度的限制; POST请求一般没有请求长度的限制,因为请求数据在body上;...5.参数类型的区别: GET请求只接受ASCII字符; POST请求没有限制,支持更多的数据类型; 6.其他区别 GET请求刷新浏览器或者回退没有影响;POST请求则会重新请求一遍;

    1.4K10

    我是如何利用CSRF Get DedeCms Shell的

    说实话,有一两个月没有审计大厂了,然后随便看到群里有人问dede最新有没有漏洞,就下了一套最新的dede,结果我一看还真发现了。 我们发现后台添加广告的地方存在跨站请求伪造漏洞。...远程攻击者可通过提交特制的请求利用达到写入WebShell目的。 在添加广告的地方,广告内容你直接写就可以了。...在If语句内,第一个就是一个SELECT查询语句,我们只可以控制$aid,但是因为前面的三目运算符限制了$aid的值,所以说我们就老老实实的让他查询,这里查询的是存放广告的表,然后初始化$abody的值为空...,就输出存入过期的值,如果不过期,就输出存入的值。...所以说只要我们控制了广告的代码,就可以造GetShell,但是这是后台功能,所以说我们在没有注入的情况下,只能通过Csrf来诱导管理员来点击我们设置好的页面,来让管理员修改广告代码,或者通过一个前台SQL

    1.1K70

    我是如何利用CSRF Get DedeCms Shell的

    说实话,有一两个月没有审计大厂了,然后随便看到群里有人问dede最新有没有漏洞,就下了一套最新的dede,结果我一看还真发现了。 我们发现后台添加广告的地方存在跨站请求伪造漏洞。...远程攻击者可通过提交特制的请求利用达到写入WebShell目的。 在添加广告的地方,广告内容你直接写就可以了。 的值,所以说我们就老老实实的让他查询,这里查询的是存放广告的表,然后初始化$abody的值为空...,就输出存入过期的值,如果不过期,就输出存入的值。...所以说只要我们控制了广告的代码,就可以造GetShell,但是这是后台功能,所以说我们在没有注入的情况下,只能通过Csrf来诱导管理员来点击我们设置好的页面,来让管理员修改广告代码,或者通过一个前台SQL

    1.8K80

    Django CSRF认证的几种解决方案

    什么是CSRF 浏览器在发送请求的时候,会自动带上当前域名对应的cookie内容,发送给服务端,不管这个请求是来源A网站还是其它网站,只要请求的是A网站的链接,就会带上A网站的cookie。...攻击过程 用户登陆A网站后,攻击者自己开发一个B网站,这个网站会通过js请求A网站,比如用户点击了某个按钮,就触发了js的执行。...由于每个用户的 token 不一样,B网站上的js代码无法猜出token内容,对比必然失败,所以可以起到防范作用。...Django使用CsrfViewMiddleware中间件进行CSRF校验,默认开启防止csrf(跨站点请求伪造)攻击,在post请求时,没有携带csrf字段,导致校验失败,报403错误。...指定请求去掉CSRF校验 可以只针对指定的路由去掉CSRF校验,这也分为两种情况: FBV:用函数实现路由处理 # 导入,可以使此次请求忽略csrf校验 from django.views.decorators.csrf

    2.2K20

    【玩转全栈】—— Django 连接 vue3 保姆级教程,前后端分离式项目2025年4月最新!!!

    本文基于之前的一个旅游网站,实现 Django 连接 vue3,使 vue3 能携带 CSRF Token 发送 axios 请求给后端,后端再响应数据给前端。想要源码直接滑倒底部。...验证Token:当用户提交表单时,无论是通过POST请求还是其他非安全方法(如PUT、DELETE等),Django都会检查请求中的CSRF Token是否与存储在Cookie中的Token相匹配。...在前后端分离项目中的应用 在传统的Django项目中,模板渲染机制使得CSRF Token很容易集成进每个需要保护的表单或AJAX请求中。...问题 Django 默认启用了 CSRF 保护机制,要求所有非安全 HTTP 方法(如 POST、PUT、DELETE)必须包含有效的 CSRF Token。...配置 Vite 代理后,再使用 axios 发送请求给 Django: 这里我再给个示例: 前端通过 /api/ask 发送请求,携带 CSRF Token 请求头,将用户输入的 question 以

    96310

    Django基于用户画像的电影推荐系统源码

    一、项目介绍 本系统是以Django作为基础框架,采用MTV模式,数据库使用MongoDB、MySQL和Redis,以从豆瓣平台爬取的电影数据作为基础数据源,主要基于用户的基本信息和使用操作记录等行为信息来开发用户标签...管理系统使用的是Django自带的管理系统,并使用simpleui进行了美化。...二、系统架构图 三、系统模块图 四、目录结构及主要文件说明 ├─BiShe │ ├─admin.py (Django后端管理系统主要配置) │...在项目目录运行命令,创建表结构,同时创建Django管理系统的管理员帐号: python manage.py makemigrations user movie api python manage.py.../spark.py ,即可每日自动处理离线数据,精准推荐,推荐方式同时包含基于电影内容(基于内容)、基于用户相似度(基于协同过滤)推荐的方式。后期如有兴趣的同学还可完善改为实时推荐。

    3.1K40

    XMLHttpRequest对象的Get请求和Post请求的用法

    XMLHttpRequest对象是一种用于发起HTTP请求的JavaScript API,它可以执行GET请求和POST请求,用于与服务器交换数据。...这两种请求方法在用法上有一些区别,下面将详细介绍它们。GET请求:GET请求用于从服务器获取数据,通常将参数附加到URL的查询字符串中。这种请求通常用于获取数据,如网页、图像或其他资源。...();上述代码中,我们首先创建了XMLHttpRequest对象,然后使用open方法配置了GET请求的URL和参数。...需要注意的是,POST请求通常用于发送敏感数据,因此应该使用HTTPS来保护通信安全。此外,服务器端也需要相应的处理来解析POST请求中的数据。...以上是XMLHttpRequest的GET和POST请求用法,它们在Web开发中非常常见,用于实现与服务器的数据交互。希望这些解释对你有所帮助。

    42410

    get和post请求的区别

    网上也有文章说:get和post请求实际上是没有区别,大家可以自行查询相关文章(参考文章:https://www.cnblogs.com/logsharing/p/8448446.html,知乎对应的问题链接...①get请求用来从服务器上获得资源,而post是用来向服务器提交数据; ②get将表单中数据按照name=value的形式,添加到action 所指向的URL 后面,并且两者使用"?"...连接,而各个变量之间使用"&"连接;post是将表单中的数据放在HTTP协议的请求头或消息体中,传递到action所指向URL; ③get传输的数据要受到URL长度限制(最大长度是 2048 个字符);...如果服务器返回301或者302,则浏览器会到新的网址重新请求该资源。...从运用地方来说 forward:一般用于用户登陆的时候,根据角色转发到相应的模块. redirect:一般用于用户注销登陆时返回主页面和跳转到其它的网站等 从效率来说 forward:高. redirect

    1.5K10

    java中get请求和post请求的区别

    在Java中,GET请求和POST请求是HTTP协议中两种常见的请求方法,它们在使用方式和传递参数的方式上有一些区别: 请求方式: GET请求: 使用URL来传递参数,参数附在URL的后面,通过?...GET请求通常用于获取数据,对服务器的请求是幂等的,即多次请求的结果相同。 POST请求: 参数是通过请求体传递的,不会附加在URL上。...POST请求通常用于提交数据,对服务器的请求可能产生副作用,不一定是幂等的。 // GET请求示例 String url = "https://example.com/api/resource?...请求: 数据通过URL参数传递,对于一些敏感信息,不适合使用GET请求,因为参数会出现在URL中,可能被他人获取。...请求: 数据量通常受到URL长度的限制,浏览器和服务器对URL长度都有限制。

    99210

    Django的请求与响应

    请求与响应 请求是指浏览器通过HTTP协议发送给服务端的数据 响应指的是服务端收到响应后做相应处理后再返回给浏览器 请求样例 GET /user/api/qoqa HTTP/1.1 ---> 起始行...HEAD 类似于GET请求,只不过返回的响应中没有具体内容,只返回响应头。 POST 向指定资源提交数据进行处理请求,数据被包含在请求体中。 PUT 从客户端向服务器发送的数据取代指定文档中的内容。...Django中的请求 path_info: URL字符串,即当前请求的路径 method: 字符串,表示http的请求方法 GET: QueryDict查询字典的对象,包含get请求方式的所有资源 POST...GET与Post 无论是Get还是Post,都统一用视图函数接受请求,通过判断request.method区分具体的请求动作. if request.method == "GET": 处理GET...请求内容 elif request.method == "POST": 处理POST请求内容 GET处理 GET请求动作,一般用与向服务器获取数据 能够产生GET请求的场景: 浏览器输入URL

    80710
    领券