分享

DedeCMS digg Ajax 跨域的实现分析

 一只小佳 2020-05-06

织梦DedeCMS digg Ajax 跨域的实现分析提供解决方案如下:

@writen by etongchina 2009-02-06 19:00

实现方案:类似json实现

实现原理:js允许引入的远程文件(js)来操作本地数据

具体方法:(以https://www./wlkj/166.html 为例)

1.修改https://www./wlkj/166.html 的js调用用部分;

在本地html或js文件中写入:

<SCRIPT LANGUAGE="JavaScript">

function _Digg(type,tid){

var s = document.("SCRIPT");

s.id="cgi_emotion_list";

document.getElementsByTagName("HEAD")[0].(s);

s.src="http://www./../dig.php?type="+type+"&tid="+tid ;

//需要统计的php页面的 src

}

function visitCountCallBack(data){

document.getElementsByTagName("HEAD")[0].removeChild(document.getElementById("cgi_emotion_list"));

for(var i in data){

var e =document.getElementById(i);

if(e) e.innerHTML=data[i];

//一些代码去修改本地html

}

}

</script>

修改以下代码:<a href="javascript:Digg('digg',4653);">顶一下</a>

为:<a href="javascript:_Digg('digg',4653);">顶一下</a>

2. 访问远程文件:    

远程文件(http://www./../dig.php?type=digg&tid=456 )返回类似代码:

visitCountCallBack({

"visitcount":135

});

以上代码相当于远程文件调用本地函数:visitCountCallBack

这样一来就可以实现利用远程返回数据来动态修改本地文件。

3.总结:

关于此方案,目前可行,也有人认为会过时。我认为不会产生JS越权的问题。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约