如何编写一个自动投票程序?这篇文章告诉你 环球热门
我经常去网站抓些东西,有时也做一些自动填写表单的事情。最近接手了一个投票的任务,也即需要编写一个程序自动投票,从而也引发了如何编写自动投票程序和如何编写投票程序(投票程序怎么样防止自动投票)的话题。正所谓道高一尺、魔高一丈。自动投票和投票程序本身就是一种对弈状态。
如何编写投票程序,大致分为这么几步:
1:手动投票,分析中间出现的每一个页面的代码,找出投票规律。
(资料图片)
2:捕获提交页面的时候所post的信息。
3:编程模拟这个手动过程。
我以我刚写的这个自动投票程序为例。在此我不会给出网址链接(保密),也不会给出真实数据和截图。
首先手动投票,是一个多选投票,点击投票按钮后,会弹出一个网页,这个网页会问你是确认还是放弃,点击确认后,返回投票成功的提示。当在此点击投票按钮的时候提示已经投过一票,不能重复投票。关闭所有浏览器窗口,打开一个新窗口,投票,仍然可以投票成功。根据如下行为,可以得出如下结论:
1:投票需要有两次和服务器的交互,第一次向服务器提交投票结果,第二次交互向服务器提交是否确认此结果。
2:此两页面之间的session是有联系的,也即同一个session下不能投两次票。当关闭浏览器,重新开启刘拉尼后,因为相当于新开了一个session,所以仍然会投票成功。
知道了这个后,就开始抓去两次交互的HTTP头信息(Header信息)
第一次交互的信息如下(点击投票按钮):--------------------------------------------------------------------------
Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/vnd.ms-excel, application/vnd.ms-powerpoint, application/msword, application/x-shockwave-flash, */*
Referer: http://xxxxx/xxxxxxxxxxxxxxxxxxxxxxxx
Accept-Language: zh-cn
Content-Type: application/x-www-form-urlencoded
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; MyIE2; .NET CLR 1.1.4322)
Host: xxx.xxx.xxx.xxx
Content-Length: 167
Connection: Keep-Alive
Cache-Control: no-cache
checkvalue=32&bbb=%CD%B6%C6%B1&ilc=0&kkk=22
---------------------------------------------------------------------------------
从网页源代码中可以分析出来,数据是post上去的,post的数据为"checkvalue=32&bbb=%CD%B6%C6%B1&ilc=0&kkk=22",其中checkvalue=32即为投票选中的复选框的值,bbb为投票按钮的名称,"%CD%B6%C6%B1"为"投票"两个汉字的转码。ilc=0和kkk=22是两个隐藏域中信息,作用还不明确。从网页源代码中可以分析出来,数据是post上去的,post的数据为"checkvalue=32&bbb=%CD%B6%C6%B1&ilc=0&kkk=22",其中checkvalue=32即为投票选中的复选框的值,bbb为投票按钮的名称,"%CD%B6%C6%B1"为"投票"两个汉字的转码。ilc=0和kkk=22是两个隐藏域中信息,作用还不明确。
然后接收到的Header如下:-------------------------------------------------------------
Date: Wed, 05 Jan 2005 12:45:10 GMT
Server: Apache/1.3.27 (Win32)
X-Powered-By: PHP/4.1.2
Set-Cookie: ilc=22
Keep-Alive: timeout=15, max=100
Connection: Keep-Alive
Transfer-Encoding: chunked
Content-Type: text/html
--------------------------------------------------------------------
可以看到里面有一个关键的地方Set-Cookie : ilc = 22,也即设置了一个cookie,这个cookie值为22,也即post上去的kkk的值,猜测这是此次投票的编码。可以看到里面有一个关键的地方Set-Cookie : ilc = 22,也即设置了一个cookie,这个cookie值为22,也即post上去的kkk的值,猜测这是此次投票的编码。
从返回的源代码中可以分析出来checkvalue=32这个值并没有写在第二个页面的隐藏域中,那么它就只能记录在session中。从第二次交互的信息中也可以证明。
第二次交互的信息:
发送:------------------------------------------------------------
Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/vnd.ms-excel, application/vnd.ms-powerpoint, application/msword, application/x-shockwave-flash, */*
Referer: http://xxxxx/xxxxxxxxxxxxxxxxxxxxxxxx
Accept-Language: zh-cn
Content-Type: application/x-www-form-urlencoded
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; MyIE2; .NET CLR 1.1.4322)
Host: xxx.xxx.xxx.xxx
Content-Length: 22
Connection: Keep-Alive
Cache-Control: no-cache
Cookie: ilc=22
inbtn=%C8%B7%C8%CF
-----------------------------------------------------------------
可以看到第二次post上去的信息仅仅是一个按钮的信息。inbtn为"确认"按钮的名字。而"%C8%B7%C8%CF"就是"确认"两个字的转码。checkvalue=32这个投票信息并不包含在第二次交互中,这只能说明第一次交互中就把这个信息写入到session中保存了。可以看到第二次post上去的信息仅仅是一个按钮的信息。inbtn为"确认"按钮的名字。而"%C8%B7%C8%CF"就是"确认"两个字的转码。checkvalue=32这个投票信息并不包含在第二次交互中,这只能说明第一次交互中就把这个信息写入到session中保存了。
不能重复投票可能是session中有记录,也可能是cookie中有记录。cookie的可能性大一些。
那么怎么模拟这个过程呢,我用了WebClient类,这个类非常好。其中的Headers属性可以设置头信息。而UploadData函数则可以post数据上去。并且同一个WebClient的两次连接是在同一个Session中的。这样完成两次交互也就是一次投票之后,就可以重新new一个WebClient,这样就相当于重新开了一个Session。
代码如下:
staticvoidpost()
{
stringuriString="http://xxxxx/xxxxxxxxxxxxxxxxxxxxxxxx";
WebClient myWebClient=newWebClient();
stringpostData=null;
byte[] byteArray;
byte[] responseArray;
WebHeaderCollection myWebHeaderCollection;
postData="checkvalue=32&bbb=%CD%B6%C6%B1&ilc=0&kkk=22";
myWebClient.Headers.Add("Content-Type","application/x-www-form-urlencoded");
myWebClient.Headers.Add("Referer","http://xxxxx/xxxxxxxxxxxxxxxxxxxxxxxx");
myWebClient.Headers.Add("Accept-Language","zh-cn");
myWebHeaderCollection=myWebClient.Headers;
//第一次交互Console.WriteLine("发送的HTTP头信息");
for(inti=0; i
{
Console.WriteLine (myWebHeaderCollection.GetKey(i)+":"+myWebHeaderCollection.Get(i));
}
byteArray=Encoding.Default.GetBytes(postData);
responseArray=myWebClient.UploadData(uriString,"POST",byteArray);
Console.WriteLine("接收的HTTP头信息");
myWebHeaderCollection=myWebClient.ResponseHeaders;
for(inti=0; i
{
Console.WriteLine (myWebHeaderCollection.GetKey(i)+":"+myWebHeaderCollection.Get(i));
}Console.WriteLine("接收的正文信息");
Console.WriteLine(Encoding.Default.GetString(responseArray));
//Console.ReadLine();
//第二次交互(用同一个WebClient实例)postData="inputinfo=%C8%B7%C8%CF";
myWebClient.Headers.Add("Content-Type","application/x-www-form-urlencoded");
myWebClient.Headers.Add("Referer","http://xxxxx/xxxxxxxxxxxxxxxxxxxxxxxx");
myWebClient.Headers.Add("Accept-Language","zh-cn");
myWebClient.Headers.Add("Cookie","ilc=126");
myWebHeaderCollection=myWebClient.Headers;
Console.WriteLine("发送的HTTP头信息");
for(inti=0; i
{
Console.WriteLine (myWebHeaderCollection.GetKey(i)+":"+myWebHeaderCollection.Get(i));
}
byteArray=Encoding.Default.GetBytes(postData);
responseArray=myWebClient.UploadData(uriString,"POST",byteArray);
Console.WriteLine("接收的HTTP头信息");
myWebHeaderCollection=myWebClient.ResponseHeaders;
for(inti=0; i
{
Console.WriteLine (myWebHeaderCollection.GetKey(i)+":"+myWebHeaderCollection.Get(i));
}
Console.WriteLine("接收的正文信息");
Console.WriteLine(Encoding.Default.GetString(responseArray));
//Console.ReadLine();}
运行后输出的信息和手动投票时截获的信息基本一致。
然后就可以运行一个无限循环
inti=0;
while(true)
{
try
{
post();
i++;
Console.WriteLine("这是您投的第"+i+"张票");
}catch(Exception e)
{
Console.WriteLine("有错误发生:"+e.Message);
}Console.WriteLine("---------------------------------");
}
我做的命令行程序,要捕捉错误避免程序停止。停止程序的时候直接X掉窗口即可。另外用命令行程序的一个好处是不用做多线程,直接多运行几个exe的实例就可以达到多线程的目的(实际是多进程了)。
那么我们在做投票(包括其它表单)如何防备别人自动投票或者自动填写表但呢?session限制的方法显然不是一个有效的方法。而ip限制不实际,因为很多用户都没有ip地址,都是网络运营商作的NAT映射,封掉一个ip地址相当于封掉一批机器。所以一般也不采用。那么如何最有效呢。可以采用两种方法:
1:验证码,验证码直接导致了无法用程序来填写表单,因为验证码都为图片,文字的验证码是没有任何意义的。图片的验证码就决定了,如果要自动,那么必须识别出来验证码的数字和字母。至少一般人是没法做的,这是模式识别的问题。当然我也有朋友专门做模式识别的,可以从复杂背景下辨别出来潦草的手写笔迹,碰上这样的人谁也没办法了。但是像微软有些表单的验证码的图片作的非常复杂。除了背景有很多底纹之外,数字和图片还是花体的,并且角度也不一样,有竖的,有斜的,这样就很难识别。采用了验证码基本可以保证不会被自动投票。
2:ip限时间或票数:限制ip在一段时间内的投票数量或者投两票之间的间隔时间。比如同一ip地址一天内投票数不能超过100张。或者两次投票间隔至少5分钟等。这样即使有自动投票程序,其速度也就大大降低。起不到快速投票的作用。
如果同时结合这两种手段,那么基本很难再做自动投票的事情了。
另外就是上面我所提供的头信息是怎么抓取的,这个在IE上有个插件叫做ieHTTPHeader,您可以从此处
标签: 验证码
相关推荐:
最新新闻:
- 鼠标属性中没有触摸板的选项卡怎么办?教你一招 每日热议
- ups电源的AH单位是怎么意思?和功率W怎么换算的?
- 如何建立倒数计时器?javascript建立倒数计时器_世界资讯
- 全球最资讯丨软件文档中的“基线化”是什么?提升文档基线的8种方法
- 云擎未来 智信天下 2023移动云大会盛大开幕
- 艾青绿原文及赏析(艾青绿) 全球动态
- HTML中空格怎么打出来?html页面中表示空格的字符实体有哪些?
- 如何编写一个自动投票程序?这篇文章告诉你 环球热门
- 天天最资讯丨苹果教育优惠活动什么时候开始?苹果教育优惠活动购买教程
- 百事通!如何提升usb2.0接口u盘读写速度?方法介绍
- nh文件用什么打开存在格式?如何阅读?
- 隐形的翅膀歌词含义_歌曲隐形的翅膀歌词含义
- 北京告诫:“五一”假期住宿餐饮不得在价外加价
- 五一还不知道去哪嗨?象象送你一份出游大礼包 世界热议
- 硬盘检测工具哪个好?如何检测硬盘是否损坏?|全球今日报
- 今日观点!为什么华硕笔记本电池使用时间越来越短?使用华硕笔记本电池问题集锦
- 世界信息:数据库怎么分库分表?数据库瓶颈与CPU瓶颈的区别
- 路由器连接路由器怎么设置?路由器连接设置
- DWT型屋顶风机怎么样?DWT型屋顶风机特点介绍_世界微动态
- 安卓APP解析包时出现问题如何解决?安卓APP告诉你_世界速读
- 全球速读:魔戒咕噜配置要求高吗?魔戒咕噜游戏最低配置要求是多少?
- 焦点速递!AI聊天机器人入侵亚马逊虚假评价 网购信任危机加剧
- Excel表格中的通配符如何批量替换?替换通配符的基本使用方法_全球观点
- 如何用电脑自带的计算器开方?计算器使用教程
- 日常运维笔记之Apache的工作模式及使用方法
- 【环球报资讯】页眉页脚怎么设置?页眉和页脚的切换教程
- 全球新动态:嗜睡是什么原因引起的男_嗜睡是什么原因引起的
- 佳能5D3和5D2的区别是什么?佳能5D3与5D2的区别-全球新资讯
- 商丘房产拆迁律师费用多少钱 世界百事通
- 【全球播资讯】手机忘记手势密码怎么办?教你一招
- MySQL怎么下载安装?MySQL如何卸载干净?
- ldquo 职称 rdquo 用英文怎么写
- 更改文件扩展名的方法有哪些?更改文件扩展名的方法-全球通讯
- 今日讯!怎样远程控制别人的电脑?远程控制的方法流程
- 【环球热闻】尼康D7000的特点是什么?尼康D7000的特点介绍
- 清房协租赁住房发展趋势研讨 暨金地产业园区及租赁住宅参观活动|天天热点
- 焦点关注:电脑恢复出厂设置在哪里?重装系统来恢复你的电脑
- 世界热资讯!运营商欠网易600万成老赖!曾合作《梦幻西游》等
- 世界观点:移动最低套餐有哪些?18元/月4G飞享套餐介绍
- 电驴连接服务器的方法有哪些?电驴连接不上服务器的解决方法介绍 全球热头条
- 今日精选:笔记本电脑计算机的配置表 笔记本电脑配置单及价格大全
- space是哪个键?键盘上最长的键是空格键吗?-当前热议
- 报道:移动硬盘有文件但看不见怎么恢复文件?教你一招轻松解决
- photoshop羽化在哪?ps羽化怎么用?_每日快播
- urlmon.dll网络操作API——URL语言函数 即时焦点
- python爬虫中的session和cookie如何破解?方法步骤
- 环球精选!如何使用win10虚拟桌面?使用win10虚拟桌面的实际用途及技巧
- 血源诅咒主线流程是怎样?新手玩家谋福利的经验与技巧 每日短讯
- 苹果手机的蜂窝网络是什么?iPhone12怎么打开?
- 电脑音量图标不见了怎么办?用这个方法快速找回
- 清房协租赁住房发展趋势研讨 暨金地产业园区及租赁住宅参观活动|天天热点
- 微软将以690亿美元收购动视暴雪:有望于本周获批
- 海尔AWE惊喜不断这次又有哪些亮点?_世界微速讯
- 亮点十足质价比高 华为超联接笔记本MateBook D 14开售 世界通讯
- 逼近GTX 1060!AMD Radeon 780M核显实测来了 全球速看
- 赋能教育数字化转型,华为终端商用携六大智慧解决方案亮相教育装备展 关注
- 2023第一季度中国智能门锁TOP10出炉:小米市场占有量第一 天天百事通
- 环球快资讯:中金湖北科投光谷产业园封闭式基础设施证券投资基金获通过
- Mysteel:18省份合计公布182个钢铁项目-环球今头条
- 香港的麻辣教师(麻辣老师)
- 六横登高架设作业安全培训考证忙 没有登高架设作业证书别想上岗挣钱
- 抓班子带队伍方面存在问题具体整改措施整改时限_抓班子带队伍方面存在的问题
- 焦点精选!旅行丨去过云南泼水节,上战场都不怕了!
- 讯息:办理房产证大概需要多少钱
- 5月1日苍南到临海自驾游什么路线最便捷(苍南开车到台州多久时间)
- 特殊二维码图片疯传全网:可导致微信闪退|全球热消息
- 米哈游重拳出击:海外《原神》泄密论坛遭侵权警告 短讯
- 博主惊呼小米13 Ultra四摄高度统一:简直就像1颗镜头拍的
- 恐怖悬疑游戏《爱冒险的阿曼达》上线Steam 目前好评
- 金至尊铂金多少钱一克(2023年04月26日)参考价格 每日看点
- 警惕!295家假冒国企名单公布
- 长虹美菱(000521):该股换手率大于8%(04-26)
- 范伟黑社会电影有哪些 范伟个人资料简介_世界报道
- 这些增量资金或驰援股市!_全球短讯
- iPhone 15 Pro Max仍用14同款主摄,超大底要等到iPhone 16