刷新
当前位置: 编程技术>.net/c#/asp.net
WinForm项目开发中WebBrowser用法实例汇总
来源: 互联网 发布时间:2014-11-01
本文导语: 本文实例汇总了WinForm项目开发中WebBrowser用法,希望对大家项目开发中使用WebBrowser起到一定的帮助,具体用法如下: 1. [PermissionSet(SecurityAction.Demand, Name = "FullTrust")] [ComVisibleAttribute(true)] public partial class frmWebData : Form { public...
本文实例汇总了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脚本
function ErrorMessage(message) { document.getElementById("error").innerText = message; } 后台代码 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脚本调用后台方法
脚本代码
后台代码
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); /// /// 发起HttpWebResponse请求 /// /// 请求连接 /// 请求参数 /// 请求设置『委托』,当委托等于NULL的时候,默认请求;否则使用所设置的HttpWebRequest /// HttpWebResponse 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; } /// /// 创建验证凭证 /// eg: /// IDictionary _requestCredentials = new Dictionary(); ///_requestCredentials.Add("UserName", _userName); ///_requestCredentials.Add("PassWord", _userPwd); ///_requestCredentials.Add("MacAddress", _macAddress); ///byte[] _credentials = HttpWebRequestToolV2.CreateCredentials(_requestCredentials, Encoding.UTF8); /// /// public static byte[] CreateCredentials(IDictionary 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 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; } /// /// 登录web网页验证 /// /// 超链接 /// 用户名 /// 密码 /// MAC地址 /// 会话 /// 网页登录验证是否成功『失败,将抛出网页验证验证失败信息』 public bool ProcessRemoteLogin(string url, string _userName, string _userPwd, string _macAddress, out Cookie sessionID) { bool _checkResult = false; string _errorMessage = string.Empty; //--------------------创建登录凭证-------------------- IDictionary _requestCredentials = new Dictionary(); _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
/// /// 从WebBrowser中获取CookieContainer /// /// WebBrowser对象 /// CookieContainer 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; }