jsonp跨域原理简单总结_jsonp的工作原理

jsonp跨域原理简单总结_jsonp的工作原理JavaScript是一种在Web开发中经常使用的前端动态脚本技术。在JavaScript中,有一个很重要的安全性限制,被称为“Same-OriginPolicy”(同源策略)。这一策略对于JavaScript代码能够访问的页面内容做了很重要的限制,即JavaScript只能访问与包含它的文档在同一域下的内容。JavaScript这个安全策略在进行多iframe或多窗口编程、以及Ajax

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

JavaScript是一种在Web开发中经常使用的前端动态脚本技术。在JavaScript中,有一个很重要的安全性限制,被称为“Same-Origin Policy”(同源策略)。

这一策略对于JavaScript代码能够访问的页面内容做了很重要的限制,即JavaScript只能访问与包含它的文档在同一域下的内容。

JavaScript这个安全策略在进行多iframe或多窗口编程、以及Ajax编程时显得尤为重要。

通过XMLHttpRequest实现的Ajax请求,不能向不同的域提交请求,例如,在abc.example.com下的页面,不能向def.example.com提交Ajax请求。

然而,当进行一些比较深入的前端编程的时候,不可避免地需要进行跨域操作,这时候“同源策略”就显得过于苛刻。

JSONP跨域GET请求是一个常用的解决方案,下面我们来看一下JSONP跨域是如何实现的,并且探讨下JSONP跨域的原理。

 

利用在页面中创建<script>节点的方法向不同域提交HTTP请求的方法称为JSONP,这项技术可以解决跨域提交Ajax请求的问题

假设在http://example1.com/index.php这个页面中向http://example2.com/getinfo.php提交GET请求,我们可以将下面的JavaScript代码放在http://example1.com/index.php这个页面中来实现:

var eleScript= document.createElement("script");  
eleScript.type = "text/javascript";  
eleScript.src = "http://example2.com/getinfo.php";  
document.getElementsByTagName("head")[0].appendChild(eleScript); 

Jetbrains全家桶1年46,售后保障稳定


JSONP的
优点


它不像XMLHttpRequest对象实现的Ajax请求那样受到同源策略的限制;兼容性好

当GET请求从http://example2.com/getinfo.php返回时,可以返回一段JavaScript代码,这段代码会自动执行,可以用来负责调用http://example1.com/index.php页面中的一个callback函数。

JSONP的缺点是它只支持GET请求而不支持POST等其它类型的HTTP请求;不能解决不同域的两个页面之间如何进行JavaScript调用的问题。

http://跨域的dns/document!searchJSONResult.action?&jsoncallback=jsonp1236827957501&_=1236828192549&searchWord=%E7%94%A8%E4%BE%8B¤tUserId=5351&conditionBean.pageSize=15

 在响应端(http://跨域的dns/document!searchJSONResult.action),通过 jsoncallback = request.getParameter(“jsoncallback”) 得到jquery端随后要回调的js function name:jsonp1236827957501 然后 response的内容为一个Script Tags:”jsonp1236827957501(“+按请求参数生成的json数组+”)”; jquery就会通过回调方法动态加载调用这个js tag:jsonp1236827957501(json数组); 这样就达到了跨域数据交换的目的。

JSONP原理

JSONP的最基本的原理是:动态添加一个<script>标签,而script标签的src属性是没有跨域的限制的。这样说来,这种跨域方式其实与ajax XmlHttpRequest协议无关了。

这样其实”jQuery AJAX跨域问题”就成了个伪命题,jquery $.ajax方法名有误导人之嫌。

如果设为dataType: ‘jsonp’,这个$.ajax方法就和ajax XmlHttpRequest没什么关系了,取而代之的则是JSONP协议。

JSONP是一个非官方的协议,它允许在服务器端集成Script tags返回至客户端,通过javascript callback的形式实现跨域访问。

JSONP即JSON with Padding。由于同源策略的限制,XmlHttpRequest只允许请求当前源(域名、协议、端口)的资源。

如果要进行跨域请求,我们可以通过使用html的script标记来进行跨域请求,并在响应中返回要执行的script代码,其中可以直接使用JSON传递javascript对象。这种跨域的通讯方式称为JSONP。

jsonCallback函数jsonp1236827957501(….):是浏览器客户端注册的,获取跨域服务器上的json数据后,回调的函数

Jsonp的执行过程如下:

首先在客户端注册一个callback (如:’jsoncallback’), 然后把callback的名字(如:jsonp1236827957501)传给服务器。注意:服务端得到callback的数值后,要用jsonp1236827957501(……)把将要输出的json内容包括起来,此时,服务器生成 json 数据才能被客户端正确接收。

然后以 javascript 语法的方式,生成一个function,function名字就是传递上来的参数 ‘jsoncallback’的值 jsonp1236827957501 .

最后将 json 数据直接以入参的方式,放置到 function 中,这样就生成了一段 js 语法的文档,返回给客户端。

客户端浏览器,解析script标签,并执行返回的 javascript 文档,此时javascript文档数据,作为参数,传入到了客户端预先定义好的 callback 函数里。

可以说jsonp的方式原理上和<script src=”http://跨域/…xx.js”></script>是一致的。JSONP是一种脚本注入(Script Injection)行为,所以有一定的安全隐患。

那jquery为什么不支持post方式跨域呢?

虽然采用post+动态生成iframe是可以达到post跨域的目的,但这样做是一个比较极端的方式,不建议采用。

也可以说get方式的跨域是合法的,post方式从安全角度上,被认为是不合法的,万不得已还是不要剑走偏锋。

来个超简单的例子:

<!DOCTYPE HTML>   
<html>   
<head>   
<title>Test Jsonp</title>  
<script type="text/javascript">   
function jsonpCallback(result)   {   
 	alert(result.msg);   
 	}   
</script>  
<script type="text/javascript"src="http://crossdomain.com/jsonServerResponse?jsonp=jsonpCallback"></script>   
</head>   
</html>   


http://crossdomain.com/jsonServerResponse?jsonp=jsonpCallback 这个 url 是跨域服务器取 json 数据的接口,参数为回调函数的名字,返回的格式为:jsonpCallback({msg:’this is json data’})
其中 jsonCallback 是客户端注册的,获取跨域服务器上的json数据后回调的函数。

简述原理与过程:

首先在客户端注册callback,然后把callback的名字传给服务器。

此时,服务器生成 json 数据。然后以 javascript 语法的方式,生成一个function , function 名字就是传递上来的参数 jsonp。

最后将 json 数据直接以入参的方式,放置到 function 中,这样就生成了一段 js 语法的文档,返回给客户端。

客户端浏览器,解析script标签,并执行返回的 javascript 文档,此时数据作为参数,传入到了客户端预先定义好的 callback 函数里。(动态执行回调函数)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/234143.html原文链接:https://javaforall.net

(0)
上一篇 2025年6月10日 下午8:15
下一篇 2025年6月10日 下午8:43


相关推荐

  • 机器学习算法——感知机&支持向量机

    机器学习算法——感知机&支持向量机1 前言本篇博客主要详细介绍两种具有一定相似性的机器学习算法 感知机 Perceptron 和支持向量机 SVM 该两种算法都是在特征空间中寻找划分平面从而对数据集进行划分的思想 但寻找划分平面的算法不同 划分平面的定义也有差距 本篇博客主要叙述思路为算法模型 代价函数 学习算法 最后的算法模型使用实例介绍 这两种机器学习的算法的实例都是基于 Titanic 数据集 关于数据集的特征工程部分就不具体

    2026年3月26日
    2
  • 阿里云服务器端口开放访问不了_阿里云服务器能不能翻墙

    阿里云服务器端口开放访问不了_阿里云服务器能不能翻墙最近在自己写前端后端代码,然后部署在服务器上。在部署后端代码后发现通过域名访问不了该端口,正常情况下启动服务后就能访问,于是发现需要开放该端口。这里以阿里云的服务器为例:首先登录阿里云账号后,进入服务器管理页面。找到左侧的防火墙选项卡找到右侧的添加规则按钮点击后,应用类型选择自定义,然后填写端口范围,即你要公开访问的端口号,然后点击确定。以上步骤完成后,即可访问该端口…

    2022年10月2日
    5
  • IE10/IE11兼容视图设置方法_ie浏览器兼容性视图设置

    IE10/IE11兼容视图设置方法_ie浏览器兼容性视图设置如何设置ie11浏览器兼容性视图?ie浏览器是系统自带的浏览器,由于兼容性问题不受欢迎。接下来小编就给大家介绍一下如何设置ie11浏览器兼容性视图。具体如下:1.首先第一步打开电脑中的【ie浏览器】。2.第二步进入浏览器首页后,根据下图所示,点击页面右上方的齿轮图标。3.第三步在弹出的菜单栏中,根据下图所示,点击【兼容性视图设置】选项。4.第四步进入【兼容性视图设置】页面后,根据下图所示,…

    2025年8月29日
    6
  • 36.Oracle深度学习笔记——SLOB 工具使用

    36.Oracle深度学习笔记——SLOB 工具使用36 Oracle 深度学习笔记 SLOB 工具使用 nbsp 欢迎转载 转载请标明出处 SLOB 全称 SillyLittleO 主要目的是防止内部争用 测试数据库的物理 IO 逻辑 IO REDO 带宽 工具下载链接如下 http oaktable net articles slob silly little oracle benchmark 直接解压得到

    2026年3月17日
    2
  • 《Effective C++ 》学习笔记——规定10「建议收藏」

    《Effective C++ 》学习笔记——规定10

    2022年1月17日
    49
  • 建模方法(四)-因子分析定义和应用

    建模方法(四)-因子分析定义和应用因子分析 factoranalys 也是一种降维 简化数据的技术 它通过研究众多变量之间的内部依赖关系 使用少数几个 抽象 的变量来表示其基本的数据结构 这几个抽象的变量被称作 因子 能反映原来众多变量的主要信息 原始的变量是可观测的显在变量 而因子一般是不可观测的潜在变量 例如 商店的环境 商店的服务和商品的价格作为因子 这三个方面除了价格外 商店的环境和服务质量 都是客观

    2026年3月19日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号