厚积薄发,丰富的公用类库积累,助你高效进行系统开发(12)--- 网络相关操作辅助类

俗话说,一个好汉十个帮,众人拾柴火焰高等都说明一个道理,有更多的资源,更丰富的积累,都是助你走向成功,走向顶峰的推动力。

本篇的公用类库的介绍主题是程序开发中多线程操作环境中,常用到的网络操作相关类,本篇随笔介绍包含邮件发送辅助类(包含附件、嵌入图片等)、获取网页数据辅助类库、管理文档服务器类、网络相关操作辅助类、IE代理设置辅助类等对象,这些辅助类覆盖了网络编程开发中多数的应用。良好的封装及操作,给我们提供非常方便、高效的辅助类库操作体验。

本篇继续继续整理优化已有的共用类库,并继续发表随笔介绍公用类库的接口方法以及详细使用操作,力求给自己继续优化,积攒更丰富的公用类库资源,加深了解的同时,也给大家展现公用类库好的方面。
1、发送邮件的辅助类 EmailHelper。

实现效果

  1. 本辅助类主要是用来方便实现发送邮件操作,可以发送附件、嵌入图片、HTML等内容邮件。使用底层SMTP协议指令进行发送,成功率较高。

2)邮件发送可以用在客户反馈,信息推广,客户沟通,员工交流等方面业务需要。

实现代码

1)辅助类提供的方法源码如下所示:

///     
/// 设定语言代码,默认设定为GB2312,如不需要可设置为""    
/// 
public string Charset = "GB2312";    
   
///     
/// 邮箱服务器    
/// 
public string MailServer    
   
///     
/// 邮件服务器端口号,默认端口为25    
/// 
public int MailServerPort    
   
///     
/// SMTP认证时使用的用户名    
/// 
public string MailServerUsername    
   
///     
/// SMTP认证时使用的密码    
/// 
public string MailServerPassword    
   
///     
/// 发件人地址    
/// 
public string From    
   
///     
/// 发件人姓名    
/// 
public string FromName    
   
///     
/// 回复邮件地址    
/// 
public string ReplyTo = "";    
   
///     
/// 邮件主题    
/// 
public string Subject = "";    
   
///     
/// 是否Html邮件    
/// 
public bool IsHtml = false;    
   
///     
/// 收件人是否发送收条    
/// 
public bool ReturnReceipt = false;    
   
///     
/// 邮件正文    
/// 
public string Body = "";    
   
///     
/// 邮件发送优先级,可设置为"High","Normal","Low"或"1","3","5"    
/// 
public string Priority    
   
///     
/// 错误消息反馈    
/// 
public string ErrorMessage    
   
///     
/// 收件人姓名    
/// 
public string RecipientName = "";    
   
///     
/// 默认构造函数    
/// 
public EmailHelper()    
   
///     
/// 待邮箱发送配置参数的构造函数    
///     
/// 邮件服务器    
/// 用户名    
/// 用户密码
public EmailHelper(string mailServer, string username, string password)     
   
///     
/// 待邮箱发送配置参数的构造函数    
///     
/// 邮件服务器    
/// 用户名    
/// 用户密码    
/// 邮箱服务器端口
public EmailHelper(string mailServer, string username, string password, int port)     
   
 ///     
/// 添加一个附件,需使用绝对路径    
/// 
public bool AddAttachment(string path)    
        
///     
/// 添加一个收件人    
///       
/// 收件人地址
public bool AddRecipient(string str)           
   
 ///     
/// 添加一个抄送收件人    
///     
/// 收件人地址
public bool AddRecipientCC(string str)    
        
///     
/// 添加一个密件收件人    
///     
/// 收件人地址
public bool AddRecipientBCC(string str)    
        
///     
/// 清空收件人列表    
/// 
public void ClearRecipient()    
        
///     
/// 发送邮件    
/// 
public bool SendEmail()    

2)辅助类EmailHelper的使用例子代码如下所示

EmailHelper email = new EmailHelper("smtp.163.com", "[email protected]", "password");    
email.Subject = "伍华聪的普通测试邮件";    
email.Body = string.Format("测试邮件正文内容");    
email.IsHtml = true;    
email.From = "[email protected]";    
email.FromName = "wuhuacong2013";    
email.AddRecipient("[email protected]");    
try   
{    
    bool success = email.SendEmail();    
    MessageUtil.ShowTips(success ? "发送成功" : "发送失败");    
}    
catch (Exception ex)    
{    
    MessageUtil.ShowError(ex.Message);    
}  
厚积薄发,丰富的公用类库积累,助你高效进行系统开发(12)--- 网络相关操作辅助类_第1张图片

3)如果使用发送附件、发送嵌入图片(正文中有图片显示内容的)方式,则例子代码如下所示。

EmailHelper email = new EmailHelper("smtp.163.com", "[email protected]", "password");    
email.Subject = "伍华聪的图片附件测试邮件";    
string embedFile = Path.Combine(Application.StartupPath, "cityroad.jpg");    
email.Body = string.Format("测试邮件正文内容 ", embedFile);    
email.IsHtml = true;    
email.From = "[email protected]";    
email.FromName = "wuhuacong2013";    
email.AddRecipient("[email protected]");    
email.AddAttachment(Path.Combine(Application.StartupPath, "ringin.wav"));//.AddAttachment("C:\\test.txt");    
   
try   
{    
    bool success = email.SendEmail();    
    MessageUtil.ShowTips(success ? "发送成功" : "发送失败");     
}    
catch (Exception ex)    
{    
    MessageUtil.ShowError(ex.Message);    
}  
厚积薄发,丰富的公用类库积累,助你高效进行系统开发(12)--- 网络相关操作辅助类_第2张图片

**2、获取网页数据辅助类库 HttpHelper。 **
实现效果

  1. 本辅助类主要是用来方便实现获取网页数据的操作,可以通过GET、POST方式获取网页内容,获取验证码等图片资源,是网络编程不可或缺的强大辅助类库。
    2) 该辅助类库在我的QQ搜通天系列软件、QQ群成员提取工具、易博搜搜等网络应用软件上,辅助类主要是用于网页数据采集和分析操作。

实现代码
1)辅助类提供的方法源码如下所示:

#region 属性    
        
///     
/// 内容类型,默认为"application/x-www-form-urlencoded"    
/// 
public string ContentType    
   
///     
/// Accept值,默认支持各种类型    
/// 
public string Accept    
   
///     
/// UserAgent,默认支持Mozilla/MSIE等    
/// 
public string UserAgent    
   
///     
/// Cookie容器    
/// 
public CookieContainer CookieContainer    
   
///     
/// 获取网页源码时使用的编码    
///     
/// 
public Encoding Encoding    
   
///     
/// 网络延时    
/// 
public int NetworkDelay    
   
///     
/// 最大尝试次数    
/// 
public int MaxTry   
  
#endregion   
  
#region 构造函数    
   
///     
/// 构造函数    
/// 
public HttpHelper()    
   
///     
/// 构造函数    
///     
/// 指定CookieContainer的值
public HttpHelper(CookieContainer cc)    
   
///     
/// 构造函数    
///     
/// 内容类型    
/// Accept类型    
/// UserAgent内容
public HttpHelper(string contentType, string accept, string userAgent)    
   
///     
/// 构造函数    
///     
/// 指定CookieContainer的值    
/// 内容类型    
/// Accept类型    
/// UserAgent内容
public HttpHelper(CookieContainer cc, string contentType, string accept, string userAgent)   
  
#endregion   
  
#region 公共方法    
                    
///     
/// 获取指定页面的HTML代码    
///     
/// 指定页面的路径    
/// Cookie集合    
/// 回发的数据    
/// 是否以post方式发送请求    
/// 
public string GetHtml(string url, CookieContainer cookieContainer, string postData, bool isPost)    
   
///     
/// 获取指定页面的HTML代码    
///     
/// 指定页面的路径    
/// Cookie集合对象    
/// 回发的数据    
/// 是否以post方式发送请求    
/// 页面引用    
/// 
public string GetHtml(string url, CookieContainer cookieContainer, string postData, bool isPost, string referer)    
   
///     
/// 获取指定页面的HTML代码    
///     
/// 指定页面的路径    
/// Cookie集合    
/// 页面引用    
/// 
public string GetHtml(string url, CookieContainer cookieContainer, string reference)    
   
///     
/// 获取指定页面的HTML代码    
///     
/// 指定页面的路径    
/// 
public string GetHtml(string url)    
   
///     
/// 获取指定页面的HTML代码    
///     
/// 指定页面的路径    
/// 页面引用    
/// 
public string GetHtml(string url, string reference)    
   
///     
/// 获取指定页面的HTML代码    
///     
/// 指定页面的路径    
/// 回发的数据    
/// 是否以post方式发送请求    
/// 
public string GetHtml(string url, string postData, bool isPost)    
                    
///     
/// 获取指定页面的Stream    
///     
/// 指定页面的路径    
/// Cookie集合对象    
/// 
public Stream GetStream(string url, CookieContainer cookieContainer)    
   
///     
/// 获取指定页面的Stream    
///     
/// 指定页面的路径    
/// Cookie对象    
/// 页面引用
public Stream GetStream(string url, CookieContainer cookieContainer, string reference)    
   
///     
/// 根据Cookie字符串获取Cookie的集合    
///     
/// Cookie字符串    
/// 
public CookieCollection GetCookieCollection(string cookieString)    
   
///     
/// 获取HTML页面内容指定隐藏域Key的Value内容    
///     
/// 待操作的HTML页面内容    
/// 隐藏域的名称    
/// 
public string GetHiddenKeyValue(string html, string key)    
   
///     
/// 获取网页的编码格式    
///     
/// 网页地址    
/// 
public string GetEncoding(string url)    
   
///     
/// 判断URL是否有效    
///     
/// 待判断的URL,可以是网页以及图片链接等    
/// 200为正确,其余为大致网页错误代码
public int GetUrlError(string url)    
   
///     
/// 移除Html标记    
/// 
public string RemoveHtml(string content)    
   
///     
/// 返回 HTML 字符串的编码结果    
///     
/// 字符串    
/// 编码结果
public static string HtmlEncode(string inputData)    
   
///     
/// 返回 HTML 字符串的解码结果    
///     
/// 字符串    
/// 解码结果
public static string HtmlDecode(string str)   
  
#endregion  

2)辅助类HttpHelper的使用例子代码如下所示,下面的是最为简单的获取页面内容的操作。

public void GetQQLog()    
{    
    string qq = this.txtQQ.Text;    
    string json = "";    
   
    string url = string.Format("http://b.qzone.qq.com/cgi-bin/blognew/blog_get_titlelist?direct=1&numperpage=100&uin={0}", qq);    
    HttpHelper helper = new HttpHelper();    
    helper.Encoding = Encoding.Default;    
    json = helper.GetHtml(url);    
    ..............    
}  

实际操作可能更多的是要记录Cookie信息,方便下一次的调用,还有可能需要获取验证码等等,复杂一点的例子代码如下所示。

string uin = e.Argument.ToString();                
HttpHelper httpHelper = new HttpHelper();    
string refUrl = "http://qzone.qq.com/";    
string url = string.Format("http://ptlogin2.qq.com/check?uin={0}&appid=46000101&r=0.5454333601416937", uin);    
string checkHtml = httpHelper.GetHtml(url, Portal.gc.cookieZone, refUrl);    
//ptui_checkVC('1','56443c908b8be83dc4435e253e6b43ad99eab4fe0846930d');    
Regex re = new Regex("ptui_checkVC\\('\\d+','(.*?)'\\);", RegexOptions.IgnoreCase | RegexOptions.Singleline | RegexOptions.IgnorePatternWhitespace);    
Match mc = re.Match(checkHtml);    
if (!mc.Success)    
{    
    return;    
}    
   
string vc_type = re.Matches(checkHtml)[0].Groups[1].Value;    
string imageUrl = string.Format("http://captcha.qq.com/getimage?aid=46000101&r=0.2758570793854393&uin={0}&vc_type={1}", uin, vc_type);    
using (Stream s = httpHelper.GetStream(imageUrl, Portal.gc.cookieZone))    
{    
    if (s == null)    
    {    
        MessageExUtil.ShowWarning("获取登陆码错误,请检查您的网络!");    
        return;    
    }    
    e.Result = Image.FromStream(s);    
}  

上面的操作都是使用GET方式获取页面内容或者数据的,另外还有一种方式就是使用POST方式提交数据,并获取页面内容的,如下例子所示。

#region 构造提交参数    
StringBuilder sb = new StringBuilder();    
sb.AppendFormat("callCount=1");    
sb.AppendFormat("&page=/{0}/members/", urlName);    
sb.AppendFormat("&httpSessionId=");    
sb.AppendFormat("&scriptSessionId=D4DAC4AD9C3BF9B71C82802BDDBA0C25369");    
sb.AppendFormat("&c0-scriptName=CircleBean");    
sb.AppendFormat("&c0-methodName=getNewCircleUsers");    
sb.AppendFormat("&c0-id=0");//保留字符    
sb.AppendFormat("&c0-param0=number:{0}", circleId);//11    
sb.AppendFormat("&c0-param1=number:{0}", pageSize);//数量    
sb.AppendFormat("&c0-param2=number:{0}", pageSize * i);//0,30,60    
sb.AppendFormat("&c0-param3=boolean:true");    
sb.AppendFormat("&batchId={0}", i);    
i++;    
   
//callCount=1    
//page=/dnkxin/members/    
//httpSessionId=    
//scriptSessionId=D4DAC4AD9C3BF9B71C82802BDDBA0C25369    
//c0-scriptName=CircleBean    
//c0-methodName=getNewCircleUsers    
//c0-id=0    
//c0-param0=number:15057111            //()    
//c0-param1=number:10    
//c0-param2=number:0    
//c0-param3=boolean:true    
//batchId=0   
#endregion    
   
string content = "";    
try   
{    
    httpHelper.ContentType = "text/plain";    
    content = httpHelper.GetHtml(url, cookie, sb.ToString(), true, refUrl);//使用Post方式提交内容,并返回页面结果    
    re = new Regex(circleReg.ToString(), RegexOptions.IgnoreCase | RegexOptions.Singleline | RegexOptions.IgnorePatternWhitespace);    
    mc = re.Match(content);    
}    
catch (Exception ex)    
{    
    LogTextHelper.WriteLine(ex.ToString());    
    break;    
}  

下面是一些具体应用的例子截图,主要就是通过该辅助类获取、分析网页的处理结果。


厚积薄发,丰富的公用类库积累,助你高效进行系统开发(12)--- 网络相关操作辅助类_第3张图片

厚积薄发,丰富的公用类库积累,助你高效进行系统开发(12)--- 网络相关操作辅助类_第4张图片

**3、管理文档服务器类,提供文件上传、下载、删除等功能辅助类 FileServerManage。 **
实现效果

  1. 本辅助类主要是用来方便实现管理文档服务器类,提供文件上传、下载、删除等功能。 不过注意,由于IIS操作限制,可能一些后缀名的文件不支持访问。
    2)FileServerManage 主要是通过IIS网站方式上传管理文件附件的,要使用该辅助类库的功能,需要为指定的目录(一般在文件服务器上一个目录)建立一个虚拟网站,指定端口等参数,该辅助类库的构造函数,使用的是虚拟网站的URL地址以及文件服务器的登录账号和密码(本机则使用本机的账号密码)。 3)另外使用IIS作为文件上传操作,除了需要用到当前机器的账号密码登录外,还需要在IIS管理中开通/启用WebDev的功能。

实现代码
1)辅助类提供的方法源码如下所示:

///     
/// 构造函数    
/// 
public FileServerManage()    
   
///     
/// 构造函数    
///     
/// 指定URL地址    
/// 指定用户名    
/// 指定密码
public FileServerManage(string url, string username, string password)    
   
///     
/// 上传文件    
///     
/// 流对象    
/// 保存文件名,可包含文件夹(test/test.txt)    
/// bool[true:成功,false:失败]
public bool UploadFile(Stream inputStream, string fileName)    
   
///     
/// 上传文件    
///     
/// 上传地址    
/// 上传文件名称,可包含文件夹(test/test.txt)    
/// bool[true:成功,false:失败]
public bool UploadFile(string fileUrl, string fileName)    
   
///     
/// 删除文件    
///     
/// 文件名称,可包含文件夹(test/test.txt)    
/// bool[true:成功,false:失败]
public bool DeleteFile(string fileName)    
   
///     
/// 判断文件是否存在    
///     
/// 文件名称,可包含文件夹(test/test.txt)    
/// bool[true:存在,false:否]
public bool IsFileExist(string fileName)    
   
///     
/// 通过HttpResponse方式读取文件,Web开发才可以使用    
///     
/// 新文件名称,可包含文件夹(test/test.txt)    
/// 原文件名称    
/// 
public string ReadFile(string newFileName, string oldFileName)    
   
///     
/// 读取服务器文件到字节数据中    
///     
/// 文件名称,可包含文件夹(test/test.txt)    
/// 
public byte[] ReadFileBytes(string fileName)   

2)辅助类FileServerManage的使用例子代码如下所示

private void btnWebFile_Click(object sender, EventArgs e)    
{    
    WHC.OrderWater.Commons.Web.FileServerManage file = new WHC.OrderWater.Commons.Web.FileServerManage("http://192.168.1.30:8009", "administrator", "123456789");    
    try   
    {    
        //上传文件    
        bool first = false;    
        using (FileStream fs = new FileStream("C:\\test.txt", FileMode.Open))    
        {    
            first = file.UploadFile(fs, "test.txt");    
        }    
   
        //利用子目录上传,需要服务器手动创建目录    
        bool second = file.UploadFile("C:\\test.txt", "Bridge/test.txt");    
   
        MessageUtil.ShowTips(string.Format("第一次上传:{0} 第二次上传{1}", first, second));    
            
        byte[] fileBytes = file.ReadFileBytes("test.txt");    
        if (fileBytes != null)    
        {    
            MessageUtil.ShowTips(string.Format("File Bytes:{0}", fileBytes.Length));    
        }    
   
        //删除文件    
        first = file.DeleteFile("test.txt");    
        bool third = file.IsFileExist("Bridge/test.txt");    
        second = file.DeleteFile("Bridge/test.txt");     
        MessageUtil.ShowTips(string.Format("删除文件:{0}、{1} 文件存在:{2}", first, second, third));    
            
    }    
    catch (Exception ex)    
    {    
        MessageUtil.ShowError(ex.Message);    
    }    
}  

**4、网络相关操作辅助类 NetworkUtil **
实现效果

  1. 本辅助类主要是用来方便实现网络相关操作,可以对IP或者域名进行相互解析,基于Socket的TCP/UDP相关操作,检测本机是否联网等相关的网络操作。
    实现代码
    1)辅助类提供的方法源码如下所示:
///     
/// 获取本地机器IP地址    
///     
/// 
public static string GetLocalIP()    
   
///     
/// 检查设置的IP地址是否正确,并返回正确的IP地址,无效IP地址返回"-1"。    
///     
/// 设置的IP地址    
/// 非法IP 则返回 -1 
public static string GetValidIP(string ip)    
   
///     
/// 检查设置的端口号是否正确,并返回正确的端口号,无效端口号返回-1。    
///     
/// 设置的端口号
public static int GetValidPort(string port)    
   
///     
/// 将字符串形式的IP地址转换成IPAddress对象    
///     
/// 字符串形式的IP地址
public static IPAddress StringToIPAddress(string ip)    
   
///     
/// 获取本机的计算机名    
/// 
public static string LocalHostName    
   
///     
/// 获取本机的局域网IP    
/// 
public static string LANIP    
   
///     
/// 获取本机在Internet网络的广域网IP    
/// 
public static string WANIP    
   
///     
/// 获取远程客户机的IP地址    
///     
/// 客户端的socket对象
public static string GetClientIP(Socket clientSocket)    
   
///     
/// 创建一个IPEndPoint对象    
///     
/// IP地址    
/// 端口号
public static IPEndPoint CreateIPEndPoint(string ip, int port)    
   
///     
/// 创建一个自动分配IP和端口的TcpListener对象    
/// 
public static TcpListener CreateTcpListener()    
   
///     
/// 创建一个TcpListener对象    
///     
/// IP地址    
/// 端口
public static TcpListener CreateTcpListener(string ip, int port)    
   
///     
/// 创建一个基于TCP协议的Socket对象    
/// 
public static Socket CreateTcpSocket()    
   
///     
/// 创建一个基于UDP协议的Socket对象    
/// 
public static Socket CreateUdpSocket()   
  
#region 获取TcpListener对象的本地终结点    
///     
/// 获取TcpListener对象的本地终结点    
///     
/// TcpListener对象
public static IPEndPoint GetLocalPoint(TcpListener tcpListener)    
   
///     
/// 获取TcpListener对象的本地终结点的IP地址    
///     
/// TcpListener对象
public static string GetLocalPoint_IP(TcpListener tcpListener)    
   
///     
/// 获取TcpListener对象的本地终结点的端口号    
///     
/// TcpListener对象
public static int GetLocalPoint_Port(TcpListener tcpListener)   
  
#endregion   
  
#region 获取Socket对象的本地终结点    
        
///     
/// 获取Socket对象的本地终结点    
///     
/// Socket对象
public static IPEndPoint GetLocalPoint(Socket socket)    
   
///     
/// 获取Socket对象的本地终结点的IP地址    
///     
/// Socket对象
public static string GetLocalPoint_IP(Socket socket)    
   
///     
/// 获取Socket对象的本地终结点的端口号    
///     
/// Socket对象
public static int GetLocalPoint_Port(Socket socket)   
  
#endregion    
   
///     
/// 绑定终结点    
///     
/// Socket对象    
/// 要绑定的终结点
public static void BindEndPoint(Socket socket, IPEndPoint endPoint)    
   
///     
/// 绑定终结点    
///     
/// Socket对象            
/// 服务器IP地址    
/// 服务器端口
public static void BindEndPoint(Socket socket, string ip, int port)    
   
///     
/// 指定Socket对象执行监听,默认允许的最大挂起连接数为100    
///     
/// 执行监听的Socket对象    
/// 监听的端口号
public static void StartListen(Socket socket, int port)    
   
///     
/// 指定Socket对象执行监听    
///     
/// 执行监听的Socket对象    
/// 监听的端口号    
/// 允许的最大挂起连接数
public static void StartListen(Socket socket, int port, int maxConnection)    
   
///     
/// 指定Socket对象执行监听    
///     
/// 执行监听的Socket对象    
/// 监听的IP地址    
/// 监听的端口号    
/// 允许的最大挂起连接数
public static void StartListen(Socket socket, string ip, int port, int maxConnection)    
   
///     
/// 连接到基于TCP协议的服务器,连接成功返回true,否则返回false    
///     
/// Socket对象    
/// 服务器IP地址    
/// 服务器端口号
public static bool Connect(Socket socket, string ip, int port)    
   
///     
/// 以同步方式向指定的Socket对象发送消息    
///     
/// socket对象    
/// 发送的消息
public static void SendMsg(Socket socket, byte[] msg)    
   
///     
/// 使用UTF8编码格式以同步方式向指定的Socket对象发送消息    
///     
/// socket对象    
/// 发送的消息
public static void SendMsg(Socket socket, string msg)    
   
///     
/// 以同步方式接收消息    
///     
/// socket对象    
/// 接收消息的缓冲区
public static void ReceiveMsg(Socket socket, byte[] buffer)    
   
///     
/// 以同步方式接收消息,并转换为UTF8编码格式的字符串,使用5000字节的默认缓冲区接收。    
///     
/// socket对象
public static string ReceiveMsg(Socket socket)    
   
///     
/// 关闭基于Tcp协议的Socket对象    
///     
/// 要关闭的Socket对象
public static void Close(Socket socket)    
   
   
///     
/// 检测本机是否联网    
///     
/// 
public static bool IsConnectedInternet()    
   
///     
/// 检测本机是否联网的连接属性    
/// 
public static InternetConnectionStatesType CurrentState    
   
///     
/// 检测本机是否联网(互联网)    
///     
/// 
public static bool IsOnline()    
   
///     
/// 转换主机域名DNS到IP地址    
///     
/// 主机域名DNS    
/// 
public static string ConvertDnsToIp(string hostname)    
   
///     
/// 转换主机IP地址到DNS域名    
///     
/// 主机IP地址    
/// 
public static string ConvertIpToDns(string ipAddress)    
   
///     
/// 根据IP端点获取主机名称    
///     
/// IP端点    
/// 
public static string GetHostName(IPEndPoint ipEndPoint)    
   
///     
/// 根据主机IP地址对象获取主机名称    
///     
/// 主机IP地址对象    
/// 
public static string GetHostName(IPAddress ip)    
   
///     
/// 根据主机IP获取主机名称    
///     
/// 主机IP    
/// 
public static string GetHostName(string hostIP)    
   
///     
/// 得到一台机器的EndPoint端点    
///     
/// 主机实体    
/// 
public static EndPoint GetNetworkAddressEndPoing(IPHostEntry entry)    
   
///     
/// 主机名是否存在    
///     
/// 主机名    
/// 
public static bool IsHostAvailable(string host)    
   
   
///     
/// 在主机名解析到一个IP主机实体    
///     
/// 主机名    
/// 
public static IPHostEntry ResolveHost(string host) 

2)辅助类NetworkUtil的使用例子代码如下所示。

private void btnNetWork_Click(object sender, EventArgs e)    
{    
    StringBuilder sb = new StringBuilder();    
    sb.AppendFormat("本机IP:{0} \r\n", NetworkUtil.GetLocalIP());    
    sb.AppendFormat("检测本机是否联网:{0} \r\n", NetworkUtil.IsConnectedInternet());    
    sb.AppendFormat("www.iqid.com域名IP:{0} \r\n", NetworkUtil.ConvertDnsToIp("www.iqidi.com"));    
    sb.AppendFormat("本机LocalHostName:{0}  \r\n", NetworkUtil.LocalHostName);    
    sb.AppendFormat("本机局域网IP:{0}  \r\n", NetworkUtil.LANIP);    
    sb.AppendFormat("本机广域网IP:{0}  \r\n", NetworkUtil.WANIP);    
   
    Socket socket = NetworkUtil.CreateTcpSocket();    
    Socket udpsocket = NetworkUtil.CreateUdpSocket();    
    TcpListener listen = NetworkUtil.CreateTcpListener("127.0.0.1", 9900);    
    listen.Start(100);    
   
    MessageUtil.ShowTips(sb.ToString());    
}  

**5、IE代理设置辅助类 ProxyHelper。 **
实现效果

  1. 本辅助类主要是用来方便实现IE代理设置操作。
    实现代码
    1)辅助类提供的方法源码如下所示:
///     
/// IE代理设置辅助类    
/// 
public class ProxyHelper    
{   
    #region IE代理设置    
   
    ///     
    /// 让IE支持WAP    
    /// 
    public static void SetIESupportWap()    
   
    ///     
    /// 设置代理    
    ///     
    /// 代理服务器    
    /// 设置代理可用    
    /// 
    public static string SetIEProxy(string ProxyServer, int EnableProxy)   
       
  
    #endregion   
  
    #region 其他操作    
   
    ///     
    /// 测试代理配置    
    ///     
    /// 代理信息    
    /// 测试信息
    public static bool TestProxy(ProxySettingEntity setting, TestEntity te)    
   
    ///     
    /// 代理设置    
    ///     
    /// Web请求    
    /// 代理设置
    public static void SetProxySetting(WebRequest request, ProxySettingEntity Proxy)   
  
    #endregion    
}    
   
///     
/// 测试信息    
/// 
[Serializable]    
public class TestEntity    
{    
    ///     
    /// 测试网站地址    
    /// 
    public string TestUrl    
   
    ///     
    /// 测试网站Title    
    /// 
    public string TestWebTitle    
   
    ///     
    /// Web编码    
    /// 
    public string TestWebEncoding    
}    
   
///     
/// 代理设置    
/// 
[Serializable]    
public class ProxySettingEntity    
{    
    ///     
    /// 编号    
    /// 
    public int Id    
   
    ///     
    /// 代理服务器IP    
    /// 
    public string Ip    
   
    ///     
    /// 代理服务器端口    
    /// 
    public int Port    
   
    ///     
    /// 代理用户名    
    /// 
    public string UserName    
   
    ///     
    /// 代理密码    
    /// 
    public string Password    
   
    ///     
    /// 代理类型    
    /// 
    public int ProxyType    
}  

2)辅助类ProxyHelper的使用例子代码如下所示

CHM帮助文档持续更新中,统一下载地址是: http://www.iqidi.com/download/commonshelp.rar
公用类库DLL+XML注释文件下载地址是:http://files.cnblogs.com/wuhuacong/WHC.OrderWater.Commons.rar

你可能感兴趣的:(厚积薄发,丰富的公用类库积累,助你高效进行系统开发(12)--- 网络相关操作辅助类)