gpt4 book ai didi

python - Django-rest-framework API 测试 403 {'detail' : 'You do not have permission to perform this action.' }

转载 作者:行者123 更新时间:2023-12-01 07:18:05 30 4
gpt4 key购买 nike

我目前正在编写一个测试来测试我的获取请求,获取请求需要 header 中的 jwt access_token,我正在使用 django-rest-framework-simplejwt 来获取 token 并将其用作默认身份验证类

设置.py:

REST_FRAMEWORK = {
# Use Django's standard `django.contrib.auth` permissions,
# or allow read-only access for unauthenticated users.
'DEFAULT_PERMISSION_CLASSES': [
'rest_framework.permissions.IsAdminUser',
],
'DEFAULT_AUTHENTICATION_CLASSES': (
'rest_framework_simplejwt.authentication.JWTAuthentication',
),
# 'DEFAULT_FILTER_BACKENDS': ('django_filters.rest_framework.DjangoFilterBackend',)
}

我的test_api.py:

from rest_framework.test import APITestCase
from rest_framework import status
from rest_framework.test import APIClient
from django.urls import reverse
from listing.models import Property
from backend.models import User

class PropertyTestCase(APITestCase):
def setUp(self):
property_1 = Property.objects.create(title="test", size=322.00, price=8000000, price_rent=300000, price_per_square_meter=500000, price_rent_per_square_meter=20000, description="description 1", type="sell", category="category 1", address="address 1", lat=21.027763, long=105.834160, images=["https://avatars2.githubusercontent.com/u/46511495?s=88&v=4"], contact_name="name 1", contact_address="test address 1", contact_phone="0923512213", contact_email="test@gmail.com", frontend=322, road=32, floor=4, bedroom=5, living_room=6, toilet=2, direction="Nam", balcony="Nam", meta_data={"menu": {"id": "file", "popup": {"menuitem": [{"value": "New", "onclick": "CreateNewDoc()"}, {"value": "Open", "onclick": "OpenDoc()"}, {"value": "Close", "onclick": "CloseDoc()"}]}, "value": "File"}})
property_1.save()
property_2 = Property.objects.create(title="test2", size=322.00, price=8000000, price_rent=300000, price_per_square_meter=500000, price_rent_per_square_meter=20000, description="description 2", type="rent", category="category 2", address="address 2", lat=21.027763, long=105.834160, images=["https://avatars2.githubusercontent.com/u/46511495?s=88&v=4"], contact_name="name 2", contact_address="test address 2", contact_phone="0923512213", contact_email="test2@gmail.com", frontend=322, road=32, floor=4, bedroom=5, living_room=6, toilet=2, direction="Nam", balcony="Nam", meta_data={"menu": {"id": "file", "popup": {"menuitem": [{"value": "New", "onclick": "CreateNewDoc()"}, {"value": "Open", "onclick": "OpenDoc()"}, {"value": "Close", "onclick": "CloseDoc()"}]}, "value": "File"}})
property_2.save()
self.property_1_id = property_1.id
self.property_2_id = property_2.id
self.client = APIClient()

url = '/api/register'
data = {
"username": "dat12@icts.vn",
"password": "123456",
"confirm_password": "123456"
}

response = self.client.post(url, data=data, format='json')
self.access_token = response.json()['data']['access']


def test_list_property_success(self):
url = '/api/property/'
data = {
"page": 1,
"page_size": 2,
}

headers = {
"Authorization": "Bearer {}".format(self.access_token)
}
self.client.credentials(HTTP_AUTHORIZATION='Bearer ' + self.access_token)
response = self.client.get(url, data=data, format='json', headers=headers)
print(response.json())
self.assertEqual(200, response.status_code)

我已经在 postman 中尝试了带有标题授权的 api,并且它有效,我还在测试中打印了访问 token ,它是正确的。

但是当我运行测试 test_list_property_success 当前响应时,代码为 403 和以下响应(在测试中打印出来)

{'detail': 'You do not have permission to perform this action.'}

我已经设置了 self.client.credentials 并在 get 请求中添加了 header ,我不知道还缺少什么。

如有任何帮助,我们将不胜感激

最佳答案

找出原因,因为 DEFAULT_PERMISSION_CLASSES 设置为管理员用户,所以只有管理员角色的 token 可以在我的 api 中使用,所以我更改为:

REST_FRAMEWORK = {
# Use Django's standard `django.contrib.auth` permissions,
# or allow read-only access for unauthenticated users.
'DEFAULT_PERMISSION_CLASSES': [
'rest_framework.permissions.IsAuthenticated',
],
'DEFAULT_AUTHENTICATION_CLASSES': (
'rest_framework_simplejwt.authentication.JWTAuthentication',
),
# 'DEFAULT_FILTER_BACKENDS': ('django_filters.rest_framework.DjangoFilterBackend',)
}

现在它起作用了

关于python - Django-rest-framework API 测试 403 {'detail' : 'You do not have permission to perform this action.' },我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57847439/

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