跨域问题

一、跨域产生的原因:因为ajax有一个同源策略,但咱们调用的接口来自于第三方网站,那这里必须跨域

二、什么情况下会产生跨域:

协议名://二级域名.一级域名.类型:端口号/目录1/文件名?参数1=值&参数2=值2&参数3=值31.协议不同2.端口不同3.主域不同4.主域相同,子域不同5.域名和ip

三、跨域解决方案

jsonp:前端+后端CORS:服务端http://www.ruanyifeng.com/blog/2016/04/cors.html  代理(服务端代理,客户端代理)

ajax跨域错误提示:

Failed to loadhttps://api.douban.com/v2/movie/search?q=%E7%BA%A2%E6%B5%B7%E8%A1%8C%E5%8A%A8: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://127.0.0.1:8080' is therefore not allowed access.

vue代理实现:

打开vue脚手架->config->index.js,找到  dev: {proxyTable: {'/v2':{    target:'https://api.douban.com',//要代理的接口changeOrigin:true,//实现跨域pathRewrite: {'^/v2':'/v2'}  }},

jsonp实现原理:动态创建script标签 ,因为script中的src有跨域能力

jsonp实现步骤:

前端实现:

  第一步:动态创建script标签,并添加callback参数

  第二步:要创建callback函数 例如:getdata

后端实现:

第一步:接收浏览器传递过来的callback函数  例如:$callback=$_GET['callback'];第二步:返回函数调用形式,其内部的参数就是json例如:echo$callback."(".$json.")";

jsonp缺点:只支持 get请求

jsonp优点:兼容性比较好 兼容:IE5+

CORS跨域:http://www.ruanyifeng.com/blog/2016/04/cors.html

php 实现的cors跨域:header('Access-Control-Allow-Origin: *');

缺点:只支持IE10+

优点:

1.前端无需改代码,

2.支持所有请求方式 包括:post,delete,put,get

作者:奇妙雨

链接:https://www.jianshu.com/p/08d47e51a5b9

來源:简书

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1. 什么是跨域? 跨域一词从字面意思看,就是跨域名嘛,但实际上跨域的范围绝对不止那么狭隘。具体概念如下:只要协议...
    他在发呆阅读 4,218评论 0 0
  • 1. 什么是跨域? 跨域一词从字面意思看,就是跨域名嘛,但实际上跨域的范围绝对不止那么狭隘。具体概念如下:只要协议...
    稍纵即逝_e5e9阅读 1,531评论 0 0
  • 跨域问题的场景和解决方案多种多样,只要是做前端开发,总会遇到。而且面试时也是必问的问题。所以自己学习总结记录一下。...
    花开_陈凤娟阅读 4,028评论 0 0
  • 浏览器在请求不同域的资源时,会因为同源策略的影响请求不成功,这就是通常被提到的“跨域问题”。作为前端开发,解决跨域...
    SCQ000阅读 7,460评论 1 52
  • 跨域失败 当使用jsonp跨域时, 1:请求必须是GET 2:python 写的webservice返回的格式是J...
    旅行家John阅读 3,325评论 0 1

友情链接更多精彩内容