AJAX和Python错误-请求的资源上不存在“Access Control Allow Origin”头

2024-09-27 07:35:51 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在构建一个Javascript库,它可以使用AJAX与一个简单的Python web服务器对话。

以下是web服务器类:

class WebHandler(http.server.BaseHTTPRequestHandler):

    def parse_POST(self):
        ctype, pdict = cgi.parse_header(self.headers['content-type'])
        if ctype == 'multipart/form-data':
            postvars = cgi.parse_multipart(self.rfile, pdict)
        elif ctype == 'application/x-www-form-urlencoded':
            length = int(self.headers['content-length'])
            postvars = urllib.parse.parse_qs(self.rfile.read(length),
                                             keep_blank_values=1)
        else:
            postvars = {}
        return postvars

    def do_POST(self):
        postvars = self.parse_POST()

        print(postvars)

        # reply with JSON
        self.send_response(200)
        self.send_header("Content-type", "application/json")
        self.end_headers()
        json_response = json.dumps({'test': 42})
        self.wfile.write(bytes(json_response, "utf-8"))

下面是我使用的Javascript方法:

var send_action = function() {
    var url = "http://192.168.1.51:8000";
    var post_data = {'gorilla': 'man'};

    $.post(url, post_data, function(data) {
        alert("success");

    })
      .done(function(data) {
        alert("second success");

    })
      .fail(function() {
        alert("error");

    })
      .always(function() {
        alert("finished");
    });
};

当我运行服务器并调用JS函数时,服务器会打印{'gorilla': 'man'},但是浏览器会闪烁错误警报,然后闪烁完成警报。在开发人员日志中,我有:

XMLHttpRequest cannot load http://192.168.1.51:8000/. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'null' is therefore not allowed access.

当我在$.post中指定*dataType*s时,会发生同样的事情,如下所示:

$.post(url, post_data, function(data) {
    alert( "success" );
}, 'json')

或者

$.post(url, post_data, function(data) {
    alert( "success" );
}, 'jsonp')

服务器和浏览器会话都在同一台计算机上。

解决方案

需要在self.send_header("Content-type", "application/json")之后添加额外的头:

self.send_header("Access-Control-Allow-Origin", "*");
self.send_header("Access-Control-Expose-Headers", "Access-Control-Allow-Origin");
self.send_header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");

Tags: self服务器sendjsonurldataaccessparse
1条回答
网友
1楼 · 发布于 2024-09-27 07:35:51

有很多主题是关于:访问控制允许原点。阅读更多:http://en.wikipedia.org/wiki/Same_origin_policy

在后面添加这行:self.send_header("Content-type", "application/json")

self.send_header("Access-Control-Allow-Origin","*");
self.send_header("Access-Control-Expose-Headers: Access-Control-Allow-Origin");
self.send_header(("Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept");

相关问题 更多 >

    热门问题