本文实例汇总了WinForm项目开发中WebBrowser用法,希望对大家项目开发中使用WebBrowser起到一定的帮助,具体用法如下:
1.
[PermissionSet(SecurityAction.Demand, Name = "FullTrust")]
[ComVisibleAttribute(true)]
public partial class frmWebData : Form
{
public frmWebData()
{
InitializeComponent();
}
protected override void OnLoad(EventArgs e)
{
wbService.ObjectForScripting = this;
base.OnLoad(e);
}
}
2.后台调用Javascript脚本
<script type="text/javascript" language="javascript">
function ErrorMessage(message) {
document.getElementById("error").innerText = message;
}
</script>
后台代码
static string ErrorMsg = string.Empty;
private void wbService_DocumentCompleted(object sender, WebBrowserDocumentCompletedEventArgs e)
{
if (!string.IsNullOrEmpty(ErrorMsg))
wbService.Document.InvokeScript("ErrorMessage", new object[1] { string.Format("操作失败,原因:{0}!", ErrorMsg) });
}
3.JavaScript脚本调用后台方法
脚本代码
<div id="content">
<h2 id="error">
操作正在响应中.....</h2>
<div class="utilities">
<a class="button right"
onclick="window.external.DoSvrWebDbBack()">
刷新
</a>
<!--<a class="button right"
onclick="window.external.NavigateToLogin()">重新登录</a>-->
<div class="clear">
</div>
</div>
</div>
后台代码
public void DoSvrWebDbBack()
{
try
{
}
catch (TimeoutException)
{
ErrorMsg = "超时,请稍候再尝试!";
}
catch (Exception ex)
{
ErrorMsg = ex.Message.ToString();
}
}
4.设置cookie
Cookie _cookie = BaseWinForm.LoginMessage.SessionID2;
InternetSetCookie(BaseWinForm.LoginMessage.SvrWebDbBack, "ASP.NET_SessionId", _cookie.Value);
wbService.Navigate(BaseWinForm.LoginMessage.SvrWebDbBack, null, null, string.Format("Referer:{0}", BaseWinForm.LoginMessage.SvrWebDbLoingUrl));
[DllImport("wininet.dll", CharSet = CharSet.Auto, SetLastError = true)]
public static extern bool InternetSetCookie(string urlName, string cookieName, string cookieData);
5.请求链接获取返回处理
public class HttpWebRequestToolV2
{
public delegate HttpWebRequest RequestRule(string url);
/// <summary>
/// 发起HttpWebResponse请求
/// </summary>
/// <param name="url">请求连接</param>
/// <param name="credentials">请求参数</param>
/// <param name="httpWebRequestRule">请求设置『委托』,当委托等于NULL的时候,默认请求;否则使用所设置的HttpWebRequest</param>
/// <returns>HttpWebResponse</returns>
public static HttpWebResponse CreateHttpWebRequest(string url, byte[] credentials, RequestRule httpWebRequestRule)
{
if (string.IsNullOrEmpty(url))
throw new ArgumentNullException("url");
HttpWebRequest _request = null;
if (httpWebRequestRule != null)
{
_request = httpWebRequestRule(url);
}
else
{
_request = WebRequest.Create(url) as HttpWebRequest;
_request.Method = "POST";
_request.ContentType = "application/x-www-form-urlencoded";
_request.CookieContainer = new CookieContainer();
}
if (credentials != null)
{
_request.ContentLength = credentials.Length;
using (var requestStream = _request.GetRequestStream())
{
requestStream.Write(credentials, 0, credentials.Length);
}
}
return _request.GetResponse() as HttpWebResponse;
}
/// <summary>
/// 创建验证凭证
/// eg:
/// IDictionary<string, string> _requestCredentials = new Dictionary<string, string>();
///_requestCredentials.Add("UserName", _userName);
///_requestCredentials.Add("PassWord", _userPwd);
///_requestCredentials.Add("MacAddress", _macAddress);
///byte[] _credentials = HttpWebRequestToolV2.CreateCredentials(_requestCredentials, Encoding.UTF8);
/// </summary>
/// <returns></returns>
public static byte[] CreateCredentials(IDictionary<string, string> credentials, Encoding encoding)
{
if (credentials == null)
throw new ArgumentNullException("credentials");
if (credentials.Count == 0)
throw new ArgumentException("credentials");
if (encoding == null)
throw new ArgumentNullException("encoding");
StringBuilder _credentials = new StringBuilder();
foreach (KeyValuePair<string, string> credential in credentials)
{
_credentials.AppendFormat("{0}={1}&", credential.Key, credential.Value);
}
string _credentialsString = _credentials.ToString().Trim();
int _endIndex = _credentialsString.LastIndexOf('&');
if (_endIndex != -1)
_credentialsString = _credentialsString.Substring(0, _endIndex);
return encoding.GetBytes(_credentialsString);
}
使用示例
public static HttpWebRequest RequestSetting(string url)
{
HttpWebRequest _request = null;
_request = WebRequest.Create(url) as HttpWebRequest;
_request.Method = "POST";
_request.ContentType = "application/x-www-form-urlencoded";
_request.Timeout = 1000 * 10;//超时五秒
_request.CookieContainer = new CookieContainer();
return _request;
}
/// <summary>
/// 登录web网页验证
/// </summary>
/// <param name="url">超链接</param>
/// <param name="_userName">用户名</param>
/// <param name="_userPwd">密码</param>
/// <param name="_macAddress">MAC地址</param>
/// <param name="sessionID">会话</param>
/// <returns>网页登录验证是否成功『失败,将抛出网页验证验证失败信息』</returns>
public bool ProcessRemoteLogin(string url, string _userName, string _userPwd, string _macAddress, out Cookie sessionID)
{
bool _checkResult = false;
string _errorMessage = string.Empty;
//--------------------创建登录凭证--------------------
IDictionary<string, string> _requestCredentials = new Dictionary<string, string>();
_requestCredentials.Add("UserName", _userName);
_requestCredentials.Add("PassWord", _userPwd);
_requestCredentials.Add("MacAddress", _macAddress);
byte[] _credentials = HttpWebRequestToolV2.
CreateCredentials
(_requestCredentials, Encoding.UTF8);
//-----------------------------------------------------
CookieCollection _cookie = null;
/*
*LoginType 1:成功 0:失败
*Err 失败原因
*/
using (HttpWebResponse _httpRespone = HttpWebRequestToolV2.
CreateHttpWebRequest
(url, _credentials, RequestSetting))
{
_cookie = new CookieCollection();
if (_httpRespone.Cookies.Count > 0)
_cookie.Add(_httpRespone.Cookies);
}
//-------------------------------------------------------
Cookie _loginType = _cookie["LoginType"];
sessionID = _cookie["ASP.NET_SessionId"];
Cookie _err = _cookie["Err"];
if (_loginType != null && _err != null && sessionID != null)
{
_checkResult = _loginType.Value.Equals("1");
if (!_checkResult)
_errorMessage = HttpUtility.UrlDecode(_err.Value);
}
else
{
_errorMessage = "Web服务异常,请稍候在试!";
}
if (!string.IsNullOrEmpty(_errorMessage))
throw new Exception(_errorMessage);
return _checkResult;
}
6.从WebBrowser中获取CookieContainer
/// <summary>
/// 从WebBrowser中获取CookieContainer
/// </summary>
/// <param name="webBrowser">WebBrowser对象</param>
/// <returns>CookieContainer</returns>
public static CookieContainer GetCookieContainer(this WebBrowser webBrowser)
{
if (webBrowser == null)
throw new ArgumentNullException("webBrowser");
CookieContainer _cookieContainer = new CookieContainer();
string _cookieString = webBrowser.Document.Cookie;
if (string.IsNullOrEmpty(_cookieString)) return _cookieContainer;
string[] _cookies = _cookieString.Split(';');
if (_cookies == null) return _cookieContainer;
foreach (string cookieString in _cookies)
{
string[] _cookieNameValue = cookieString.Split('=');
if (_cookieNameValue.Length != 2) continue;
Cookie _cookie = new Cookie(_cookieNameValue[0].Trim().ToString(), _cookieNameValue[1].Trim().ToString());
_cookieContainer.Add(_cookie);
}
return _cookieContainer;
}
|