码迷,mamicode.com
首页 > 其他好文 > 详细

DRF框架中csrf异常

时间:2019-10-04 21:16:09      阅读:110      评论:0      收藏:0      [点我收藏+]

标签:框架   mes   解决   The   使用   ajax   tail   set   led   

一.报错信息

"detail": "CSRF Failed: CSRF cookie not set."

二.解决办法

方法一:

在配置文件中配置

REST_FRAMEWORK = {
    'DEFAULT_AUTHENTICATION_CLASSES': (
        'rest_framework.authentication.TokenAuthentication',
    )
}

方法二.在提交信息中加上csrf_token:

页面form框中设置

{% csrf_token %}
这代码在页面中的显示内容
<input type="hidden" name="csrfmiddlewaretoken" value="l9gICFdVzkDkLExUoAPRpE0ElkGtG70Xmn6u536Keo3kaQPXEeC00g5kbnY3vJGd">

如果是ajax提交的话

在data中加上

data:{
    ..
    ..
   'csrfmiddlewaretoken': '{{csrf_token}}' //或者 'csrfmiddlewaretoken':'l9gICFdVzkDkLExUoAPRpE0ElkGtG70Xmn6u536Keo3kaQPXEeC00g5kbnY3vJGd'
}

三.奇怪现象肯能与django中中间件有冲突

django中间件

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

如果在中间件中把‘django.middleware.csrf.CsrfViewMiddleware‘,注释掉你用方法二的时候也会报错,只有方法一能正常使用

DRF框架中csrf异常

标签:框架   mes   解决   The   使用   ajax   tail   set   led   

原文地址:https://www.cnblogs.com/pythonywy/p/11622917.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!