跨域

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

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

协议名://二级域名.一级域名.类型:端口号/目录1/文件名?参数1=值&参数2=值2&参数3=值3

1.协议不同
2.端口不同
3.主域不同
4.主域相同,子域不同
5.域名和ip

三、跨域解决方案

jsonp:前端+后端
CORS:服务端 http://www.ruanyifeng.com/blog/2016/04/cors.html
代理(服务端代理,客户端代理)
  ajax跨域错误提示:
 Failed to load https://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
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前言 原文地址:前端跨域总结博主博客地址:Damonare的个人博客 正文 1. 什么是跨域? 跨域一词从字面意思...
    yo_yo_阅读 506评论 0 5
  • 前端开发中,跨域使我们经常遇到的一个问题,也是面试中经常被问到的一些问题,所以,这里,我们做个总结。小小问题,不足...
    Nealyang阅读 483评论 0 0
  • 前言相信每一个前端er对于跨域这两个字都不会陌生,在实际项目中应用也是比较多的。但跨域方法的多种多样实在让人目不暇...
    Www刘阅读 686评论 2 23
  • 文/茶主 近年来妇科疾病的患者数量呈逐年上升趋势,茶主认为这和一些女性朋友不了解妇科常识有关。 妇科疾病包括外阴部...
    悠然茶笙阅读 742评论 0 3
  • 每颗流星都是天际的泪珠,默默的一生,只为那惊鸿的一瞬。我时常在想,是否正因为流星承载了太多的梦想,才会消逝得如此迅...
    徐大锤阅读 1,564评论 0 1