版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、VB自动登陆网络站点详解(二):Inet控件与WebBrowser控件配合使用2009-04-25 00:26您正在看的VB教程是:VB自动登陆网络站点详解(二):Inet控件与WebBrowser控件配合使用。 URL帐号密码其它参数SOHU邮箱UserNamePassword网易通行证usernamepasswordCSDN通行证login_namepasswordcookietime=0&x=42&y=10表格中的参数就是按照前面介绍的方法得到的,在程序中将要用到。先说明一点, WebBrowser也是可以直接POST数据给Web服务器的,我将在第四部分给出代码。这里先看
2、看Inet与WebBrowser相互配合的效果。新建一个工程,部件中勾选中“Microsoft Internet Transfer Controls 6.0”、“Microsoft Internet Controls”,依次添加Inet1、WebBrowser1、Text1、Text2、Combo1在窗体上,可以把WebBrowser1适当拉大一点,将各控件位置安排好(可以参考运行后的图片),下面是代码: Dim URL1(2 As String: Dim URL2(2 As String Dim C1(2 As Stri
3、ng: Dim C2(2 As String: Dim C3(2 As StringPrivate Sub Form_Load( Text1.Text = "" Text2.Text = "" Text2.PasswordChar = "*" Combo1.AddItem "SOHU邮箱", 0 Combo1.Ad
4、dItem "网易通行证", 1 Combo1.AddItem "CSDN通行证", 2Combo1.AddItem "请选择一个登陆", 3 Combo1.Text = Combo1.List(3 URL1(0 = " URL2(0 = " URL1(1 = " URL2(1 = " URL1(2 = "
5、 URL2(2 = " 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 = "
6、cookietime=0&x=42&y=10"End SubPrivate Sub Form_Resize(If Me.WindowState <> 1 Then WebBrowser1.Left = 10 WebBrowser1.Width = Me.Width - 120 WebBrowser1.Height = Me.Height - 800End IfEnd SubPrivate Sub Text2_KeyUp(KeyCode As Inte
7、ger, 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
8、 MsgBox "请输入密码": Exit SubDim strFormData As String strFormData = C1(Combo1.ListIndex + "=" + Text1.Text + "&" + C2(Combo1.ListIndex + "=" + Text2.Text + "&" + C3(Combo1.ListIndex Inet1.Execute URL1(Combo1.
9、ListIndex, "Post", strFormData, "Content-Type: application/x-www-form-urlencoded " Do Until Inet1.StillExecuting = False '这里阻塞前面的Inet1,确保登陆成功之后再取页面,你可以将此Do取消了试一次。 DoEvents Loop If
10、Combo1.ListIndex = 1 Then WebBrowser1.Navigate URL2(Combo1.ListIndex + C1(Combo1.ListIndex + "=" + Text1.Text Else WebBrowser1.Navigate URL2(Combo1.ListIndex End IfEnd Su
11、b大家可以挑选一个自己已经注册过的站点看看效果。图文可以看到,登陆成功之后, Inet与WebBrowser是可以保持住同一个Session对话的!不过当我们在WebBrowser中显示出来的页面上点击了一个连接之后,请求却不能成功(请读者自己试一下,在登陆成功的站点中任意点击一个与用户相关的连接,弹出来的将是一个“你没有登陆”的页面)。为什么? 因为我们现在点击的连接还是使用IE(操作系统默认的浏览器)打开的,而IE请求页面的时候使用的是服务器新发送过来的Session,这个新的Session与你在WebBrowser中使用的Session也就是身份ID不一样,至少服务器是这么认为的,它以为
12、是另一个没有登陆的用户。所以说Session的作用范围不是对整个客户机的,通过实际的代码可以很好的理解这一点。(可以利用这一点,使用代码在一台电脑上实现两个以上的用户同时登陆,甚至还能对同一主题进行无缝发言。所以接下来我们要使页面继续停在WebBrowser中显示。因为很显然,既然WebBrowser与Inet是可以保持住同一个Session对话的,那么WebBrowser与WebBrowser内部自然也是可以的!要添加的代码很简单 Private Sub WebBrowser1_NewWindow2(ppDisp As Object, Cancel As Boolean
13、; Dim frm2 As New Form2 frm2.WebBrowser1.RegisterAsBrowser = True Set ppDisp = frm2.WebBrowser1.Object frm2.ShowEnd Sub然后在工程中添加一个Form2,上面再放一个WebBrowser1,调整好位置,Form2的代码窗口添加上以下代码:Private Sub Form_Load(WebBrowser1.Silent = TrueEnd SubPrivate S
14、ub Form_Resize(If Me.WindowState <> 1 Then WebBrowser1.Left = 10 WebBrowser1.Width = Me.Width - 120 WebBrowser1.Height = Me.Height - 600End IfEnd SubPrivate 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.ShowEnd Sub 利用Inet发送登陆请求,WebBrowser浏览实际页面,的确是个很不错的构思,在登陆站点相对教少的情况下应该
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年个人旧车转让协议范本
- 2024高效化妆品委托加工协议范例
- 事业单位考试计算机基础知识大纲和试题
- 2024年度医疗用品购销协议模板
- 2024年度住宅楼施工项目协议目录
- 2024年股票投资合作协议模板
- 2024年重庆市区住宅租赁协议
- 2024年软件服务行业协议样本
- 2024专项彩妆产品代理销售协议
- 文书模板-《临时劳务安全免责协议书》
- 超越指标:存量时代降本增效的利器
- 《中小学书法教育指导纲要》解读
- 住院医师规范化培训临床技能核课件
- 青岛版五四制五年级上册数学应用题216道
- 工程造价鉴定十大要点与案例分析
- 2024年金融行业发展趋势
- 印刷设计行业档案管理制度完善
- 地热资源勘查与开发利用规划编制规程
- 三年级上海市沪版英语第一学期上学期期中考试试卷
- 临床见习教案支气管哮喘地诊疗教案
- 2023年云南昆明市西山区碧鸡街道社区青年人才招考笔试历年高频考点(难、易错点荟萃)附带答案详解
评论
0/150
提交评论