gpt4 book ai didi

python - 使用 chrome POSTMAN 测试 http POST 时,它在 django 中不起作用

转载 作者:太空宇宙 更新时间:2023-11-03 13:36:51 27 4
gpt4 key购买 nike

我使用 Django 1.9.7 & Python 3.5

我实现了创建用户机制并尝试使用 POSTMAN(chrome 应用程序)进行测试,但它不起作用并且显示如下内容:

Forbidden (CSRF cookie not set.): /timeline/user/create/

这是代码:

urls.py

from django.conf.urls import url
From. import views

app_name = 'timeline'
urlpatterns = [
# ex) /
url(r'^$', views.timeline_view, name='timeline_view'),

# ex) /user/create
url(r'^user/(?P<method>create)/$', views.user_view, name='user_view'),
]

views.py

from django.contrib.auth import authenticate, login, logout
from django.shortcuts import render, HttpResponse

from timeline.models import *


def timeline_view(request):
return HttpResponse('hello world')


def user_view(request, method):
if method == 'create' and request.method == 'POST':
print("hi")
username = request.POST.get('username')
username = request.POST.get('username')
user = User.objects.create_user(username, password=password)
user.first_name = request.POST.get('name','')
user.save()
profile = UserProfile()
profile.user = user
profile.save()
return HttpResponse('create success')
else:
return HttpResponse('bad request', status=400)

postman : enter image description here

我试过了 Django CSRF Cookie Not Set但我认为这篇文章适用于过去的版本。

最佳答案

对于测试,我使用了@csrf_exempt 装饰器。

from django.views.decorators.csrf import csrf_exempt

@csrf_exempt
def user_view(request, method):
...

现在您应该可以在没有 csrf cookie 的情况下调用此函数。

(我上次尝试时,我使用的是 django 1.8.7)

来源: https://docs.djangoproject.com/en/1.9/ref/csrf/#edge-cases

关于python - 使用 chrome POSTMAN 测试 http POST 时,它在 django 中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38305269/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com