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显示选择目录对话框的代码
Nov 10 Javascript
firefox firebug中文入门教程 脚本之家新年特别版
Jan 02 Javascript
JS 显示当前日期与时间的代码
Mar 24 Javascript
JQuery UI DatePicker中z-index默认为1的解决办法
Sep 28 Javascript
客户端 使用XML DOM加载json数据的方法
Sep 28 Javascript
Enter转换为Tab的小例子(兼容IE,Firefox)
Nov 14 Javascript
js拆分字符串并将分割的数据放到数组中的方法
May 06 Javascript
AngularJS实现路由实例
Feb 12 Javascript
纯JS实现弹性导航条效果
Mar 06 Javascript
基于 Vue.js 2.0 酷炫自适应背景视频登录页面实现方式
Jan 17 Javascript
element-ui 上传图片后清空图片显示的实例
Sep 04 Javascript
JavaScript或jQuery 获取option value值方法解析
May 12 jQuery
关于火狐(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
PHP静态类
2006/11/25 PHP
php实现通用的信用卡验证类
2015/03/24 PHP
PHP数组函数知识汇总
2016/05/12 PHP
JQuery扩展插件Validate 2通过参数设置验证规则
2011/09/05 Javascript
css3元素简单的闪烁效果实现(html5 jquery)
2013/12/28 Javascript
jquery解析xml字符串示例分享
2014/03/25 Javascript
JS实现先显示大图后自动收起显示小图的广告代码
2015/09/04 Javascript
html+js实现简单的计算器代码(加减乘除)
2016/07/12 Javascript
ajax 提交数据到后台jsp页面及页面跳转问题
2017/01/19 Javascript
jQuery+pjax简单示例汇总
2017/04/21 jQuery
微信小程序 request接口的封装实例代码
2017/04/26 Javascript
js中比较两个对象是否相同的方法示例
2019/09/02 Javascript
jQuery实现轮播图效果demo
2020/01/11 jQuery
python制作小说爬虫实录
2017/08/14 Python
获取Django项目的全部url方法详解
2017/10/26 Python
详谈Pandas中iloc和loc以及ix的区别
2018/06/08 Python
Windows 8.1 64bit下搭建 Scrapy 0.22 环境
2018/11/18 Python
python制作简单五子棋游戏
2019/06/18 Python
python 自定义装饰器实例详解
2019/07/20 Python
Django rstful登陆认证并检查session是否过期代码实例
2019/08/13 Python
python编写猜数字小游戏
2019/10/06 Python
python中的线程threading.Thread()使用详解
2019/12/17 Python
Python collections.defaultdict模块用法详解
2020/06/18 Python
基于html5实现的图片墙效果
2014/10/16 HTML / CSS
澳大利亚领先的皮肤诊所:Skin Matrix(抗衰老、痤疮专家、药妆护肤)
2018/05/20 全球购物
介绍一下如何利用路径遍历进行攻击及如何防范
2014/01/19 面试题
国际商务专业学生个人的自我评价
2013/09/28 职场文书
给同事的道歉信
2014/01/11 职场文书
《有趣的发现》教学反思
2014/04/15 职场文书
加入学生会演讲稿
2014/04/24 职场文书
护士医德考评自我评价
2015/03/03 职场文书
2016优秀护士先进个人事迹材料
2016/02/25 职场文书
Python Pandas pandas.read_sql_query函数实例用法分析
2021/06/21 Python
Python+腾讯云服务器实现每日自动健康打卡
2021/12/06 Python
《帝国时代4》赛季预告 新增内容编译器可创造地图
2022/04/03 其他游戏
基于CSS制作创意端午节专属加载特效
2022/06/01 HTML / CSS