django 取消csrf限制的实例
# 导入包
from django.views.decorators.csrf import csrf_exempt
# 使用装饰器即可避免csrf限制
@csrf_exemptdef add_bookshelf(request): user_id = request.POST.get(’user_id’) print(user_id) return HttpResponse(’123’)
补充知识:Django 前后端分离跨域AJAX获取csrftoken及获取cookie时遇到的问题
获取CSRFTOKEN
Django的中间件’django.middleware.csrf.CsrfViewMiddleware’会将csrftoken的值设置在cookie中。在前后端不分离的项目中,若需要在AJAX使用csrftoken的值则可在js脚本中通过document.cookie直接获取cookie的值(也可以通过其他更快捷的轮子如js-cookie)。
在前后端分离的项目中(已配置django-cors-headers),无法直接使用js从cookie中获取csrfToken的值(浏览器的同源策略),即使已经成功设置了csrfToken的cookie值
解决方法
在中间件中引入
corsheaders.middleware.CorsPostCsrfMiddleware’corsheaders.middleware.CorsMiddleware’,’django.middleware.security.SecurityMiddleware’,’django.contrib.sessions.middleware.SessionMiddleware’,’django.middleware.common.CommonMiddleware’,’django.middleware.csrf.CsrfViewMiddleware’,’corsheaders.middleware.CorsPostCsrfMiddleware’,
有些博客中使用该中间件替代django.middleware.csrf.CsrfViewMiddleware是不可行的,因为该中间件并没有期望中csrf校验的功能,下面为该中间件的源代码。
class CorsPostCsrfMiddleware(MiddlewareMixin): def _https_referer_replace_reverse(self, request): ''' Put the HTTP_REFERER back to its original value and delete the temporary storage ''' if conf.CORS_REPLACE_HTTPS_REFERER and ’ORIGINAL_HTTP_REFERER’ in request.META: http_referer = request.META[’ORIGINAL_HTTP_REFERER’] request.META[’HTTP_REFERER’] = http_referer del request.META[’ORIGINAL_HTTP_REFERER’] def process_request(self, request): self._https_referer_replace_reverse(request) return None def process_view(self, request, callback, callback_args, callback_kwargs): self._https_referer_replace_reverse(request) return None
以上这篇django 取消csrf限制的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持好吧啦网。
相关文章:
1. Java构建JDBC应用程序的实例操作2. javascript设计模式 ? 建造者模式原理与应用实例分析3. Python使用oslo.vmware管理ESXI虚拟机的示例参考4. Express 框架中使用 EJS 模板引擎并结合 silly-datetime 库进行日期格式化的实现方法5. IDEA的Mybatis Generator驼峰配置问题6. 一篇文章带你了解JavaScript-对象7. IntelliJ IDEA设置条件断点的方法步骤8. Jsp中request的3个基础实践9. python flask框架快速入门10. 浅谈SpringMVC jsp前台获取参数的方式 EL表达式
