React Post请求跨域问题
- 前后端分离,前端ReactJS,后端PHP(Laravel), 本地调试的时候想调用远端接口。
- 前端配置:在pakcage.json中配置代理如下:
"proxy": "https://www.shufadict.com/api",
- 后端配置:Laravel添加中间件,配置允许跨域,如下:
header('Access-Control-Allow-Origin: *');
header("Access-Control-Allow-Credentials: false");
header("Access-Control-Allow-Methods: PUT, POST, GET, DELETE, OPTIONS");
header("Access-Control-Allow-Headers: Content-Type, Access-Token, nonce, timestamp, packagename, sign, uuid");
header("Access-Control-Expose-Headers: *");
结果,所有get请求都ok,但是post请求都返回如下错误:
Access to XMLHttpRequest at 'https://www.shufadict.com/' (redirected from 'http://localhost:3000/common/feedback') from origin 'http://localhost:3000' has been blocked by CORS policy: Response to preflight request doesn't pass access control check: It does not have HTTP ok status.
求指点,困扰好几天了。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
webpack 参考这个看有没有帮助 https://webpack.docschina.org/configuration/dev-server/#devserverproxy
header带上这个 withCredentials: true 试一下
如果你请求用的axios:
自己回答一下,其实出现下面这个提示表示已经没有跨域问题了,只是后端没有返回http ok状态而已:
Response to preflight request doesn't pass access control check: It does not have HTTP ok status.
我的post参数传的有问题,在后端拦截器中就报错了,没有返回http ok的状态。故而出现了这个错误。