php redis jsonp,发送 JSONP 请求

本文介绍了JSONP(JSON with Padding)的工作原理,它是如何绕过同源策略,让JavaScript在不支持CORS的浏览器中进行跨域数据请求的。通过创建动态`<script>`标签,并指定一个回调函数名作为查询参数,服务端返回的JSON数据会被包装在这个回调函数中执行。文章详细展示了实现JSONP请求的示例代码,包括如何构建URL、创建回调函数以及处理响应。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

发送 JSONP 请求

由 学院君 创建于7个月前, 最后更新于 7个月前

版本号 #1

333 views

0 likes

0 collects

使用

不受同源策略的影响

包含 JSON 编码数据的响应会自动解析

这种使用

假设你已经写了一个服务,它处理 GET 请求并返回 JSON 编码的数据,同源的文档可以通过 XMLHttpRequest 对象和 JSON.parse(),如果服务器上启用了 CORS,在较新的浏览器上,跨域的文档也可以使用 XMLHttpRequest 享受该服务,在不支持 CORS 的旧版本浏览器中,跨域的文档只能通过 JSONP 访问这个服务。

当通过

在实践中,支持 JSONP 的服务不会强制指定客户端必须实现的回调函数名称,而是使用查询参数的值,允许客户端指定一个函数名,然后使用该函数名去填充响应:

function getJSONP(url, callback) {

// 为本次请求创建一个唯一的回调函数名称

var cbnum = "cb" + getJSONP.counter++;

var cbname = "getJSONP." + cbnum;

// 将回调函数名称以表单编码的形式添加到URL的查询部分

// 使用jsonp作为参数名(另一些常见的实现使用callback作为参数名)

if (url.indexOf("?") === -1) {

url += "?jsonp=" + cbname;

} else {

url += "&jsonp=" + cbname;

}

// 创建 script 元素用于发送请求

var script = document.createElement("script");

// 调用将被脚本执行的回调函数

getJSONP[cbnum] = function (response) {

try {

callback(response);

} finally {

delete getJSONP[cbnum];

script.parentNode.removeChild(script);

}

};

// 立即触发 HTTP 请求

script.src = url;

document.body.appendChild(script);

}

getJSONP.counter = 0;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值