AJAX(XMLHttpRequest)进行跨域请求方法详解(一)

2023-05-16

注意:以下代码请在Firefox 3.5、Chrome 3.0、Safari 4之后的版本中进行测试。IE8的实现方法与其他浏览不同。

跨域请求,顾名思义,就是一个站点中的资源去访问另外一个不同域名站点上的资源。这种情况很常见,比如说通过 style 标签加载外部样式表文件、通过 img 标签加载外部图片、通过 script 标签加载外部脚本文件、通过 Webfont 加载字体文件等等。默认情况下,脚本访问文档属性等数据采用的是同源策略(Same origin policy)。

那么,什么是同源策略呢?如果两个页面的协议、域名和端口是完全相同的,那么它们就是同源的。同源策略是为了防止从一个地址加载的文档或脚本访问或者设置从另外一个地址加载的文档的属性。如果两个页面的主域名相同,则还可以通过设置 document.domain 属性将它们认为是同源的。

随着 Web2.0 和 SNS 的兴起,Web 应用对跨域访问的需求也越来越多,但是,在脚本中进行跨域请求是受安全性限制的,Web 开发人员迫切需要提供一种更安全、方便的跨域请求方式来融合(Mashup)自己的 Web 应用。这样做的一个好处就是可以将请求分摊到不同的服务器,减轻单个服务器压力以提高响应速度;另外一个好处是可以将不同的业务逻辑分布到不同的服务器上以降低负载。

值得庆幸的是,跨域请求的标准已经出台,主流浏览器也已经实现了这一标准。W3C 工作组中的 Web Applications Working Group(Web 应用工作组)发布了一个 Cross-Origin Resource Sharing(跨域资源共享,该规范地址:http://www.w3.org/TR/access-control/和http://dev.w3.org/2006/waf/access-control/) 推荐规范来解决跨域请求的问题。该规范提供了一种更安全的跨域数据交换方法。具体规范的介绍可以访问上面提供的网站地址。值得注意的是:该规范只能应用在类似 XMLHttprequest 这样的 API 容器内。IE8、Firefox 3.5 及其以后的版本、Chrome浏览器、Safari 4 等已经实现了 Cross-Origin Resource Sharing 规范,已经可以进行跨域请求了。

Cross-Origin Resource Sharing 的工作方式是通过添加 HTTP 头的方法来判断哪些资源允许 Web 浏览器访问该域名下的信息。然而,对于那些 HTTP 请求导致用户数据产生副作用的请求方法(特别是对于除了GET、某些 MIME 类型的 POST 之外的 HTTP方法),该规范要求浏览器对请求进行“预先验”,通过发送 HTTP 的 OPTIONS 请求头询问服务器有哪些支持的方法,在征得服务器的同意后,再使用实际的 HTTP 请求方法发送实际的请求。服务器也可以通知客户端是否需要将验证信息(如 Cookie 和 HTTP Authentication 数据)随同请求一起发送。

下面我们就采用实际的例子说明 Cross-Origin Resource Sharing 是如何工作的。

 

1,简单请求

 

什么样的请求算是简单请求呢?简单请求必须满足下面2点:
a,只使用 GET、POST 进行的请求,这里的POST只包括发送给服务器的数据类型(Content-Type)必须是 application/x-www-form-urlencoded、multipart/form-data 或者 text/plain中一个。
b,HTTP 请求没有设置自定义的请求头,如我们常用的 X-JSON。

 

先使用下面的代码进行测试:

 

然后,在服务器创建 CrossDomainRequest.aspx 的内容如下:

 

点击 “开始测试” 按钮,发送的请求和返回的响应信息如下:

 

需要特别注意的是:在请求信息中,浏览器使用 Origin 这个 HTTP 头来标识该请求来自于 http://www.meng_xian_hui.com:801;在返回的响应信息中,使用 Access-Control-Allow-Origin 头来控制哪些域名的脚本可以访问该资源。如果设置 Access-Control-Allow-Origin:*,则允许所有域名的脚本访问该资源。如果有多个,则只需要使用逗号分隔开即可。

注意:在服务器端,Access-Control-Allow-Origin 响应头 http://www.meng_xian_hui.com:801 中的端口信息不能省略。

有人可能会想:自己发送请求头会如何呢?比如 xhr.setRequestHeader("Origin","http://www.meng_xian_hui.com:801"); 实践证明,自己设置 Origin 头是不行的。

是不是现在就可以采用 XMLHttpRequest 来请求任意一个网站的数据呢?还是不行的。允许哪些域名可以访问,还需要服务器来设置 Access-Control-Allow-Origin 头来进行授权,具体的代码是:

Response.AddHeader("Access-Control-Allow-Origin", "http://www.meng_xian_hui.com:801");

这行代码就告诉浏览器,只有来自 http://www.meng_xian_hui.com:801 源下的脚本才可以进行访问。

好了,上面我们就完成了一个简单的跨域请求,怎么样?感觉还是不错的吧。下面我们进行一个“预检”请求。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

AJAX(XMLHttpRequest)进行跨域请求方法详解(一) 的相关文章

随机推荐

  • 安装编译tinyply

    1 下载tinyply xff1a https github com ddiakopoulos tinyply 2 修改CmakeLists txt第17行 set SHARED LIB false CACHE BOOL 34 Build
  • crazyswarm下载编译和使用问题整理

    本文写于2021 12 6 最近一次更新为2023 1 5 目录 项目简介 安装步骤 编译报错解决 使用注意 项目简介 crazyswarm版本对应commit为 4d6ca47b085227fbc893479894001d1c7ceab5
  • Word排版过程中多个参考文献一起引用

    最近在写论文的过程中 xff0c 遇到多个参考文献在一起 xff0c 如果手动输入 xff0c 在打印或者转换成pdf的过程中 xff0c 总是只剩下一个文献 如 1 2 3 4 想使用 1 4 来交叉引用 xff1a 1 切换域代码 xf
  • 《成长是一件孤独的事》周国平 书摘

    每个人在世界上都应该有这样一件事情 xff0c 你真正喜欢它 xff0c 做这件事情本身就是享受 xff0c 你没有快乐工作的能力 xff0c 这才是最可悲的 人是带着感情生活 xff0c 有好恶 xff0c 有喜怒哀乐 xff0c 在我看
  • 为什么他们能成为大师-7位华人诺贝尔科学奖得主的成功法则

    7位华人诺贝尔科学奖得主的治学方法有以下特点 xff1a xff08 1 xff09 求知欲强 xff0c 目标很明确 xff08 2 xff09 好问善疑 xff0c 敢于提出问题 xff08 3 xff09 文理兼通 xff0c 艺术修
  • VINS-MONO的运行方法

    在ubuntu16 04上运行vins mono的方法 xff1a 打开三个终端 xff1a 第一个终端输入 xff1a source VINS Mono ws devel setup bash roslaunch vins estimat
  • macbook pro 中安装jupyter notebook 的过程以及遇到的问题

    1 首先打开terminal 使用python命令查看当前python版本为 Python 2 7 10 2 升级pip安装工具 xff1a sudo python m pip install upgrade force pip 注 xff
  • 视觉SLAM十四讲 安装libcxsparse3.1.2报错

    版权声明 xff1a 本文为博主原创文章 xff0c 未经博主允许不得转载 http blog csdn net qq 29985391 article details 79007693 经常会暗示自己学会动脑思考 xff0c 先自己去想解
  • PX4多旋翼航线算法代码解析

    文章目录 前言一 航线算法二 代码解析1 GPS经纬度转地理系下坐标2 scale值的计算3 位置坐标转换4 飞机当前位置距离目标位置误差小于一个单位15 飞机当前位置距离目标位置误差大于等于一个单位16 新计算出的期望位置归一化到单位圆坐
  • ROS入门(八)——仿真机器人四(Gazebo+Rviz+雷达、摄像头、kinet仿真显示)

    所用的学习链接 xff1a 奥特学园 ROS机器人入门课程 ROS理论与实践 零基础教程P278 288 以上视频笔记见http www autolabor com cn book ROSTutorials 官方参考链接 xff1a htt
  • ROS入门(一)——ROS安装(vmware16+ubuntu20.04+ROS-Noetic)

    嵌套 xff1a ROS可以在Ubuntu上运行 xff0c Ubuntu在虚拟机Vmware中安装 从 虚拟机vmware安装 ubuntu安装 ros安装 xff0c 逐步介绍安装ROS环境的过程 整个过程是我一步步跟着各种博客安装实现
  • [原创]人生感悟

    女人最有力的武器不是尖酸刻薄和斤斤计较 xff0c 而是温柔和宽容大度 世界万物都将求一个平衡 xff0c 所有的善行不一定能有回报 xff0c 但是自己种的果实往往都会自己食用 xff0c 不要在年轻的时候鲁莽地为自己挖坑 xff0c 感
  • win10找不到d3dx9_43.dll,无法正常启动0xc000007b

    Win10电脑 xff0c 安装PhoenixRC时 xff0c 安装好后点击运行 xff0c 报错找不到d3dx9 43 dll 按照网上的一些教程下载d3dx9 43 dll并放到C Windows System32 下再运行regsv
  • 收录一些欧美优秀css网站

    http www dezinerfolio com 漂亮欧美风格博客 http hellomac pl http divplayers com http skipvine ro http www tooopen com 虽然是国产的 xff
  • 几种非易失性存储器的比较

    SRAM为数据访问和存储提供了一个快速且可靠的手段 由系统电源或其他备用电源 xff08 如电池 xff09 供电时 xff0c 他们就具有非易失性 表1给出了几种给定的非易失性存储器存储技术的优缺点 表1非易失性存储器比较 NVSRAM中
  • C#向Excel报表中插入图片的2种方法

    这几天做向Excel插入数据 xff0c 其中有插入图片的需求 xff0c 经试验 xff0c 下面2种方法都可以插入图片 xff0c 但各有不同的用处 现将这2种方法共享出来 xff0c 希望需要的朋友进行参考 xff0c 代码中已经有详
  • Response.Redirect 打开新窗口的两种方法

    一般情况下 xff0c Response Redirect 方法是在服务器端进行转向 xff0c 因此 xff0c 除非使用 Response Write 34 lt script gt window location 61 39 http
  • C# 实现向浏览器的兼容性视图列表中添加、删除网站和检查网站是否在兼容性网站列表中

    今天回答论坛上的一个问题 xff0c 搜索了一下网上 xff0c 并没有找到一个完整的例子 xff0c 下面根据网上的一些资料 xff0c 经过转换 完善成一个完整的例子 下面的例子可以实现添加 删除 检测网站是否在兼容性网站列表中的功能
  • Excel中 ColorIndex 属性值和颜色对照表

    Excel中 ColorIndex 属性值和颜色对照表 资料参考 http msdn microsoft com en us library cc296089 aspx http www mvps org dmcritchie excel
  • AJAX(XMLHttpRequest)进行跨域请求方法详解(一)

    注意 xff1a 以下代码请在Firefox 3 5 Chrome 3 0 Safari 4之后的版本中进行测试 IE8的实现方法与其他浏览不同 跨域请求 xff0c 顾名思义 xff0c 就是一个站点中的资源去访问另外一个不同域名站点上的