javascript - jquery中的$.post()为什么不能跨域提交数据呢?
習慣沉默
習慣沉默 2017-05-16 13:36:50
0
3
635

如题,为什么jquery中封装的ajax方法,使用jsonp可以get方式提交数据,但是直接用post的方式,跨域后就无法提交,其根本原因是什么呢?

習慣沉默
習慣沉默

全部回复(3)
世界只因有你

jquery自身的功能是不支持的,但是你可以基于jquery实现跨域post。

jquery本身只支持jsonp跨域,但是jsonp的原理限制了只能支持get。

如果想要实现原生jquery跨域,在你的请求地址的head里面加上Access-Control-Allow-Origin,值设置成调用该API的域名(或者*)

仅有的幸福

跨域一般分两种:

  1. jsonp 跨域。 jsonp 本来就是使用 get 文件的方法绕过跨域检查,所以不支持post。也有第三方库用get来模拟post请求。

  2. COR 跨域。 COR 跨域需要修改服务端 Access-Control-Allow-Origin 响应。 一般客户端会发送两次 post 请求,第一次类型为 option,服务端响应允许后,第二次发送真正的带数据的请求。
    如果答主条件许可,尽量使用第二种跨域方法吧,可以直接支持 post。

如果无法修改服务端配置,答主可以去找一下第三方的库,看看能否用jsonp模拟 post 请求。

阿神

注意,不是jquery不支持,而是浏览器在没有允许跨域的头的时候,就把响应拦截掉了,然后给你了个错误。jquery在接收到这个错误之后,就会给你报跨域的错误。
你可以抓个包看看(注意不要用浏览器的f12抓包),其实服务端的响应都在的。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板