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 相关文章推荐
jquery offset函数应用实例
Nov 14 Javascript
可自己添加html的伪弹出框实现代码
Sep 08 Javascript
jquery foreach使用示例
Sep 12 Javascript
jQuery调取jSon数据并展示的方法
Jan 29 Javascript
如何用angularjs制作一个完整的表格
Jan 21 Javascript
详解vue.js的事件处理器v-on:click
Jun 27 Javascript
微信小程序仿知乎实现评论留言功能
Nov 28 Javascript
JavaScript时间日期操作实例小结【5个示例】
Dec 22 Javascript
jQuery利用cookie 实现本地收藏功能(不重复无需多次命名)
Nov 07 jQuery
jQuery实现消息弹出框效果
Dec 10 jQuery
Vue开发中常见的套路和技巧总结
Nov 24 Vue.js
原生JavaScript实现换肤
Feb 19 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
桌面中心(一)创建数据库
2006/10/09 PHP
php获取post中的json数据的实现方法
2011/06/08 PHP
PHP中几种常见的超时处理全面总结
2012/09/11 PHP
php+js iframe实现上传头像界面无跳转
2014/04/29 PHP
JavaScript URL参数读取改进版
2009/01/16 Javascript
关于Aptana Studio生成自动备份文件的解决办法
2009/12/23 Javascript
25个优雅的jQuery Tooltip插件推荐
2011/05/25 Javascript
js过滤HTML标签以及空格的思路及代码
2013/05/24 Javascript
js读取配置文件自写
2014/02/11 Javascript
调用DOM对象的focus使文本框获得焦点
2014/02/19 Javascript
jQuery简单实现禁用右键菜单
2015/03/10 Javascript
jQuery实现首页顶部可伸缩广告特效代码
2015/04/15 Javascript
纯HTML5制作围住神经猫游戏-附源码下载
2015/08/23 Javascript
JavaScript各类型的关系图解
2015/10/16 Javascript
JavaScript中const、var和let区别浅析
2016/10/11 Javascript
详解vue-router2.0动态路由获取参数
2017/06/14 Javascript
jQuery事件_动力节点Java学院整理
2017/07/05 jQuery
详解express与koa中间件模式对比
2017/08/07 Javascript
详解Vue 动态组件与全局事件绑定总结
2018/11/11 Javascript
原生JS实现顶部导航栏显示按钮+搜索框功能
2019/12/25 Javascript
微信小程序之滑动页面隐藏和显示组件功能的实现代码
2020/06/19 Javascript
javascript实现多边形碰撞检测
2020/10/24 Javascript
python获取豆瓣电影简介代码分享
2014/01/16 Python
Python中对象迭代与反迭代的技巧总结
2016/09/17 Python
使用Python &amp; Flask 实现RESTful Web API的实例
2017/09/19 Python
python实现图书管理系统
2018/03/12 Python
python 获取utc时间转化为本地时间的方法
2018/12/31 Python
如何基于python操作excel并获取内容
2019/12/24 Python
win10下opencv-python特定版本手动安装与pip自动安装教程
2020/03/05 Python
html5 application cache遇到的严重问题
2012/12/26 HTML / CSS
人力资源管理专业学生自我评价
2013/11/20 职场文书
幼儿园教师获奖感言
2014/03/11 职场文书
2015年艾滋病防治工作总结
2015/05/22 职场文书
MySQL触发器的使用
2021/05/24 MySQL
教你使用pyinstaller打包Python教程
2021/05/27 Python
Redis中缓存穿透/击穿/雪崩问题和解决方法
2021/12/04 Redis