当前端提出请求时,API标头不在Python-Tornado工作
我有一个基本的CRUD应用程序,并且我正在尝试在Localhost上获得React-Redux:3000,以向后端提出请求,Python-Tornado(使用Pymongo用于数据库),在127.0.0.0.1:8888。起初,CORS阻止了所有请求,但是我在网上发现您可以添加标题以允许访问API,因此我确实喜欢:
class UserHandler(tornado.web.RequestHandler):
def set_default_headers(self):
self.set_header("Access-Control-Allow-Origin", "*")
self.set_header("Access-Control-Allow-Headers", "Origin, X-Requested-With,
Content-Type, Accept, Authorization")
self.set_header('Access-Control-Allow-Methods',
'GET,HEAD,OPTIONS,POST,PUT,DELETE')
self.set_status(204)
def get(self, id=None):
{...}
def post(self):
{...}
def delete(self, id):
{...}
def put(self, id):
{...}
def make_app():
return tornado.web.Application([
(r"/users/(?P<id>\w+)", UserHandler),
(r"/user/(?P<id>\w+)", UserHandler),
(r"/users", UserHandler)
],
debug = True,
autoreload = True)
if __name__ == "__main__":
app = make_app()
port = 8888
app.listen(port)
print(f"
I've got a basic CRUD application, and I'm trying to get React-Redux on localhost:3000 to make requests to the backend, Python-Tornado (using pymongo for the database) at 127.0.0.1:8888. At first CORS was blocking all requests, but I found online that you can add headers to allow access to the API, so I did like this:
class UserHandler(tornado.web.RequestHandler):
def set_default_headers(self):
self.set_header("Access-Control-Allow-Origin", "*")
self.set_header("Access-Control-Allow-Headers", "Origin, X-Requested-With,
Content-Type, Accept, Authorization")
self.set_header('Access-Control-Allow-Methods',
'GET,HEAD,OPTIONS,POST,PUT,DELETE')
self.set_status(204)
def get(self, id=None):
{...}
def post(self):
{...}
def delete(self, id):
{...}
def put(self, id):
{...}
def make_app():
return tornado.web.Application([
(r"/users/(?P<id>\w+)", UserHandler),
(r"/user/(?P<id>\w+)", UserHandler),
(r"/users", UserHandler)
],
debug = True,
autoreload = True)
if __name__ == "__main__":
app = make_app()
port = 8888
app.listen(port)
print(f"???? Server is listening on port {8888}")
#start server on current thread
tornado.ioloop.IOLoop.current().start()
Now my Front end is allowing GET requests, but POST, PUT, and DELETE are still getting blocked with the following error:
Access to XMLHttpRequest at 'http://127.0.0.1:8888/users/625f7194a10940f94e0b8f13'
from origin 'http://localhost:3000' has been blocked by CORS policy: Response to
preflight request doesn't pass access control check: The 'Access-Control-Allow-
Origin' header has a value 'https://localhost:3000' that is not equal to the supplied
origin.
I've looked around at multiple resources and they all say to simply add those headers, so I'm not sure where to go from here.
Any help is appreciated, thanks!
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
code-apprentice by code-apprentice 是正确的:请求原点与
access> access-access-control-允许原素
标头。但是,为了在开发过程中(在调试模式下)保持更容易的状态,您可以始终允许当前的请求来源或设置通配符值。如果您想从多个设备进行测试(因为您不需要重新配置原始标头)也将很有用。
这就是我在项目中所做的:
The answer by Code-Apprentice is correct: the request origin doesn't match the value in
Access-Control-Allow-Origin
header.However, to keep things easier during development (while in debug mode), you can always allow the current request origin or just set wildcard values. This will also be useful if you want to test from multiple devices (as you won't need to reconfigure the origin header).
This is what I do in my projects:
您的React代码似乎向
http://127.0.0.1:3000
提出了请求/localhost:3000 。就标题而言,这是两个不同的主机。只要使它们俩都一样。Your react code appears to make a request to
http://127.0.0.1:3000
, but yourAccess-Control-Allow-Origin
only allowshttps://localhost:3000
. These are two different hosts as far as the headers are concerned. Just make them both the same.