javascript - jquery中的$.post()为什么不能跨域提交数据呢?
问题描述
如题,为什么jquery中封装的ajax方法,使用jsonp可以get方式提交数据,但是直接用post的方式,跨域后就无法提交,其根本原因是什么呢?
问题解答
回答1:jquery自身的功能是不支持的,但是你可以基于jquery实现跨域post。
jquery本身只支持jsonp跨域,但是jsonp的原理限制了只能支持get。
如果想要实现原生jquery跨域,在你的请求地址的head里面加上Access-Control-Allow-Origin,值设置成调用该API的域名(或者*)
回答2:跨域一般分两种:
jsonp 跨域。 jsonp 本来就是使用 get 文件的方法绕过跨域检查,所以不支持post。也有第三方库用get来模拟post请求。
COR 跨域。 COR 跨域需要修改服务端 Access-Control-Allow-Origin 响应。 一般客户端会发送两次 post 请求,第一次类型为 option,服务端响应允许后,第二次发送真正的带数据的请求。如果答主条件许可,尽量使用第二种跨域方法吧,可以直接支持 post。
如果无法修改服务端配置,答主可以去找一下第三方的库,看看能否用jsonp模拟 post 请求。
回答3:注意,不是jquery不支持,而是浏览器在没有允许跨域的头的时候,就把响应拦截掉了,然后给你了个错误。jquery在接收到这个错误之后,就会给你报跨域的错误。你可以抓个包看看(注意不要用浏览器的f12抓包),其实服务端的响应都在的。
相关文章:
1. html - 爬虫时出现“DNS lookup failed”,打开网页却没问题,这是什么情况?2. html - css 如何添加这种边框?3. java - 在局域网中自动探测设备原理4. javascript - 想一周学会增删查改登录,有入门node.js+express+mongoos的好demo 吗,有thinkphp 经验5. javascript - 关于this的指向性问题6. css3 - 如何理解animation-fill-mode及其使用?7. javascript - echart+百度地图8. nginx - 关于vue项目部署到ngnix后出现的问题9. javascript 开发百度地图10. 微信chooseImage接口部分机型选择图片后莫名其妙的跳转其他页面
