热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

前端跨域访问后端数据的方法

参考链接:https:mp.weixin.qq.coms4G_27oRLSMMYBFvtYZgqcg一、什么是跨域当两个域名的协议、子域名、主域名、端口号中有任意一个不

参考链接:https://mp.weixin.qq.com/s/4G_27oRLSMMYBFvtYZgqcg

一、什么是跨域

当两个域名的协议、子域名、主域名、端口号中有任意一个不相同的时候,两者之间的请求便存在跨域。

1、什么是同源策略及其限制内容

  同源策略是一种约定,它是浏览器最核心也是最基本的安全功能。如果缺少了同源策略,浏览器很容易遭受XSS、CSRF等攻击。所谓同源是指\'协议+域名(子域名、主域名)+端口号\'三者相同,即便两个不同域名指向同一个IP,也不属于同源。

2、常见的跨域场景

 

 

 特别说明:

  HTML标签中img、link、script的这三个标签允许跨域加载资源

注:

1.请求跨域了,那么请求有没有发出去?

  跨域并不是请求发不出,请求能正常发送并且服务器也能正常接收和返回结果,只不过结果被浏览器拦截了。

2.为什么表单方式可以发起跨域请求而Ajax不能?

  归根结底,跨域是为了阻止用户读取到另一个域名下的内容。Ajax可以获取响应,浏览器认为不安全拦截了响应。但是表单并不会获取新的内容,所以可以发起跨域请求。同时也说明了跨域并不能完全阻止CSRF,因为请求已经发出去了。

二、跨域解决方案

1、JSONP

  原理:利用script标签没有跨域限制的漏洞,网页可以得到其他动态来源的JSON数据。此方式需要目标服务器支持才能实现。

  1.1 Ajax与JSONP对比

  原则上两者都是客户端向服务端发送请求并获取服务端返回的数据。但是Ajax属于同源策略,JSONP属于非同源策略。

  1.2 JSONP的优缺点

  优点:JSONP的兼容性好,能解决大部分主流浏览器的跨域数据访问的问题。

  缺点:JSONP仅仅支持get请求,对数据安全性无法保障

  1.3 Jquery中ajax通过jsonp获取跨域数据示例
  请求方JS代码:

$(function () {
    $.ajax({
        url:\'http://test.cache.com/index/checkjsonp.html\',
        dataType:\'jsonp\',
        type:\'get\',
        jsonpCallback:\'checkCallback\', //自定义传递给服务器的函数名,而不是使用jQuery自动生成的,可省略
        jsonp:"callback",
        success:function (data) {
            console.log(data)
        },
        error:function () {
            alert(\'error\')
        }
    })
});

 跨域服务器返回PHP代码:

    public function checkJsonp()
    {
        echo "checkCallback(".json_encode(array(\'success\'=>1)).")";
    } 

   返回结果:

2、HTTP访问控制(CORS)

 2.1 原理:  

          CORS需要浏览器和服务器同时支持,IE8和9需要通过XDomainRequest来实现,存在一定的兼容性问题。

     浏览器会自动的进行CORS通信,实现CORS通信的关键在于服务器。只要服务器实现了CORS,也就实现了跨域 

 2.2 实现:

    服务端设置 Access-Control-Allow-Origin 就可以开启CORS。该属性表示那些域名可以访问该网站,如果设置成通配符则表示所有网站均可访问

 2.3 示例:

  JS代码:

$(function () {
    $.ajax({
        url:\'http://test.cache.com/index/checkjsonp.html\',
        dataType:\'json\',
        type:\'get\',
        success:function (data) {
            console.log(data)
        },
        error:function () {
            alert(\'error\')
        }
    })
});

 PHP代码:

    public function checkJsonp()
    {
        header("Access-Control-Allow-Origin:http://initial.think6.com");
        header(\'Access-Control-Allow-Methods:OPTIONS, GET, POST\'); // 允许option,get,post请求
        header(\'Access-Control-Allow-Headers:x-requested-with\'); // 允许x-requested-with请求头
        echo json_encode(array(\'success\'=>1));
    }

 返回结果:

3、WebSocket

原理:WebSocket是一种通信协议,它实现了浏览器与服务器之间的全双工通信(即通信双方可以同时发动和接收信息的信息交互方式)。同时websocket并不实行同源策略,只要服务器支持,它就可以实现跨域通信。

4、Node中间件代理

原理:同源策略是浏览器需要遵循的标准,服务器向服务器请求则无需遵循同源策略,从而实现跨区数据请求。

 

5、nginx反向代理

实现原理类似于Node中间件,需要搭建一个中转nginx服务器,用于转发请求。使用nginx反向代理实现跨域是最简单的方式,只需要修改nginx服务器配置即可解决跨域问题,支持所有浏览器、session。无需修改代码且不会影响服务器性能。

 

 

 

 

 

 

   

 


推荐阅读
  • 本文介绍了作者在开发过程中遇到的问题,即播放框架内容安全策略设置不起作用的错误。作者通过使用编译时依赖注入的方式解决了这个问题,并分享了解决方案。文章详细描述了问题的出现情况、错误输出内容以及解决方案的具体步骤。如果你也遇到了类似的问题,本文可能对你有一定的参考价值。 ... [详细]
  • 使用nodejs爬取b站番剧数据,计算最佳追番推荐
    本文介绍了如何使用nodejs爬取b站番剧数据,并通过计算得出最佳追番推荐。通过调用相关接口获取番剧数据和评分数据,以及使用相应的算法进行计算。该方法可以帮助用户找到适合自己的番剧进行观看。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文介绍了C#中生成随机数的三种方法,并分析了其中存在的问题。首先介绍了使用Random类生成随机数的默认方法,但在高并发情况下可能会出现重复的情况。接着通过循环生成了一系列随机数,进一步突显了这个问题。文章指出,随机数生成在任何编程语言中都是必备的功能,但Random类生成的随机数并不可靠。最后,提出了需要寻找其他可靠的随机数生成方法的建议。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • t-io 2.0.0发布-法网天眼第一版的回顾和更新说明
    本文回顾了t-io 1.x版本的工程结构和性能数据,并介绍了t-io在码云上的成绩和用户反馈。同时,还提到了@openSeLi同学发布的t-io 30W长连接并发压力测试报告。最后,详细介绍了t-io 2.0.0版本的更新内容,包括更简洁的使用方式和内置的httpsession功能。 ... [详细]
  • Html5-Canvas实现简易的抽奖转盘效果
    本文介绍了如何使用Html5和Canvas标签来实现简易的抽奖转盘效果,同时使用了jQueryRotate.js旋转插件。文章中给出了主要的html和css代码,并展示了实现的基本效果。 ... [详细]
  • Ihavethefollowingonhtml我在html上有以下内容<html><head><scriptsrc..3003_Tes ... [详细]
author-avatar
潇潇雨621715
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有