时间:2021-05-18
一、 什么是 CSRF ?
CSRF是Cross Site Request Forgery的缩写,看起来和XSS差不多的样子,但是其原理正好相反,XSS是利用合法用户获取其信息,而CSRF是伪造成合法用户发起请求。具体操作原理看google。。
二、Laravel的CSRF防御过程
Laravel 会自动在用户 session (根据session_id 关联确认属于谁) 生成存放一个随机令牌(token)放在session中,并且如果使用 Laravel 的 {{form::open}} 会自动隐藏存在 csrf_token(),如果需要写html form 则需要在表单中添加具体看下图:
三、Token产生原理
通过 Illuminate\Session\Store 类的 getToken 方法获取随机产生长度为40的字符串
以上这篇对laravel的csrf 防御机制详解,及form中csrf_token()的存在介绍就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
用了laravel就会知道其中的csrf验证功能,如果post传值的时候,没有csrf_token就会报如下的错误:这是因5.2之后的版本中会默认在路由里面添加
前端HTML{%loadstatic%}{%get_static_prefixasgetstatic%}用户协议。{%csrf_token%}上面的代码只是HT
home.html:个人信息页面个人信息页面只有返回一串字符串login.html:登录页面登录页面{%csrf_token%}账号:密码:要考虑加上csrf_
1.前台templates/upload/upload.htmlTitle{%csrf_token%}名字:头像:2.项目设定settings.py#添加ALL
djangoajax发送post请求的两种方法,具体内容如下所述:第一种:将csrf_token放在from表单里functionadd_competion_g