文章探索:   分类:    关键字:  
  + 栏目导航
  + 相关文章
文本框中光标位置的获得
用VB导入导出你的IE收藏夹
VB应用程序访问SQL Server方法探讨
VB访问SQL Server数据库技术全揭密
自动上网抓数据的机器人
自己的IE——用VB制作浏览器
VB中如何保存Webbrowser中的整个页面..
在VB中该如何控制其它程序的弹出窗口..
保存webbrowser中的HTML内容
破译动网验证码的简单方法
轻松获取QQ密码
VB.NET获取硬盘序列号的方法
WEBBROWSER 技巧一(收藏)
VB自动登陆网络站点详解(二):Inet..
获取webbrowser控件网页的源码
WebBrowser控件说明
关于用VB做更漂亮的窗体的思考
VB中访问存储过程的几种办法
VB6中改变屏幕的分辨率和刷新频率
VB编写一个能显示百分比的自定义进度..
公农历转换VB类
VB.NET窗口渐淡关闭
使用VB实现邮箱自动注册(二):修改..
VB.NET轻松实现任务栏程序
VB.NET启动外部程序
利用vb实现图片上传
VB实现局域网内的文件传输
VB 一个Function传回多个值
在VB中实现多线程
VB 手机号码编码程序


技术教程 -> VB教程 ->  
使用VB实现邮箱自动注册(一):表单自动提交
来源:转载   人气:800   录入时间:2007-11-8
    前些天在网上看到有人需要邮箱自动注册的程序,于是自己也写了一个,在查资料的过程中我看到一些网友写的类似文章,有一些是基于网络协议,需要了解session,cookie这些东西,对于一个新手来说很繁琐,等到把这些东西搞懂,热情也消耗殆尽。VB的优点就在于可以让那些对于计算机底层不是很了解的人迅速实现自己的程序设计,我找到了一种比较简单的办法,要求对HTML标记语言有所了解即可,现在把自己的经验写出来于各位网友共享,该方法也许不值一提,也许对您有所帮助。
   
   我的办法就是利用控件WebBrowser,我想很多人对它都很熟悉,在新建一个工程之后您要做的是添加两个控件,一个是WebBrowser,另一个是Scriptlet,这两个控件配合使用,就可以完成这个任务了,Scriptlet中的IHTMLDocument2对象可以用来获得WebBrowser控件中的HTML文档。这两个控件的名字在组件对话框里分别叫Microsoft HTML Object Library和Microsoft Internet Controls。
   
   这两个控件添加完成之后,你还需要知道WebBrowser的一个事件DocumentComplete,这个事件在整个网页下载完成之后触发,也就是说在页面完成之后这个事件即被执行,有了这些就可以顺利的实现注册了。
   
   下面以eyou网站的免费邮箱注册为例来实现我的程序设计,新建标准工程后向Form中添加一个WebBrowser控件。所有代码如下:
   
   Dim ii As Integer
   
   
   
   Private Sub Form_Load()
   
   WebBrowser1.Navigate "http://freemail.eyou.com/signup.html?bgp=%CE%D2%BD%D3%CA%DC&bgp_enable=on"
   
   End Sub
   
   
   
   Private Sub WebBrowser1_DocumentComplete(ByVal pDisp As Object, URL As Variant)
   
   Dim doc As IHTMLDocument2
   
   Set doc = WebBrowser1.Document
   
   Dim tmp As String
   
   
   
   If InStr(doc.body.innerText, "寻找一个新的用户名") > 0 Then
   
   tmp = "sdfsdf23" + Trim(Str$(ii))
   
   doc.All.Item("uid").focus
   
   SendKeys tmp
   
   SendKeys "{enter}"
   
   End If
   
   
   
   If InStr(doc.body.innerText, "输入您的个人资料") > 0 Then
   
   
   
   doc.All.Item("Password").Value = "123456"
   
   doc.All.Item("Confirm").Value = "123456"
   
   doc.All.Item("FirstName").Value = "tomcant"
   
   doc.All.Item("question").Value = "what is your name"
   
   doc.All.Item("answer").Value = "my name is ddd"
   
   doc.All.Item("year").Value = "80"
   
   doc.All.Item("month").Value = "3"
   
   doc.All.Item("day").Value = "18"
   
   doc.All.Item("day").focus
   
   SendKeys "{enter}"
   
   End If
   
   
   If InStr(doc.body.innerText, "申请邮箱成功") > 0 Then
   
   ii = ii + 1
   
   WebBrowser1.Navigate "http://freemail.eyou.com/signup.html?bgp=%CE%D2%BD%D3%CA%DC&bgp_enable=on"
   
   End If
   
   
   End Sub
   
   Eyou的免费邮箱注册入口地址为http://freemail.eyou.com/signup.html?bgp=%CE%D2%BD%D3%CA%DC&bgp_enable=on,所以要在Form_load事件中使用WebBrowser控件的Navigate方法。
   
   在eyou的注册入口页面完成之后WebBrowser1_DocumentComplete即被执行,在这个函数中主要有三个条件语句,在三个条件语句之前有如下三句:
   
   Dim doc As IHTMLDocument2
   
   Set doc = WebBrowser1.Document
   
   Dim tmp As String
   
   doc定义为IHTMLDocument2对象用以取得WebBrowser1的文档,tmp字符串是循环注册中的用户名,在程序刚开始定义了ii这个integer变量,在每次注册完成之后ii加1附于tmp之后用以改变用户名。
   
   第一个条件语句如下:
   
   If InStr(doc.body.innerText, "寻找一个新的用户名") > 0 Then
   
   tmp = "sdfsdf23" + Trim(Str$(ii))
   
   doc.All.Item("uid").focus
   
   SendKeys tmp
   
   SendKeys "{enter}"
   
   End If
   
   首先判断是否是注册入口页面,通过InStr(doc.body.innerText, "寻找一个新的用户名") > 0语句实现,doc.body.innerText即取得了该页面中的所有文字。如果是则构造一个用户名。doc.All.Item("uid").focus使用户名文本框取得焦点,其中uid是该文本框的ID,这个ID的取得是通过查看HTML源代码得到的,所以要求对HTML标记语言有所了解。使用户名文本框取得焦点之后通过SendKeys函数模拟键盘向文本框发送tmp字符串,这样用户名即填写完成,之后发送回车键提交表单。关于SendKeys函数的使用大家可查阅MSDN帮助。
   
   第二个条件语句首先判断改页面是否是个人资料填写页面,然后填写个人资料,其方法同填写用户名一致,取得个文本框的ID后填写其值,最后提交表单。
   
   最后一个条件语句判断邮箱注册成功后将ii加一,然后将页面重新定位到注册入口页面,至此一个循环完成。
   
   以上代码即实现了自动注册提交。
   




Copyright(C)2007-2024 广州市佳沛数码科技有限公司 版权所有
公司地址: 广州市荔湾区东漖北路560号511室
电话:020-81803473 传真:020-81544987