js/ajax跨越访问-jsonp的原理和实例(javascript和jquery实现代码)


Posted in Javascript onDecember 27, 2012

很庆幸,我又见到了末日后新升的太阳,所以我还能在这里写文章,言归正传哈,最近做了一个项目,需要用子域名调用主域名下的一个现有的功能,于是想到了用jsonp来解决,在我们平常的项目中不乏有这种需求的朋友,于是记录下来以便以后查阅同时也希望能帮到大家。

什么是JSONP协议?
JSONP即JSON with Padding。由于同源策略的限制,XmlHttpRequest只允许请求当前源(域名、协议、端口)的资源。如果要进行跨域请求,我们可以通过使用html的script标记来进行跨域请求,并在响应中返回要执行的script代码,其中可以直接使用JSON传递javascript对象。这种跨域的通讯方式称为JSONP。
很明显,JSONP是一种脚本注入(Script Injection)行为,需要特别注意其安全性。

Jquery中的jsonp实例
我们需要两个页面,分别承担协议的客户端和服务器端角色。

客户端代码

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml" > 
<head> 
<title>jsonp测试例子</title> 
<script type="text/javascript" src="http://www.xxxxxxxxxxxx.cn/js/jquery.min.js"></script> 
<script type="text/javascript"> 
jQuery(document).ready(function(){ 
$.ajax({ 
type: "get", 
async: false, 
url: "http://www.xxxxxxxxxxxx.cn/demos/jsonp.php", 
dataType: "jsonp", 
jsonp: "callback",//传递给请求处理程序或页面的,用以获得jsonp回调函数名的参数名(一般默认为:callback) 
jsonpCallback:"feedBackState",//自定义的jsonp回调函数名称,默认为jQuery自动生成的随机函数名 
success: function(data){ 
var $ul = $("<ul></ul>"); 
$.each(data,function(i,v){ 
$("<li/>").text(v["id"] + " " + v["name"]).appendTo($ul) 
}); 
$("#remote").append($ul); 
}, 
error: function(){ 
alert('fail'); 
} 
}); 
}); 
</script> 
</head> 
<body> 
远程数据如下:<br/> 
<div id="remote"></div> 
</body> 
</html>

服务端代码(本例采用PHP)
<?php 
$jsonp = $_REQUEST["callback"]; 
$str = '[{"id":"1","name":"测试1"},{"id":"2","name":"测试2"}]'; 
$str = $jsonp . "(" .$str.")"; 
echo $str; 
?>

js/ajax跨越访问-jsonp的原理和实例(javascript和jquery实现代码) 
Jsonp的原理和简单实例
jquery是对其进行了封装,你可能看不到真正的实现方法,我们用下面的一个例子进行说明:
客户端代码:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml" > 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<head> 
<title>jsonp测试例子</title> 
<script type="text/javascript" src="http://www.xxxxxxxxxxxx.cn/js/jquery.min.js"></script> 
<script type="text/javascript"> 
function CallJSONPServer(url){ // 调用JSONP服务器,url为请求服务器地址 
var oldScript =document.getElementById(url); // 如果页面中注册了调用的服务器,则重新调用 
if(oldScript){ 
oldScript.setAttribute("src",url); 
return; 
} 
var script =document.createElement("script"); // 如果未注册该服务器,则注册并请求之 
script.setAttribute("type", "text/javascript"); 
script.setAttribute("src",url); 
script.setAttribute("id", url); 
document.body.appendChild(script); 
} 
function OnJSONPServerResponse(data){ 
var $ul = $("<ul></ul>"); 
$.each(data,function(i,v){ 
$("<li/>").text(v["id"] + " " + v["name"]).appendTo($ul) 
}); 
$("#remote").append($ul); 
} 
</script> 
</head> 
<body> 
<input type="button" value="点击获取远程数据" onclick="CallJSONPServer('http://www.xxxxxxxxxxxx.cn/demos/jsonp_original.php')" /> 
<div id="remote"></div> 
</body> 
</html>

服务端代码
<?php 
$str = '[{"id":"1","name":"测试1"},{"id":"2","name":"测试2"}]'; 
$str = "OnJSONPServerResponse(" .$str.")"; 
echo $str; 
?>

js/ajax跨越访问-jsonp的原理和实例(javascript和jquery实现代码) 
别的不多说,相信看代码大家应该明白它是怎么实现的了。
需要注意
1.由于 jquery 在ajax 处理中使用的是utf-8编码传递参数的,所以jsonp处理端用utf-8的编码最好,这样省得编码转换了,如果不是utf-8记得转换,否则中文会乱码。
2.请求的服务端url最好不要写成http://www.xxxxxxxxxxxx.cn/?act=add这样的,应写全其为:http://www.xxxxxxxxxxxx.cn/index.php?act=add这样的,在应用的过程中出现了不兼容的情况。
到此就ok了,如有朋友碰到什么问题可发上来大家共同交流。
欢迎大家转载,转载请注明原创 包括链接一定要加上,否则...此处略去n个字
签名:共同交流,共同学习,帮助需要帮助的人,共同走向成功之路。
Javascript 相关文章推荐
javascript之对系统的toFixed()方法的修正
May 08 Javascript
修复IE9&amp;safari 的sort方法
Oct 21 Javascript
window.open()详解及浏览器兼容性问题示例探讨
May 29 Javascript
node.js不得不说的12点内容
Jul 14 Javascript
jQuery在线选座位插件seat-charts特效代码分享
Aug 27 Javascript
jQuery拖拽排序插件制作拖拽排序效果(附源码下载)
Feb 23 Javascript
jquery使用Cookie和JSON记录用户最近浏览历史
Apr 19 Javascript
浅谈js内置对象Math的属性和方法(推荐)
Sep 19 Javascript
微信小程序 火车票查询实例讲解
Oct 17 Javascript
hammer.js实现图片手势放大效果
Aug 29 Javascript
使用Node.js实现ORM的一种思路详解(图文)
Oct 24 Javascript
原生js实现日期选择插件
May 21 Javascript
关于火狐(firefox)及ie下event获取的两种方法
Dec 27 #Javascript
Javascript图像处理—为矩阵添加常用方法
Dec 27 #Javascript
ie支持function.bind()方法实现代码
Dec 27 #Javascript
前后台交互过程中json格式如何解析以及如何生成
Dec 26 #Javascript
多个js与css文件的合并方法详细说明
Dec 26 #Javascript
JS打开图片另存为对话框实现代码
Dec 26 #Javascript
window.addEventListener来解决让一个js事件执行多个函数
Dec 26 #Javascript
You might like
初探PHP5
2006/10/09 PHP
用cookies来跟踪识别用户
2006/10/09 PHP
聊天室php&amp;mysql(一)
2006/10/09 PHP
怎样使用php与jquery设置和读取cookies
2013/08/08 PHP
windows7下安装php的php-ssh2扩展教程
2014/07/04 PHP
简单概括PHP的字符串中单引号与双引号的区别
2016/05/07 PHP
PHP Ajax跨域问题解决方案代码实例
2020/08/01 PHP
javaScript基础语法介绍
2015/02/28 Javascript
css如何让浮动元素水平居中
2015/08/07 Javascript
分享15个大家都熟知的jquery小技巧
2015/12/02 Javascript
浅谈angularjs中响应回车事件
2017/04/24 Javascript
jquery.validate表单验证插件使用详解
2017/06/21 jQuery
angular.js实现购物车功能
2017/10/23 Javascript
jquery使用FormData实现异步上传文件
2018/10/25 jQuery
JavaScript设计模式之装饰者模式实例详解
2019/01/17 Javascript
[01:00] DOTA2英雄背景故事第五期之重力引力法则谜团
2020/07/16 DOTA
python实现合并两个数组的方法
2015/05/16 Python
PyQt5打开文件对话框QFileDialog实例代码
2018/02/07 Python
python-docx修改已存在的Word文档的表格的字体格式方法
2018/05/08 Python
Python将8位的图片转为24位的图片实现方法
2018/10/24 Python
Python之列表实现栈的工作功能
2019/01/28 Python
pandas将多个dataframe以多个sheet的形式保存到一个excel文件中
2019/10/10 Python
pytorch 数据处理:定义自己的数据集合实例
2019/12/31 Python
python 实现的车牌识别项目
2021/01/25 Python
HTML5地理定位_动力节点Java学院整理
2017/07/12 HTML / CSS
药店主任岗位责任制
2014/02/10 职场文书
安全生产专项整治方案
2014/05/06 职场文书
大学生村官考核材料
2014/05/23 职场文书
关于诚信的活动方案
2014/08/18 职场文书
2015元旦节寄语
2014/12/08 职场文书
2014年污水处理厂工作总结
2014/12/19 职场文书
2015年世界无烟日活动总结
2015/02/10 职场文书
详解PHP用mb_string处理windows中文字符
2021/05/26 PHP
Python内置数据结构列表与元组示例详解
2021/08/04 Python
Python测试框架pytest高阶用法全面详解
2022/06/01 Python
python+pyhyper实现识别图片中的车牌号思路详解
2022/12/24 Python