首页 > 解决方案 > 无法将数组数据发送到 REST 端点

问题描述

我正在使用 Django REST 框架。我有一个看起来像这样的模型:

class Post(models.Model):
    title       = models.CharField(max_length=100, null=False)
    content     = HTMLField()
    created_at  = models.DateField(auto_now_add=True)
    authors     = models.ManyToManyField(User)

使用如下所示的 api 视图和序列化程序:

class CreateStoryApiView(CreateAPIView):
    serializer_class = PostSerializer

class PostSerializer(serializers.ModelSerializer):

    class Meta:
        model = Post
        fields = ('title', 'content', 'authors')

转到实际的端点,我实际上可以成功提交。我正在尝试使用 Ajax 获取详细信息并将数据提交到端点,但由于某种原因,我总是收到 400 bad request 错误。如果我删除作者字段,则不会出现该错误。下面是 Ajax 请求的样子:

$.ajax({
    type: 'POST',
    url: '/api/save-post/',
    data: {
    "csrfmiddlewaretoken": getCookie('csrftoken'),
    "title": "dasf",
    "desct": "dasf",
    "content": "fdasf",
    "authors": [1,2]
    },
    success: function (msg) {
        console.log(msg);
    }
});

尝试此 Ajax 请求时收到 400 错误请求。为什么我不能成功提交我的数组?我已经尝试"authors[]": [1,2]"authors": "[1,2]"很多其他组合,但似乎由于某种原因没有任何效果。我究竟做错了什么?

标签: djangoajaxdjango-modelsdjango-rest-framework

解决方案


检查你的 django settings.py 文件。您需要正确配置下一个参数才能发布来自另一台服务器的请求。

 CORS_ORIGIN_WHITELIST = (
    'localhost',
    'your-domain.com',
    '127.0.0.1',
    '127.0.0.1:8080'
)

CSRF_TRUSTED_ORIGINS = (
    'your-domain.com',
)

CORS_ORIGIN_ALLOW_ALL = True

CORS_EXPOSE_HEADERS = [
'Access-Control-Allow-Origin',
'Access-Control-Allow-Headers'
]

CORS_ALLOW_CREDENTIALS = True

CORS_ALLOW_HEADERS = (
    'accept',
    'accept-encoding',
    'authorization',
    'content-type',
    'cache-control',
    'dnt',
    'origin',
    'user-agent',
    'x-csrftoken',
    'x-requested-with',
)

CORS_ALLOW_METHODS = (
    'DELETE',
    'GET',
    'OPTIONS',
    'PATCH',
    'POST',
    'PUT',
)

我怀疑是因为它


推荐阅读