VB自动登陆网络站点详解(二):Inet控件与WebBrowser控件配合使用

 

 

 

URL

帐号

密码

其它参数

SOHU邮箱

http://login.sohu.com/chkpwd.php

UserName

Password

 

网易通行证

http://reg4.163.com/CheckUser.jsp

username

password

 

CSDN通行证

http://www.csdn.net/member/logon.asp

login_name

password

cookietime=0&

x=42&y=10

表格中的参数就是按照前面介绍的方法得到的,在程序中将要用到。

先说明一点, WebBrowser也是可以直接POST数据给Web服务器的,我将在第四部分给出代码。这里先看看InetWebBrowser相互配合的效果。

新建一个工程,部件中勾选中“Microsoft Internet Transfer Controls 6.0”、“Microsoft Internet Controls”,依次添加Inet1WebBrowser1Text1Text2Combo1在窗体上,可以把WebBrowser1适当拉大一点,将各控件位置安排好(可以参考运行后的图片),下面是代码:

    Dim URL1(2) As String:  Dim URL2(2) As String

    Dim C1(2) As String: Dim C2(2) As String: Dim C3(2) As String

Private Sub Form_Load()

       Text1.Text = ""

    Text2.Text = ""

    Text2.PasswordChar = "*"

    Combo1.AddItem "SOHU邮箱", 0

    Combo1.AddItem "网易通行证", 1

    Combo1.AddItem "CSDN通行证", 2

    Combo1.AddItem "请选择一个登陆", 3

    Combo1.Text = Combo1.List(3)

    URL1(0) = "http://login.sohu.com/chkpwd.php": URL2(0) = "http://www34.mail.sohu.com/control/entry"

    URL1(1) = "http://reg4.163.com/CheckUser.jsp": URL2(1) = "http://reg4.163.com/Main.jsp?"

    URL1(2) = "http://www.csdn.net/member/logon.asp": URL2(2) = "http://www.csdn.net/Member/Passport.asp"

    C1(0) = "UserName": C2(0) = "Password": C3(0) = ""

    C1(1) = "username": C2(1) = "password": C3(1) = ""

    C1(2) = "login_name": C2(2) = "password": C3(2) = "cookietime=0&x=42&y=10"

End Sub

Private Sub Form_Resize()

If Me.WindowState <> 1 Then

    WebBrowser1.Left = 10

    WebBrowser1.Width = Me.Width - 120

    WebBrowser1.Height = Me.Height - 800

End If

End Sub

Private Sub Text2_KeyUp(KeyCode As Integer, Shift As Integer)

    If KeyCode <> 13 Then Exit Sub

    If Combo1.ListIndex = 3 Then MsgBox "请选择一个登陆": Exit Sub

    If Text1.Text = "" Then MsgBox "请输入用户名": Exit Sub

    If Text2.Text = "" Then MsgBox "请输入密码": Exit Sub

    Dim strFormData As String

    strFormData = C1(Combo1.ListIndex) + "=" + Text1.Text + "&" + C2(Combo1.ListIndex) + "=" + Text2.Text + "&" + C3(Combo1.ListIndex)

    Inet1.Execute URL1(Combo1.ListIndex), "Post", strFormData, "Content-Type: application/x-www-form-urlencoded "

    Do Until Inet1.StillExecuting = False '这里阻塞前面的Inet1,确保登陆成功之后再取页面,你可以将此Do取消了试一次。

        DoEvents

    Loop

    If Combo1.ListIndex = 1 Then

        WebBrowser1.Navigate URL2(Combo1.ListIndex) + C1(Combo1.ListIndex) + "=" + Text1.Text

    Else

        WebBrowser1.Navigate URL2(Combo1.ListIndex)

    End If

End Sub

 

大家可以挑选一个自己已经注册过的站点看看效果。

可以看到,登陆成功之后, InetWebBrowser是可以保持住同一个Session对话的!不过当我们在WebBrowser中显示出来的页面上点击了一个连接之后,请求却不能成功(请读者自己试一下,在登陆成功的站点中任意点击一个与用户相关的连接,弹出来的将是一个“你没有登陆”的页面)。为什么?

因为我们现在点击的连接还是使用IE(操作系统默认的浏览器)打开的,而IE请求页面的时候使用的是服务器新发送过来的Session,这个新的Session与你在WebBrowser中使用的Session也就是身份ID不一样,至少服务器是这么认为的,它以为是另一个没有登陆的用户。所以说Session的作用范围不是对整个客户机的,通过实际的代码可以很好的理解这一点。(可以利用这一点,使用代码在一台电脑上实现两个以上的用户同时登陆,甚至还能对同一主题进行无缝发言。)

所以接下来我们要使页面继续停在WebBrowser中显示。因为很显然,既然WebBrowserInet是可以保持住同一个Session对话的,那么WebBrowserWebBrowser内部自然也是可以的!

要添加的代码很简单——

Private Sub WebBrowser1_NewWindow2(ppDisp As Object, Cancel As Boolean)

    Dim frm2 As New Form2

    frm2.WebBrowser1.RegisterAsBrowser = True

    Set ppDisp = frm2.WebBrowser1.Object

    frm2.Show

End Sub

然后在工程中添加一个Form2,上面再放一个WebBrowser1,调整好位置,Form2的代码窗口添加上以下代码:

Private Sub Form_Load()

WebBrowser1.Silent = True

End Sub

 

Private Sub Form_Resize()

If Me.WindowState <> 1 Then

    WebBrowser1.Left = 10

    WebBrowser1.Width = Me.Width - 120

    WebBrowser1.Height = Me.Height - 600

End If

End Sub

Private Sub WebBrowser1_NewWindow2(ppDisp As Object, Cancel As Boolean)’这里为了避免在Form1中同样发生的事情。

    Dim frm2 As New Form2

    frm2.WebBrowser1.RegisterAsBrowser = True

    Set ppDisp = frm2.WebBrowser1.Object

    frm2.Show

End Sub

利用Inet发送登陆请求,WebBrowser浏览实际页面,的确是个很不错的构思,在登陆站点相对教少的情况下应该是没有什么问题的。但是这也会使事情变得更加复杂。除了不能缺少的POST地址(URL1)、帐号参数(C1)、密码参数(C2)、其它参数(C3)之外,还必须要有供WebBrowser请求浏览的页面地址参数(URL2)。 虽然只是多了一个参数,但却添加了很多麻烦(比如网易邮箱的请求页面是根据用户的帐号名自动生成的,不固定)。只有利用WebBrowser直接POST数据才能避免第四个参数。但是浏览器的界面以及功能却是一个比较麻烦的问题(除非你不嫌麻烦,自己再动手写一个)。

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1,abkemail.ZIP<br>简单的email控件(18KB ) <br>2,abkpop.ZIP<br>一个简单的POP3控件(5KB)<br>3,winpopup.ZIP<br>允许您的 VB 程序通过网络发送和接收 Winpopup 信息(20KB)<br>4,autodial.ZIP <br>自动拨号的控件(30KB)<br>5,ddialw.EXE <br>DameWare公司出品的电话拨号控件(170KB)<br>6,dipw.EXE <br>DameWare 公司出品 IP 地址控件(169KB)<br>7,dm10e.ZIP <br>发送 E.Mail 的控件(117KB)<br>8,dsdns_eval.EXE <br>IP地址控件(703KB)<br>9,easyftp.ZIP <br>FTP 登录控件,就象 Cute FTP(195KB)<br>10,firewall.EXE <br>防火墙控件(534KB)<br>11,ftpx.EXE <br>FTP客户端控件和 COM 对象(629KB)<br>12,ftpserv.EXE <br>FTP服务器端控件和COM对象(523KB)<br>13,httpx.EXE <br>HTTP客户端控件和COM对象(644KB)<br>14,mail.EXE <br>邮件控件(797KB)<br>15,news.EXE <br>新闻组控件(664KB)<br>16,ntuserx.EXE <br>NT用户管理对象(426KB)<br>17,pingx.EXE <br>PIN 控件和COM对象(423KB)<br>18,rasx.EXE <br>RAS拨号控件(466KB) <br>19,socketx.EXE <br>WinSock 控件(589KB)<br>20,whoisx.EXE <br>Internet WhoIs(域名查找)控件和 COM 对象(436KB)<br>21,rasdialw.EXE <br>rasdialw(162KB)<br>22,i006_dlweb.zip<br>利用Winsock控件下载网页(2KB)<br>23,i005_hlink.zip<br>将这个控件加到你的窗体上,并设置好URL,当点击该控件时,你就可以打开一个网站或启动默认的电子邮件程序或是其它指定的程序。此外,你还可以改变颜色、字体、边框以及鼠标悬停状态等。<br>24,i004_ftp.zip<br>如果你想DIY一个CUTEFTP之类的程序,用这个控件可大大简化你的工作量。(46KB)<br>25,kchatocx.zip<br>chat控件(16KB)<br>26,kpopocx.zip<br>一个简单的pop控件(14KB)<br>27,krnicnntpocx.zip<br>一个在新闻组读取和发送消息的控件(23KB)<br>28,ocsetup10.exe<br>检测用户是否在线的控件(266KB)<br>29,dnslookup.zip<br>查找网络计算机的主机名或ip地址(17KB)<br>30,gotoweb.zip<br>使用默认的浏览器浏览指定web页面(12KB)<br>31,mailnotification.zip<br>在pop3邮件服务器检测邮件的控件(17KB)<br>32,easyras.zip<br>一个拨号上网的ras控件(155KB)<br>33,onoffline.zip<br>在线检测和断开internet(14KB)<br>34,ping.zip<br>ping一个主机(24KB)<br>35,popmail.zip<br>从pop邮件服务器上获得邮件的控件(20KB)<br>36,smtp.zip<br>通过smtp服务器发送邮件的控件(19KB)<br>37,trace.zip<br>跟踪主机的route(23)<br>38,dynamichtml.zip<br>在visual basic中使用动态超文本(dhtml)(12KB)<br>39,rasdialx.zip<br>网络拨号控制,还能得到许多相关信息(93KB)<br>40,abkemail.zip<br>一个简单的email控件(18KB)<br>41,internet.zip<br>对http,ftp,email,mime,news等进行编程的一套internet控件(413KB)<br>42,ipocxes.zip<br>两个OLE控件(Client和Server),可以用来在Internet上进行TCP/IP通讯(23KB)<br>43,dlinkacx.zip<br>在这个程序中进行数据的通信,轻松帮助你完成“客户/服务器”设计(227KB)<br>44,htmlpopu.zip<br>在你的程序中弹出一个超文本窗口(343KB)<br>45,bpmail.zip <br>邮件发送控件,完全免费的 OCX (14KB)<br>46,dns.zip <br>转换IP地址为主机名的控件(12KB)<br>47,hlink.zip <br>将这个控件加到你的窗体上,并设置好URL,当点击该控件时,你就可以打开一个网站或启动默认的电子邮件程序或是其它指定的程序。(有例程) (19KB)<br>48,mobilefbus.zip<br>MobileFBUS 1.5控件(112KB)<br>49,tapidial.zip<br>TAPI(电话应用程序接口)控件(41KB) <br>50,ccrpipa.zip<br>CCRP IP Address Control控件(77KB)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值