Casperjs中fill提交表单遇到的问题
1.if you access internet with proxy please add --ignore-ssl-errors=true --ssl-protocol=any
2.casper.then*
and casper.wait* 都是异步执行的
他们的调用,都是按堆栈中的顺序来执行;也就是说,其他同步执行的函数,譬如,console.log
, casper.echo
andcasper.evaluate
,如果跟在异步函数后面,都是要立即执行的,这就导致不同步了
这种情况下,我们需要把同步执行的函数,放到wait的回调函数里面,
3.
Casperjs中fill的作用是填充表单值,并可以提交(可选),API:http://docs.casperjs.org/en/latest/modules/casper.html#fill,这里不详述它的用法。
今天遇到一个问题,在此记录一下。问题是这样的:我一个可以正常提交form的casperjs脚本,在windows可以正常工作,之前在一台centos的linux服务器上也可以正常工作,今天在一台ubuntu12.04的服务器上却不行,尝试过各种办法(降低casperjs/phantomjs版本等)都不行。调用fill方法后,打出warning消息:[warning] [remote] unable to submit form。为了查找原因,我都去翻看了它git上的源码,想知道是哪块儿出了问题,找到以下代码块儿:
// Form submission?if(submit) { this.evaluate(function_evaluate(selector) { varform = __utils__.findOne(selector); varmethod = (form.getAttribute('method') || "GET").toUpperCase(); varaction = form.getAttribute('action') || "unknown"; __utils__.log('submitting form to '+ action + ', HTTP '+ method, 'info'); varevent = document.createEvent('Event'); event.initEvent('submit', true, true); if(!form.dispatchEvent(event)) { __utils__.log('unable to submit form', 'warning'); return; } if(typeofform.submit === "function") { form.submit(); } else{ // http://www.spiration.co.uk/post/1232/Submit-is-not-a-function form.submit.click(); } }, selector);}
看下来似乎是没有办法dispatchEvent “submit”的event。但是此时我的心情是“朕知道了,但朕也无能为力”……
考虑到这应该是兼容性的问题,不能也不好做什么大改动。但又必须让它正常工作。所以尝试寻找其它等同效果的办法。现在的问题是提交,而casperjs的api中除了这个fill方法没有提交直接的submit方法。这该怎么办法呢?接下来,我从casperjs的click api示例代码中得到启发。调用evaluate进入页面然后调用原生js的submit方法提交表单。怀着试一下心态运行了一下,各环境都能正常工作!
所以,为了兼容性,Casperjs中这样的写法:
this.fill('form#contact-form', {'subject': 'I am watching you','content': 'So be careful.','civility': 'Mr','name': 'Chuck Norris','email': 'chuck@norris.com','cc': true,'attachment': '/Users/chuck/roundhousekick.doc'}, true);
应该写成下面这样比较好:
this.fill('form#contact-form', { 'subject': 'I am watching you', 'content': 'So be careful.', 'civility': 'Mr', 'name': 'Chuck Norris', 'email': 'chuck@norris.com', 'cc': true, 'attachment': '/Users/chuck/roundhousekick.doc'}, false);this.evaluate(function(){ document.querySelector('form#contact-form').submit();});
转载于:https://www.cnblogs.com/SZLLQ2000/p/5336021.html
Casperjs中fill提交表单遇到的问题相关推荐
- java mvc中重复提交表单,spring mvc 防止重复提交表单的两种方法,推荐第二种
第一种方法:判断session中保存的token 比较麻烦,每次在提交表单时都必须传入上次的token.而且当一个页面使用ajax时,多个表单提交就会有问题. 注解Token代码: package c ...
- ajax回调函数提交表单,MVC3中ajax提交表单无法执行success回调函数,怎么办?
js代码 function AjaxInitForm(formId, btnId, isDialog, urlId){ var formObj = $('#' + formId); var btnOb ...
- 4.jQuery中Ajax提交表单数据
目录 1 表单的同步提交 2 Ajax监听表单提交事件 submit 3 阻止表单的默认提交行为 e.preventDefault() 4 获取表单内的数据 4.1 字符串型 serializ ...
- JQuery中button提交表单报TypeError: elem[type] is not a function jquery
错误: TypeError: elem[type] is not a function jquery 解决: 出现这种现象的原因是,提交的表单中,有标签的name,有以submit命名的 name中不 ...
- java jquery提交表单_Jquery ajax提交表单几种方法
在jquery中ajax提交表单有post与get方式,在使用get方式时我们可以直接使用ajax 序列化表单$('#表单ID').serialize();就行了,下面我来介绍两个提交表单数据的方法. ...
- Jquery ajax提交表单几种方法详解
[导读] 在jquery中ajax提交表单有post与get方式,在使用get方式时我们可以直接使用ajax 序列化表单$( 表单ID) serialize();就行了,下面我来介绍两个提交表单数据的 ...
- php防止订单重复计算,php防止用户重复提交表单
我们提交表单的时候,不能忽视的一个限制是防止用户重复提交表单,因为有可能用户连续点击了提交按钮或者是攻击者恶意提交数据,那么我们在提交数据后的处理如修改或添加数据到数据库时就会惹上麻烦. 效果图: 那 ...
- 如何防止用户重复提交表单
我们提交表单的时候,不能忽视的一个限制是防止用户重复提交表单,因为有可能用户连续点击了提交按钮或者是攻击者恶意提交数据,那么我们在提交数据后的处理如修改或添加数据到数据库时就会惹上麻烦. 那么如何规避 ...
- HTML提交弹出提交中,javascript – 从弹出窗口在父窗口中提交表单?
您可以通过window.opener.document在父窗口中获取对表单的引用,如下所示: var form = window.opener.document.getElementById(&quo ...
最新文章
- web-view里面的网页能请求未配置的request域名吗
- 速度提升270倍!微软和浙大联合推出全新语音合成系统FastSpeech
- PHP扩展-扩展的生成和编译
- failed to open log file_C++中glog源码剖析以及如何设计一个高效 log模块
- 减治法在生成子集问题中的应用(JAVA)--递归、二进制反射格雷码
- 第二十八章:化学学校
- Bootstrap Glyphicons图标
- 模板方法设计模式的原理及测试代码(手写JdbcTemplate)
- 制作加密狗程序_【火腿DIY】用于SDR应用程序的自定义热键键盘 | 视障人士的选择...
- 一支python教学_第一只python爬虫
- 不支持给定路径的格式_申论写作标准格式汇总,考前一定要看!
- 【MySQL快速入门】牛客网:条件查询(1)基础排序
- bootstrapmodel确认操作框_光伏电站EL检测仪的操作流程
- ThingJs操作手册
- The Painted Veil
- [藏]疯狂的极端,20款IM,UI比比看
- 因数和以及因数个数和问题
- 开源Webgis开发1——环境配置
- 概率与期望——P1365 WJMZBMR打osu! / Easy
- 最新IP数据库-基于国家省份城市县区和运营商-专业准确-每月发行