使用VB实现邮箱自动注册(二):修改代理服务器

类别:.NET开发 点击:0 评论:0 推荐:

如果一个IP在一段时间过多的注册,则该IP会被封调,一个办法就是修改注册表以修改代理服务器。在这里我使用一个API函数internetsetoption,使用之前要添加一个模块,然后加入如下代码:

Public Const internet_option_proxy = 38

Public Const INTERNET_OPEN_TYPE_PROXY = 3

Public Const INTERNET_OPTION_SETTINGS_CHANGED = 39

Type INTERNET_PROXY_INFO

    dwAccessType As Long

    lpszProxy As String

    lpszProxyBypass As String

End Type

 

Public Declare Function internetsetoption Lib "wininet.dll" _

    Alias "InternetSetOptionA" _

    (ByVal hinternet As Long, _

    ByVal dwoption As Long, _

    ByRef lpbuffer As Any, _

    ByVal dwbufferlength As Long) As Long

改代码定义了三个常数和一个结构,该API函数的具体用法请大家查询MSDNVB修改注册表的办法就太多了,我就不多说了。在WebBrowser1_DocumentComplete事件中在添加一个条件语句,用以判断是否是IP被封的提示页面,代码如下:

If InStr(doc.body.innerText, "IP地址在这一段时间内已经注册了太多的用户") > 0 Then

    Dim options As INTERNET_PROXY_INFO

    options.dwAccessType = INTERNET_OPEN_TYPE_PROXY

    options.lpszProxy = "168.10.46.77:80"

    options.lpszProxyBypass = ""

    internetsetoption 0, internet_option_proxy, options, LenB(options)

    Dim don As Double

    Dim doff As Double

    Set reg = CreateObject("Wscript.Shell")

    a = reg.regwrite("HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Internet Settings\ProxyServer", _

                "211.144.96.250:80")

    a = reg.regwrite("HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Internet Settings\ProxyEnable", _

                1)

    internetsetoption 0, INTERNET_OPTION_SETTINGS_CHANGED, 0, 0

    WebBrowser1.Navigate "http://freemail.eyou.com/signup.html?bgp=%CE%D2%BD%D3%CA%DC&bgp_enable=on"

  End If

至此代理服务器的修改也完成了。

对于一些有验证码的网站如何识别出图片上的验证码,我还没有办法解决,我试着用VC写了一个图片识别程序,但效果很不理想,希望大家多交流。

 

 

本文地址:http://com.8s8s.com/it/it43503.htm