VB.NET表单自动提交实现方案剖析

开发 后端
如何才能完成邮件自动注册这一功能呢?处理对相关代理服务器的修改之外还需要些什么呢?有经验的朋友当然会第一时间想到VB.NET表单自动提交。

我们曾经在一篇文章中介绍过邮件自动注册中的修改代理服务器的应用。不过要想实现这一功能的话还需要一个应用的实现,那就是VB.NET表单自动提交。在这里我们就会为大家详细介绍这一应用技巧。#t#

前些天在网上看到有人需要邮箱自动注册的程序,于是自己也写了一个,在查资料的过程中我看到一些网友写的类似文章,有一些是基于网络协议,需要了解session,cookie这些东西,对于一个新手来说很繁琐,等到把这些东西搞懂,热情也消耗殆尽。vb的优点就在于可以让那些对于计算机底层不是很了解的人迅速实现自己的程序设计,我找到了一种比较简单的办法,要求对HTML标记语言有所了解即可,现在把自己的经验写出来于各位网友共享,该方法也许不值一提,也许对您有所帮助。

我的办法就是利用控件WebBrowser,我想很多人对它都很熟悉,在新建一个工程之后您要做的是添加两个控件,一个是WebBrowser,另一个是Scriptlet,这两个控件配合使用,就可以完成这个任务了,Scriptlet中的IHTMLDocument2对象可以用来获得WebBrowser控件中的HTML文档。这两个控件的名字在组件对话框里分别叫Microsoft HTML Object Library和Microsoft Internet Controls。

这两个控件添加完成之后,你还需要知道WebBrowser的一个事件DocumentComplete,这个事件在整个网页下载完成之后触发,也就是说在页面完成之后这个事件即被执行,有了这些就可以顺利的实现注册了。

下面以eyou网站的免费邮箱注册为例来实现我的程序设计,新建标准工程后向Form中添加一个WebBrowser控件。所有代码如下:

 

  1. Dim ii As Integer  
  2. Private Sub Form_Load()  
  3. WebBrowser1.Navigate "http://freemail.eyou.com/signup.html?
    bgp=%CE%D2%BD%D3%CA%DC&bgp_enable=on"  
  4. End Sub  
  5. Private Sub WebBrowser1_DocumentComplete
    (ByVal pDisp As Object, URL As Variant)  
  6. Dim doc As IHTMLDocument2  
  7. Set doc = WebBrowser1.Document  
  8. Dim tmp As String  
  9. If InStr(doc.body.innerText, "寻找一个新的用户名") > 0 Then  
  10. tmp = "sdfsdf23" + Trim(Str$(ii))  
  11. doc.All.Item("uid").focus  
  12. SendKeys tmp  
  13. SendKeys "{enter}"  
  14. End If  
  15. If InStr(doc.body.innerText, "输入您的个人资料") > 0 Then  
  16. doc.All.Item("Password").Value = "123456" 
  17. doc.All.Item("Confirm").Value = "123456" 
  18. doc.All.Item("FirstName").Value = "tomcant" 
  19. doc.All.Item("question").Value = "what is your name" 
  20. doc.All.Item("answer").Value = "my name is ddd" 
  21. doc.All.Item("year").Value = "80" 
  22. doc.All.Item("month").Value = "3" 
  23. doc.All.Item("day").Value = "18" 
  24. doc.All.Item("day").focus  
  25. SendKeys "{enter}"  
  26. End If  
  27. If InStr(doc.body.innerText, "申请邮箱成功") > 0 Then  
  28. iiii = ii + 1  
  29. WebBrowser1.Navigate "http://freemail.eyou.com/signup.html?
    bgp=%CE%D2%BD%D3%CA%DC&bgp_enable=on"  
  30. End If  
  31. 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即被执行,在这个函数中主要有三个条件语句,在三个条件语句之前有如下三句:

 

  1. Dim doc As IHTMLDocument2  
  2. Set doc = WebBrowser1.Document  
  3. Dim tmp As String 

 

doc定义为IHTMLDocument2对象用以取得WebBrowser1的文档,tmp字符串是循环注册中的用户名,在VB.NET表单自动提交的程序刚开始定义了ii这个integer变量,在每次注册完成之后ii加1附于tmp之后用以改变用户名。

第一个条件语句如下:

 

  1. If InStr(doc.body.innerText, "寻找一个新的用户名") > 0 Then  
  2. tmp = "sdfsdf23" + Trim(Str$(ii))  
  3. doc.All.Item("uid").focus  
  4. SendKeys tmp  
  5. SendKeys "{enter}"  
  6. 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加一,然后将页面重新定位到注册入口页面,至此一个循环完成。

以上VB.NET表单自动提交的代码即实现了自动注册提交。

责任编辑:曹凯 来源: wewill.cn
相关推荐

2009-10-23 13:14:38

2009-10-21 16:00:26

VB.NET CASE

2010-01-22 18:14:49

VB.NET菜单组件

2009-11-02 16:22:16

VB.NET面向对象

2009-10-13 15:09:19

VB.NET使用Tre

2009-10-23 15:35:42

VB.NET实用教程

2010-01-22 15:37:02

VB.NET监控类

2009-10-12 16:51:28

VB.NET使用Ora

2009-10-28 10:15:48

VB.NET框架类库

2010-01-14 14:21:07

2009-10-29 11:41:27

VB.NET写Obje

2010-01-12 11:47:09

VB.NET可选参数

2010-01-21 12:55:08

VB.NET对象序列

2009-10-15 17:50:48

VB.NET调用API

2010-01-12 15:54:47

VB.NET动态控件数

2010-01-12 14:02:14

VB.NET数据实体层

2010-01-22 16:39:46

VB.NET添加自动查

2009-11-02 16:41:55

VB.NET串行化对象

2010-01-19 15:42:30

VB.NET赋值语句

2009-10-22 10:10:20

VB.NET Proc
点赞
收藏

51CTO技术栈公众号