邮件操作:POP3协议

获取邮件正文的内容
获取邮件中的HTML页面
下面的函数假定已经将邮件的几个部分分开
 1private string GetText_Html(string PartSrc)
 2{
 3//获取传输编码
 4Regex TransferEncoding_Regex =
 5new Regex(@"Content-Transfer-Encoding: (.*?)\r\n", RegexOptions.IgnoreCase);
 6Match MacthTransfer = TransferEncoding_Regex.Match(PartSrc);
 7//截取出的内容文本
 8string ContentStr = "";
 9//用正则表达式截取内容部分
10//正则表达式声明中一定写上不区分大小写
11Regex HtmlContent_Regex =
12new Regex(@"<html([\s\S]*?)</html>", RegexOptions.IgnoreCase);
13Match MatchHtml = HtmlContent_Regex.Match(PartSrc);
14if (MatchHtml != null)
15{
16ContentStr = MatchHtml.Groups[1].Value;
17}

18//去除首尾的\r\n
19ContentStr = ContentStr.TrimStart(new char[] '\r''\n' });
20ContentStr = ContentStr.TrimEnd(new char[] '\r''\n' });
21
22//根据传输编码处理数据
23if (MacthTransfer.Groups[1].Value == "base64")
24{
25return Encoding.GetEncoding("GB2312").GetString(Convert.FromBase64String(ContentStr));
26}

27else//暂时将base64外的文本传输编码默认为打印机编码 quoted-printable
28{
29ArrayList CBuffer = new ArrayList();
30for (int i = 0; i < ContentStr.Length; i++)
31{
32if (ContentStr[i] == '=')
33{
34i++;
35if (ContentStr[i] != '\r')
36{
37byte vByte;
38if (byte.TryParse(ContentStr.Substring(i, 2),
39NumberStyles.HexNumber, nullout vByte))
40CBuffer.Add(vByte);
41}

42i++;
43}

44else if (ContentStr[i] != '\n') CBuffer.Add((byte)ContentStr[i]);
45}

46return Encoding.Default.GetString((byte[])CBuffer.ToArray(typeof(byte)));
47}

48}


转载于:https://www.cnblogs.com/lixx/archive/2008/05/20/1203560.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值