1、自己做一个WinForm程序,上面添加一个WebBrowser控件,去访问这个页面,然后获取页面上对应的元素,例如用户名文本框,然后设置html元素的值,例如用户名设定为多少,密码设定为多少等。
上面等于完成了自动填表功能
2、自动提交功能。
获取登录页面上按钮元素,然后程序去点击该按钮,在自动填表的基础上,实现点击登录按钮,启动登录。
以下是参考资料:
下面的代码假设你已经建立了一个Windows Form,上面有一个WebBrowser名为“webBrowser”。
Study Case 1:用WinForm的Event Handler响应Web页面的事件
现在有这样一个Windows Application,它的界面上只有一个WebBrowser,显示一个本地的HTML文件作为界面。现在的问题是,所有逻辑都可以放在HTML文件里,唯独“关闭”按钮遇到了困难——通常,Web页面是没有办法直接控制浏览器的,更不用说结束这个WinForm程序了。
但是,在.Net 2.0当中,“由Windows Form响应Web页面的事件”已经成为了现实。
在.Net 2.0中,整个HTML文档以及其包含的各个HTML元素,都和一个个HtmlDocument、HtmlElement之类的.Net对象对应。因此只要找到这个“关闭”按钮对应的HtmlElement对象,为其click事件添加Event Handler即可。
假设HTML源代码如下:
那么找出该按钮并为之添加Event Handler的代码如下:
其中 HtmlBtnClose_Click是按下Web按钮时的Event Handler。
很简单吧?那么稍稍高级一点的——我们都知道一个HTML元素可能有很多各种各样的事件,而HtmlElement这个类只给出最常用、共通的几个。那么,如何响应其他事件呢?这也很简单,只需要调用HtmlElement的AttachEventHandler就可以了:
对于其他事件,把"onclick"换成该事件的名字就可以了。例如:
Study Case 2:表单(form)的自动填写和提交
要使我们的WebBrowser具有自动填表、甚至自动提交的功能,并不困难。
假设有一个最简单的登录页面,输入用户名密码,点“登录”按钮即可登录。已知用户名输入框的id(或Name,下同)是username,密码输入框的id是password,“登录”按钮的id是submitbutton,那么我们只需要在webBrowser的 DocumentCompleted事件中使用下面的代码即可:
这里我们用SetAttribute来设置文本框的“value”属性,用InvokeMember来调用了按钮的“click”方法。因为不同的Html元素,其拥有的属性和方法也不尽相同,所以.Net 2.0提供了统一的HtmlElement来概括各种Html元素的同时,提供了这两个方法以调用元素特有的功能。关于各种Html元素的属性和方法一览,可以查阅MSDN的DHTML Reference。
※关于表单的提交,的确还有另一种方法就是获取form元素而不是button,并用form元素的 submit方法:
上面等于完成了自动填表功能
2、自动提交功能。
获取登录页面上按钮元素,然后程序去点击该按钮,在自动填表的基础上,实现点击登录按钮,启动登录。
以下是参考资料:
下面的代码假设你已经建立了一个Windows Form,上面有一个WebBrowser名为“webBrowser”。
Study Case 1:用WinForm的Event Handler响应Web页面的事件
现在有这样一个Windows Application,它的界面上只有一个WebBrowser,显示一个本地的HTML文件作为界面。现在的问题是,所有逻辑都可以放在HTML文件里,唯独“关闭”按钮遇到了困难——通常,Web页面是没有办法直接控制浏览器的,更不用说结束这个WinForm程序了。
但是,在.Net 2.0当中,“由Windows Form响应Web页面的事件”已经成为了现实。
在.Net 2.0中,整个HTML文档以及其包含的各个HTML元素,都和一个个HtmlDocument、HtmlElement之类的.Net对象对应。因此只要找到这个“关闭”按钮对应的HtmlElement对象,为其click事件添加Event Handler即可。
假设HTML源代码如下:
1
2
3
4
5
|
<
html
>
<
body
>
<
input
type
=
"button"
id
=
"btnClose"
value
=
"关闭"
/>
</
body
>
</
html
>
|
那么找出该按钮并为之添加Event Handler的代码如下:
1
2
3
4
5
6
|
HtmlDocument htmlDoc = webBrowser.Document;
HtmlElement btnElement = htmlDoc.All[
"btnClose"
];
if
(btnElement !=
null
)
{
btnElement.click +=
new
HtmlElementEventHandler(HtmlBtnClose_Click);
}
|
其中 HtmlBtnClose_Click是按下Web按钮时的Event Handler。
很简单吧?那么稍稍高级一点的——我们都知道一个HTML元素可能有很多各种各样的事件,而HtmlElement这个类只给出最常用、共通的几个。那么,如何响应其他事件呢?这也很简单,只需要调用HtmlElement的AttachEventHandler就可以了:
1
2
|
btnElement.AttachEventHandler(
"onclick"
,
new
EventHandler(HtmlBtnClose_Click));
//这一句等价于上面的 btnElement.click += new HtmlElementEventHandler(HtmlBtnClose_Click);
|
对于其他事件,把"onclick"换成该事件的名字就可以了。例如:
1
|
formElement.AttachEventHandler(
"onsubmit"
,
new
EventHandler(HtmlForm_Submit));
|
Study Case 2:表单(form)的自动填写和提交
要使我们的WebBrowser具有自动填表、甚至自动提交的功能,并不困难。
假设有一个最简单的登录页面,输入用户名密码,点“登录”按钮即可登录。已知用户名输入框的id(或Name,下同)是username,密码输入框的id是password,“登录”按钮的id是submitbutton,那么我们只需要在webBrowser的 DocumentCompleted事件中使用下面的代码即可:
1
2
3
4
5
6
7
8
|
HtmlElement btnSubmit = webBrowser.Document.All[
"submitbutton"
];
HtmlElement tbUserid = webBrowser.Document.All[
"username"
];
HtmlElement tbPasswd = webBrowser.Document.All[
"password"
];
if
(tbUserid ==
null
|| tbPasswd ==
null
|| btnSubmit ==
null
)
return
;
tbUserid.SetAttribute(
"value"
,
"smalldust"
);
tbPasswd.SetAttribute(
"value"
,
"12345678"
);
btnSubmit.InvokeMember(
"click"
);
|
这里我们用SetAttribute来设置文本框的“value”属性,用InvokeMember来调用了按钮的“click”方法。因为不同的Html元素,其拥有的属性和方法也不尽相同,所以.Net 2.0提供了统一的HtmlElement来概括各种Html元素的同时,提供了这两个方法以调用元素特有的功能。关于各种Html元素的属性和方法一览,可以查阅MSDN的DHTML Reference。
※关于表单的提交,的确还有另一种方法就是获取form元素而不是button,并用form元素的 submit方法:
1
2
3
|
HtmlElement formLogin = webBrowser.Document.Forms[
"loginForm"
];
//……
formLogin.InvokeMember(
"submit"
);
|
本文之所以没有推荐这种方法,是因为现在的网页,很多都在submit按钮上添加onclick事件,以对提交的内容做最基本的验证。如果直接使用form的submit方法,这些验证代码就得不到执行,有可能会引起错误。