dojo/request PUT方法dosn'不起作用

dojo/request PUT method dosn't work

本文关键字:不起作用 dosn 方法 request PUT dojo      更新时间:2023-09-26

我有一个使用Python Django和Dojo框架的web应用程序。我想从Dojo(使用Dojo/request)向服务器Django发送一个PUT请求,但当服务器收到请求时,其中的数据是空的,并验证Invalid。但当我把方法从PUT改为POST时,它是正确的。

这是我的代码:

_save: function(data){
        var idForm = "editForm" + this.id;
        var value = dijit.byId(idForm).get('value');
        console.log(value);
        request.put("/api/guestbook/"+this.bookName+"/greeting/"+this.id+"/", {
            data: {
                book_name: this.bookName,
                message: value.message
            },
            headers: { "X-CSRFToken": _cookie('csrftoken') }
        }).then(lang.hitch(this, function(text){
        }));
    },

在Django:

def put(self, request, *args, **kwargs):
    form = self.get_form(self.form_class)
    logging.warning(form)
    logging.warning(request.PUT)
    if form.is_valid():
        logging.warning("This form is VALID")
    else:
        logging.warning("This form is INVALID!!!")

有人能帮我吗?谢谢你的帮助!

我在下面找到了接收PUT方法的方法:

def put(self, request, *args, **kwargs):
    request.PUT = QueryDict(request.body)
    form = self.form_class(request.PUT)
    if form.is_valid():
        logging.warning("This form is VALID")
    else:
        logging.warning("This form is INVALID")

这没问题:)

谢谢大家!

我从您的X-CSRFToken标头猜测您正在进行跨域请求,即CORS。

如果你在浏览器的控制台中查看,你可能会看到一个OPTIONS请求被发送到服务器。这被称为"preflight请求",您的服务器需要用CORS头进行响应,告诉浏览器可以进行跨域PUT请求。

在您的情况下,您希望服务器使用类似于的标头进行响应

Access-Control-Allow-Origin: http://your-site-hostname-and-port
Access-Control-Allow-Methods: GET, POST, PUT
Access-Control-Allow-Headers: X-CSRFToken

简单的POST请求不需要preflight OPTIONS请求,这可能就是它工作的原因。这里有一个关于html5rocks的非常好的教程。