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 学习 - 提高篇
Feb 02 Javascript
E3 tree 1.6在Firefox下显示问题的修复方法
Jan 30 Javascript
js替代copy(示例代码)
Nov 27 Javascript
引用外部脚本时script标签关闭的写法
Jan 20 Javascript
js实现鼠标感应向下滑动隐藏菜单的方法
Feb 20 Javascript
IE8兼容Jquery.validate.js的问题
Dec 01 Javascript
jQuery 1.9版本以上的浏览器判断方法代码分享
Aug 28 jQuery
详解angular2 控制视图的封装模式
Dec 27 Javascript
RxJS的入门指引和初步应用
Jun 15 Javascript
小程序实现搜索框功能
Mar 26 Javascript
如何在vue 中引入使用jquery
Nov 10 jQuery
vue 实现click同时传入事件对象和自定义参数
Jan 29 Vue.js
关于火狐(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防注入安全代码
2008/04/09 PHP
解析PHP计算页面执行时间的实现代码
2013/06/18 PHP
详解WordPress开发中wp_title()函数的用法
2016/01/07 PHP
php中preg_replace正则替换用法分析【一次替换多个值】
2017/01/17 PHP
js form action动态修改方法
2008/11/04 Javascript
IE下js调试工具Companion.JS
2010/10/15 Javascript
javascript针对DOM的应用实例(一)
2012/04/15 Javascript
怎样在JavaScript里写一个swing把数据插入数据库
2012/12/10 Javascript
jQuery选择器全面总结
2014/01/06 Javascript
Javascript基础知识(一)核心基础语法与事件模型
2014/09/29 Javascript
jQuery中is()方法用法实例
2015/01/06 Javascript
js检测iframe是否加载完成的方法
2015/11/26 Javascript
利用Vue.js指令实现全选功能
2016/09/08 Javascript
JS基于正则截取替换特定字符之间字符串操作示例
2017/02/03 Javascript
简单实现js菜单栏切换效果
2017/03/04 Javascript
jsTree事件和交互以及插件plugins详解
2017/08/29 Javascript
Node.js 使用流实现读写同步边读边写功能
2017/09/11 Javascript
jQuery实现表单动态添加与删除数据操作示例
2018/07/03 jQuery
微信小程序实现简单跑马灯效果
2020/05/26 Javascript
详细讲解如何创建, 发布自己的 Vue UI 组件库
2019/05/29 Javascript
vue安装遇到的5个报错及解决方法
2019/06/12 Javascript
Python实现图片转字符画的示例
2017/08/22 Python
Python探索之自定义实现线程池
2017/10/27 Python
Python实现PS滤镜中马赛克效果示例
2018/01/20 Python
Pandas中把dataframe转成array的方法
2018/04/13 Python
Django REST framework视图的用法
2019/01/16 Python
Python 实现文件读写、坐标寻址、查找替换功能
2019/09/11 Python
使用Python实现将多表分批次从数据库导出到Excel
2020/05/15 Python
获取CSDN文章内容并转换为markdown文本的python
2020/09/06 Python
Python爬虫之Selenium实现关闭浏览器
2020/12/04 Python
Guess美国官网:美国知名服装品牌
2019/04/08 全球购物
AMAVII眼镜官网:时尚和设计师太阳镜
2019/05/05 全球购物
深圳-东方伟业笔试部分
2015/02/11 面试题
幼儿园五一活动方案
2014/02/07 职场文书
JS Canvas接口和动画效果大全
2021/04/29 Javascript
MySQL数据库简介与基本操作
2022/05/30 MySQL