本文主要是介绍cookie不同系统间共享,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1.设置cookie的使用范围(域名+路径)
cookie.setDomain(".baidu.com");//表示在baidu下的二级域名之间都可以共享
cookie.setPath("/"); //设置成根目录
如果是测试用的localhost则不用设置domain,只要设置path就可以实现系统间共享
2.不知道有人用过把cookie存入Redis可以实现cookie跨域共享。
3.应该还用一个方法可以实现,使用jsonp来通过ajax实现,而且这种方法还比较流行
jQuery对于Ajax的跨域请求有两类解决方案,不过都是只支持get方式。分别是jquery的 jquery.ajax jsonp格式和jquery.getScript方式。
在开发中,开发人员应该都知道js在操作cookie时是不允许跨域处理的,那么怎么办呢?利用Jquery之AJAX 跨域请求 - 其中有一个方法 JSONP 可以实现跨域请求。
<script type="text/javascript">
jQuery(document).ready(function(){
$.ajax({
type : "get",
async:false,
url : "http://www.piaoyi.org/json.php",
dataType : "jsonp",
jsonp: "callback",//传递给请求处理程序或页面的,用以获得jsonp回调函数名的参数名(默认为:callback)
jsonpCallback:"success_jsonpCallback",//自定义的jsonp回调函数名称,默认为jQuery自动生成的随机函数名
success : function(json){
document.writeln(json.name+"<br>");
document.writeln(json.age+"<br>");
},
error:function(){
alert('fail');
}
});
});
</script>
后台服务器端代码,拿PHP举例:
$arr=array('name'=>'Peter Piaoyi','age'=>25,'city'=>'wuxi');
$result=json_encode($arr);
//动态执行回调函数
$callback=$_GET['callback'];
if($callback!="") echo $callback."($result)";
else echo "$result";

success_jsonpCallback({"name":"Peter Piaoyi","age":25,"city":"wuxi"}) ,从这个返回来看,success_jsonpCallback 正是我们上述代码里定义的jsonpCallback的值。
下面是其他调用代码示例 :
如何使用JSONP?
下边这一DEMO实际上是JSONP的简单表现形式,在客户端声明回调函数之后,客户端通过script标签向服务器跨域请求数据,然后服务端返回相应的数据并动态执行回调函数。
HTML代码 (任一 ):
<script type="text/javascript">
function jsonpCallback(result) {
//alert(result);
for(var i in result) {
alert(i+":"+result[i]);//循环输出a:1,b:2,etc.
}
}
var JSONP=document.createElement("script");
JSONP.type="text/javascript";
JSONP.src="http://crossdomain.com/services.php?callback=jsonpCallback";
document.getElementsByTagName("head")[0].appendChild(JSONP);
</script>
或者
Html代码
<script type="text/javascript">
function jsonpCallback(result) {
alert(result.a);
alert(result.b);
alert(result.c);
for(var i in result) {
alert(i+":"+result[i]);//循环输出a:1,b:2,etc.
}
}
</script>
<script type="text/javascript" src="http://crossdomain.com/services.php?callback=jsonpCallback"></script>
JavaScript的链接,必须在function的下面。
$.getJSON
$.ajax
$.get
客户端JS代码在jQuery中的实现方式1:
<script type="text/javascript">
$.getJSON("http://crossdomain.com/services.php?callback=?",
function(result) {
for(var i in result) {
alert(i+":"+result[i]);//循环输出a:1,b:2,etc.
}
});
</script>
<script type="text/javascript">
$.ajax({
url:"http://crossdomain.com/services.php",
dataType:'jsonp',
data:'',
jsonp:'callback',
success:function(result) {
for(var i in result) {
alert(i+":"+result[i]);//循环输出a:1,b:2,etc.
}
},
timeout:3000
});
</script>
客户端JS代码在jQuery中的实现方式3:
<script type="text/javascript">
$.get('http://crossdomain.com/services.php?callback=?', {name: encodeURIComponent('tester')}, function (json) { for(var i in json) alert(i+":"+json[i]); }, 'jsonp');
</script>
其中 jsonCallback 是客户端注册的,获取 跨域服务器 上的json数据 后,回调的函数。
http://crossdomain.com/services.php?callback=jsonpCallback
这个 url 是跨域服务 器取 json 数据的接口,参数为回调函数的名字,返回的格式为
Jsonp原理:
首先在客户端注册一个callback, 然后把callback的名字传给服务器。
然后以 javascript 语法的方式,生成一个function , function 名字就是传递上来的参数 jsonp.
比XML轻了很多,没有那么多冗余的东西。
JSON也是具有很好的可读性的,但是通常返回的都是压缩过后的。不像XML这样的浏览器可以直接显示,浏览器对于JSON的格式化的显示就需要借助一些插件了。
在JavaScript中处理JSON很简单。
其他语言例如PHP对于JSON的支持也不错。
JSON也有一些劣势:
JSON在服务端语言的支持不像XML那么广泛,不过JSON.org上提供很多语言的库。
如果你使用eval()来解析的话,会容易出现安全问题。
尽管如此,JSON的优点还是很明显的。他是Ajax数据交互的很理想的数据格式。
主要提示 :
JSONP 是构建 mashup 的强大技术,但不幸的是,它并不是所有跨域通信需求的万灵药。它有一些缺陷,在提交开发资源之前必须认真考虑它们。
第一,也是最重要的一点,没有关于 JSONP 调用的错误处理。如果动态脚本插入有效,就执行调用;如果无效,就静默失败。失败是没有任何提示的。例如,不能从服务器捕捉到 404 错误,也不能取消或重新开始请求。不过,等待一段时间还没有响应的话,就不用理它了。(未来的 jQuery 版本可能有终止 JSONP 请求的特性)。
JSONP 的另一个主要缺陷是被不信任的服务使用时会很危险。因为 JSONP 服务返回打包在函数调用中的 JSON 响应,而函数调用是由浏览器执行的,这使宿主 Web 应用程序更容易受到各类攻击。如果打算使用 JSONP 服务,了解它能造成的威胁非常重要。
ajax请求参数说明 :
function success_jsonpCallback(data)
{
success(data);
}
经测试,ajax jsonp对同步或异步请求没有影响。
这篇关于cookie不同系统间共享的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!