Mootools 请求获得“501 不支持的方法('OPTIONS')”响应

gre*_*ghz 2 python mootools http cors

我有这个 mootools 请求:

new Request({
    url: 'http://localhost:8080/list',
    method: 'get',
}).send();
Run Code Online (Sandbox Code Playgroud)

和一个小型 python 服务器,用以下方式处理它:

from BaseHTTPServer import BaseHTTPRequestHandler, HTTPServer
import subprocess

class HttpHandler(BaseHTTPRequestHandler):
    def do_GET(self):
        if self.path == '/list':
            self.list()
        else:
            self._404()

    def list(self):
        self.response200()
        res = "some string"

        self.wfile.write(res)

    def _404(self):
        self.response404()
        self.wfile.write("404\n")

    def response200(self):
        self.send_response(200)
        self.send_header('Access-Control-Allow-Origin', '*')
        self.send_header('Access-Control-Allow-Headers', 'X-Request, X-Requested-With')
        self.send_header('Content-type', 'application/json')
        self.end_headers()

    def response404(self):
        self.send_response(404)
        self.send_header('Content-type', 'application/json')
        self.end_headers()

def main():
    try:
        server = HTTPServer(('', 8080), HttpHandler)
        server.serve_forever()
    except KeyboardInterrupt:
        server.socket.close()

if __name__ == '__main__':
    main()
Run Code Online (Sandbox Code Playgroud)

当我尝试提出此请求时,我收到以下错误:

OPTIONS http://localhost:8080/ 501 (Unsupported method ('OPTIONS'))
XMLHttpRequest cannot load http://localhost:8080/. Origin null is not allowed by Access-Control-Allow-Origin.
Run Code Online (Sandbox Code Playgroud)

我不确定发生了什么事。有人可以帮我吗??

Sin*_*ion 5

正如响应字符串告诉您的那样:OPTIONS http://localhost:8080/ 501 (Unsupported method ('OPTIONS'))

当 javascript 尝试从另一个源请求资源时,现代浏览器首先询问另一个服务器(目标)是否可以从另一个源发出该请求,这正是标头的作用Access-Control*。但这个请求不会正常情况下发生GET,因为无论如何都会实际执行请求,而是使用该OPTIONS方法,该方法存在的唯一原因是通知客户端允许他们做什么,而不是实际执行。

因此,您需要一个do_OPTIONS方法,它可能类似于:

def do_OPTIONS(self):
    if self.path in ('*', '/list'):
        self.send_response(200)
        self.send_header('Allow', 'GET, OPTIONS')
        self.send_header('Access-Control-Allow-Origin', '*')
        self.send_header('Access-Control-Allow-Headers', 'X-Request, X-Requested-With')
    else:
        self.send_response(404)
    self.send_header('Content-Length', '0')
    self.end_headers()
Run Code Online (Sandbox Code Playgroud)