zl程序教程

您现在的位置是:首页 >  其他

当前栏目

跨域表单提交状态的变相判断代码

状态跨域代码 判断 提交 表单 变相
2023-06-13 09:14:14 时间
拐个弯想,如果开始可以获得iframe内部页面信息,那么不能获得的时候,不就说明表单已经提交了么~
我们发现百度的竞价右下角信息,也是采用的这种方法判断的,大家可以参考下。
示例:

test.html:
复制代码代码如下:

<html>
<head><metahttp-equiv="Content-Type"content="text/html;charset=gb2312"></head>
<bodystyle="background:#a7a7a7;">
<iframeid="testiframe"name="testiframe"></iframe>
<formmethod="post"action="http://www.test.com/testaction.php"target="testiframe"name="testform">
<inputtype="text"name="dddd"><inputtype="submit"value="ddd"name="submitbtn"/>
</form>
</body>
<script>
document.testform.onsubmit=function(){
document.testform.submitbtn.disabled=true;
submitMonitor();

}
functionsubmitMonitor(){
try{
varhash=document.getElementById("testiframe").contentWindow.location.hash;
setTimeout(submitMonitor,100);
}catch(e){
document.getElementById("testiframe").src="about:blank";
document.testform.submitbtn.disabled=false;
}
}
</script>
</html>

注意下面的代码是跨域的,不是在一个域名下的
testaction.php
复制代码代码如下:

<?php
sleep(5);
echo$_POST["dddd"];
?>

弊端:
这个弊端还很明显,如果是404,403,500等错误,也会误认为是成功提交。
所以,请注意:此方法属研究,开拓思维用。
这段是百度的判断代码
复制代码代码如下:
varsfMessTimes;
functionsfMessSubmitMonitor(){
try{
varhash=sf_mess_lib.getElement(SF_MESS_FRAME_ID).contentWindow.location.hash;
        sfMessTimes++;
        if(sfMessTimes>50){
            alert(sf_mess_msg.fail);
            sf_mess_lib.getElement(SF_MESS_SUBMIT_ID).disabled=false;
            for(vari=0,l=sf_mess_cols.length;i<l;i++){
                document.getElementById(SF_MESS_PREFIX+sf_mess_cols[i].idname).disabled=false;
            }
        }else{
            setTimeout(sfMessSubmitMonitor,100);
        }
}catch(e){
sf_mess_lib.getElement(SF_MESS_FRAME_ID).src="about:blank";
        alert(sf_mess_msg.success);
sf_mess_lib.getElement(SF_MESS_SUBMIT_ID).disabled=false;
        for(vari=0,l=sf_mess_cols.length;i<l;i++){
            varinputCfg=sf_mess_cols[i];
            varinputEl=document.getElementById(SF_MESS_PREFIX+inputCfg.idname);
            inputEl.disabled=false;
            inputEl.value=filtInnertip(inputCfg.innertip);
        }
}
}