Web课程学习笔记--jsonp的原理与简单实现

jsonp的原理与简单实现

原理

由于同源策略的限制,XmlHttpRequest只允许请求当前源(域名、协议、端口)的资源,为了实现跨域请求,可以通过script标签实现跨域请求,然后在服务端输出JSON数据并执行回调函数,从而解决了跨域的数据请求。

其本质是利用了< script src=”” ></ script >标签具有可跨域的特性,由服务端返回一个预先定义好的Javascript函数的调用,并且将服务器数据以该函数参数的形式传递过来,此方法需要前后端配合完成。
它只能以GET方式请求
一般将传递的 key 命名为 callback

php服务器示例

header('Content-Type: text/javascript; charset=utf-8'); 
// 假设从数据库里取数据了
$arr = array(
	"name"=>"js",
	"age"=>20
);
// 编码处理
$json = json_encode($arr);
//获取客户端的callback函数
$callback = $_GET['callback'];
//给接收到的函数传输入据$json作为参数, 输出到html页面运行该函数
echo $callback . '(' . $json . ')';

客户端示例

var jsonp = (function(){
   
	var count = 0;
	return function (url, callback) {
   
		//1. 创建一个script标签
		var scriptElem = document.createElement('script');
		//2. 把地址传进去
		var callbackName = "__callback__" + count++;
		var jsonpUrl = url + "?callback=" + callbackName;
		scriptElem.src = jsonpUrl;
		//3. 创建一个fn函数,用于接收返回的数据
		window[callbackName] = function(data){
   
			//把数据传给想要用的人
			callback(data);
			//把我们创建的script标签删掉
			window.document.body.removeChild(scriptElem);
		};
		//4.把标签放到body,把请求发出去
		window.document.body.appendChild(scriptElem);
	}
})();
jsonp('./js.php',function cs(data){
   
	data = JSON.stringify(data);
	console.log(data);
});

控制台输出:{“name”:”js”,”age”:20}
注: 请在php服务器下运行

本文转载自 HeartWalker’s Blog,《jsonp的原理与简单实现》

相关推荐

  1. Web课程学习笔记--jsonp原理简单实现

    2024-02-12 08:28:02       67 阅读
  2. Web课程学习笔记--CSS盒模型

    2024-02-12 08:28:02       55 阅读
  3. 大学编译器课程 编译原理实践

    2024-02-12 08:28:02       28 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-12 08:28:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-12 08:28:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-02-12 08:28:02       82 阅读
  4. Python语言-面向对象

    2024-02-12 08:28:02       91 阅读

热门阅读

  1. Git Push -f 命令详解

    2024-02-12 08:28:02       57 阅读
  2. DataX源码分析 reader

    2024-02-12 08:28:02       49 阅读
  3. 如何让MySQL从部署到稳定运行?

    2024-02-12 08:28:02       51 阅读
  4. 力扣_字符串5—解码方法

    2024-02-12 08:28:02       49 阅读
  5. spring boot 通过 application 切换cache使用的服务

    2024-02-12 08:28:02       56 阅读