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


Posted in Javascript onNovember 12, 2009

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

test.html:

<html> 
<head><meta http-equiv="Content-Type" content="text/html; charset=gb2312"></head> 
<body style="background:#a7a7a7;"> 
<iframe id="testiframe" name="testiframe"></iframe> 
<form method="post" action="http://www.test.com/testaction.php" target="testiframe" name="testform"> 
<input type="text" name="dddd"><input type="submit" value="ddd" name="submitbtn"/> 
</form> 
</body> 
<script> 
document.testform.onsubmit = function () { 
document.testform.submitbtn.disabled = true; 
submitMonitor(); } 
function submitMonitor () { 
try{ 
var hash = 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等错误,也会误认为是成功提交。
所以,请注意:此方法属研究,开拓思维用。
这段是百度的判断代码
var sfMessTimes; 
function sfMessSubmitMonitor () { 
try{ 
var hash = 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 (var i = 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 (var i = 0, l = sf_mess_cols.length; i < l; i++) { 
            var inputCfg = sf_mess_cols[i]; 
            var inputEl = document.getElementById(SF_MESS_PREFIX + inputCfg.idname); 
            inputEl.disabled = false; 
            inputEl.value = filtInnertip(inputCfg.innertip); 
        } 
} 
}
Javascript 相关文章推荐
jquery imgareaselect 使用利用js与程序结合实现图片剪切
Jul 30 Javascript
jquery ajax 检测用户注册时用户名是否存在
Nov 03 Javascript
DOM和XMLHttpRequest对象的属性和方法整理
Jan 04 Javascript
Extjs3.0 checkboxGroup 动态添加item实现思路
Aug 14 Javascript
js使用removeChild方法动态删除div元素
Aug 01 Javascript
javascript用函数实现对象的方法
May 14 Javascript
jQuery绑定事件监听bind和移除事件监听unbind用法实例详解
Jan 19 Javascript
原生Javascript和jQuery做轮播图简单例子
Oct 11 Javascript
微信开发 js实现tabs选项卡效果
Oct 28 Javascript
javaScript实现滚动条事件详解
Mar 24 Javascript
VUE Elemen-ui之穿梭框使用方法详解
Jan 19 Javascript
JavaScript异步操作中串行和并行
Nov 20 Javascript
JS 中document.URL 和 windows.location.href 的区别
Nov 11 #Javascript
ASP中进行HTML数据及JS数据编码函数
Nov 11 #Javascript
javascript 日期常用的方法
Nov 11 #Javascript
Jquery在IE7下无法使用 $.ajax解决方法
Nov 11 #Javascript
jQuery 白痴级入门教程
Nov 11 #Javascript
Javascript 解疑
Nov 11 #Javascript
不一样的文字闪烁 轮番闪烁
Nov 11 #Javascript
You might like
解析thinkphp import 文件内容变量失效的问题
2013/06/20 PHP
php中require和require_once的区别说明
2014/02/27 PHP
PHP中遇到BOM、编码导致json_decode函数无法解析问题
2014/07/02 PHP
php绘图之生成饼状图的方法
2015/01/24 PHP
php脚本守护进程原理与实现方法详解
2017/07/20 PHP
PHP有序表查找之二分查找(折半查找)算法示例
2018/02/09 PHP
js带点自动图片轮播幻灯片特效代码分享
2015/09/07 Javascript
iframe中使用jquery进行查找的方法【案例分析】
2016/06/17 Javascript
Vue.js原理分析之observer模块详解
2017/02/17 Javascript
w3c编程挑战_初级脚本算法实战篇
2017/06/23 Javascript
详解RequireJs官方使用教程
2017/10/31 Javascript
解决vue-cli项目开发运行时内存暴涨卡死电脑问题
2019/10/29 Javascript
python解析xml模块封装代码
2014/02/07 Python
用Python给文本创立向量空间模型的教程
2015/04/23 Python
Python编程中对super函数的正确理解和用法解析
2016/07/02 Python
在Python中使用AOP实现Redis缓存示例
2017/07/11 Python
python3学习笔记之多进程分布式小例子
2018/02/13 Python
用Python实现筛选文件脚本的方法
2018/10/27 Python
python将字符串转变成dict格式的实现
2019/11/18 Python
opencv3/C++实现视频读取、视频写入
2019/12/11 Python
python thrift 实现 单端口多服务的过程
2020/06/08 Python
css3实现背景动态渐变效果
2019/12/10 HTML / CSS
SISLEY希思黎官方旗舰店:享誉全球的奢华植物美容品牌
2018/04/25 全球购物
流行文化收藏品:Sideshow(DC漫画,星球大战,漫威)
2019/03/17 全球购物
Sandro法国官网:法国成衣品牌
2019/08/28 全球购物
PHP如何调用MYSQL存储过程
2014/05/30 面试题
餐厅经理岗位职责范本
2014/02/17 职场文书
信息科学与技术专业求职信范文
2014/02/20 职场文书
跟单业务员岗位职责
2014/03/08 职场文书
听课评语大全
2014/04/30 职场文书
中国文明网向国旗敬礼寄语大全
2014/09/27 职场文书
诉讼授权委托书范本
2014/10/05 职场文书
学校政风行风自查自纠报告
2014/10/21 职场文书
庆七一活动简报
2015/07/20 职场文书
公司安全管理制度范本
2015/08/05 职场文书
el-table-column 内容不自动换行的解决方法
2022/08/14 Vue.js