PHP下ajax跨域的解决方案之window.name实例分析详解

PHP下ajax跨域的解决方案之window.name实例分析详解

本文实例讲述了PHP下ajax跨域的解决方案之window.name。分享给大家供大家参考,具体如下:

原理核心:window对象的name属性是一个很特别的属性,当该window的location变化,然后重新加载,它的name属性可以依然保持不变。

依此原理,我们可以在页面A中用iframe加载其他域的页面B,而页面B中用JavaScript把需要传递的数据赋值给 window.name,页面A的iframe加载完成之后,页面A修改iframe的地址,将其变成同域的一个地址,然后就可以读出window.name的值了。

例:有两个网站www.a.com和www.b.com,我们要在www.a.com/a.html下获取www.b.com/data.html数据。

我们需要三个文件:

www.a.com 下的 a.html 获取数据并显示
www.b.com 下的data.html 提供数据
www.a.com 下的proxy.html 代理文件,与a.html同一域下,一般为空html文件。

www.b.com下的data.html如下:

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title>Insert title here</title>
</head>
<body>
  <script type="text/javascript">
    //添加需要传递的数据,大小一般为2M,IE和firefox下可以大至32M左右
    window.name = '[{"name":"test1"},{"name":"test2"}]';
  </script>
</body>
</html>

www.a.com下的proxy.html如下:

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title>Insert title here</title>
</head>
<body>
  <!-- 空的html文件 -->
</body>
</html>

www.a.com下的a.html如下:

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title>Insert title here</title>
</head>
<body>
 
<!-- 用于引用www.b.com/data.html文件 -->
<iframe id="iframe" src=""></iframe>
 
<!-- 显示获取到的数据 -->
<p id="data"></p>
 
<script type="text/javascript" src="./jquery.js"></script>
<script type="text/javascript">
var ifr = document.getElementById("iframe");
ifr.src = "http://www.b.com/data.html";
if (ifr.attachEvent) {
  ifr.attachEvent("onload", loadfunc);
} else {
  ifr.onload = loadfunc;
}
 
var state = 0;
function loadfunc() {
  if(state == 0) {
    state = 1;
    ifr.contentWindow.location = "http://www.a.com/proxy.html";
  } else {
    var data = ifr.contentWindow.name;
    $.each($.parseJSON(data), function(i, v) {
      $("#data").append(v.name);
    });
     
    //销毁iframe,保证安全
    ifr.contentWindow.document.write("");
    ifr.contentWindow.close();
    document.body.removeChild(ifr);
  }
}
</script>
</body>
</html>

关于PHP下ajax跨域的解决方案之window.name实例分析详解的文章就分享到这,如果对你有帮助欢迎继续关注我们哦

本文来自投稿,不代表科技代码立场,如若转载,请注明出处https://www.cwhello.com/40772.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
上一篇 2022年6月15日 23:51
下一篇 2022年6月15日 23:51

相关推荐

  • PHP内部函数的说明

    说明:在一个函数内部再定义函数,这个时候里面的函数只能在函数内使用,不能在外部使用,防止外部人调用函数,这种函数方式不多,面向对象中都是这种方式。 案例  

    2018年4月7日
    0368
  • 如何利用PHP开发商城的秒杀功能。

    随着电子商务的发展,商城的竞争日益激烈,为了吸引用户,商城普遍采用了秒杀活动的形式。然而,秒杀活动需要具备高并发、高可用等特性,这对开发者的技术要求很高。在本篇文章中,我们将介绍如何利用PHP开发商城...

    2023年5月23日
    01
  • 如何利用PHP实现商城的礼品卡系统。

    随着互联网的不断发展,越来越多的消费者开始通过电子商城进行购物,而在电子商城中,礼品卡成为了一种非常受欢迎的赠送方式。那么,如何利用PHP实现商城的礼品卡系统呢?本文将为大家介绍相关实现方法。一、礼品...

    2023年5月30日
    01
  • 如何用PHP生成微信小程序图。

    如何用PHP生成微信小程序分享图随着微信小程序的普及,越来越多的企业和个人开始将微信小程序作为自己的营销工具。在微信小程序的推广中,分享图是一个非常重要的环节。分享图的好坏,直接影响了用户对小程序的第...

    2023年6月3日
    01
  • 实例详解PHP中 $_POST的$_GET的用法和区别

    post和get是指页面提交的两种方式。(推荐教程:php实战视频教程)get:参数都体现在url上,可以用于翻页,简单查询,get只能接收2M以下的内容,所以有局限性,另外由于内容是可见的,安全性就下降了。post:用于...

    2022年6月17日
    0120
  • PHP中限制IP段访问、禁止IP提交表单的代码(附代码)

    本文为大家讲解的是PHP中限制IP段访问、禁止IP提交表单的代码示例,感兴趣的同学参考下。 下边只是一个PHP限制IP的实例代码,如果您打算应用到CMS中,请自行修改

    2017年9月27日
    0382
  • 重蔚php学习第三十四天——php数组相关算法

    冒泡排序 快速查找 二分查找(折半查找) 1-----100 50 小了 50---100    75 大了 1------50     25 75 小了 75----100    87 大了 50-----75     62   前提:必须是个有序数组 最后一个快速排序... ...就不...

    2017年10月10日 PHP自学教程
    0266
  • 谈谈PHP中interface的用处

    确实,PHP 接口是有它的目的的。它们是契约,是给其他开发人员的说明手册。然而,还是很难理解接口有什么用。基础接口是抽象的类,无法直接实例化,但是可被实现。这是一个基本的例子interface MyInterface { pub...

    2022年6月11日
    0156

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息