ipointer

给我最爱的宝宝
随笔 - 56, 文章 - 0, 评论 - 251, 引用 - 1
数据加载中……

OutLook解析邮件头的问题

客户反映我们的邮件提醒中,显示的发送时间不对,而且相差的非常的大,如下图:
左下角是用DateTime.Now打出来的正确时间,而右上角是OutLook解析邮件头显示出来的时间。
看到这个问题,觉得相当的奇怪,因为邮件头里我也是用WriteString(ns, "Date: " + DateTime.Now);往流里面写的呀,怎么会出来这么一个奇怪的时间呢?
开始是怀疑客户那里的应用服务器的时间出了问题,可几经确认,发现确实不是这个问题。
难道是邮件头里还隐藏着什么时间吗,可拿OutLook正常收到的邮件头和我们自己发的多次比较也没有发现什么问题,这个问题真是太奇怪了。
转而求助Google,也没有发现相关的文章;求助微软的老马,他只是指点可能时区出了问题。反复检查服务器上的时区,也没有问题。
郁闷之时,用FoxMail收了一下我们发的邮件,竟然正常,开始怀疑是微软小小的bug。
但还是定位不出问题,情急之下,胡搞乱搞,改了一下系统日期,调成了2006年,发现那个错误的日期也变成了2006-1-3。再观察邮件头,发现Date字段也变成了2006,于是问题还是出在了这个Data字段上。
再仔细比较我们的邮件头和正常的邮件头,发现了一点区别:
正常的是:Date: Tue, 13 Mar 2007 23:09:10 +0800
我们的是:Date: 2007-3-13 23:08:22
hoho,原来是OutLook解释不了这样的时间格式呀,于是修改代码成:
WriteString(ns, "Date: " + DateTime.Now.ToString("r"));
问题搞定!
这个被客户骂死的小问题拖了一两个月(嘻嘻,因为觉得不是大问题,也确实不知道怎么弄),终于找到原因了,庆祝一下。

posted on 2007-03-13 23:33 栖息的熊 阅读(2313) 评论(8)  编辑 收藏 网摘

评论

#1楼    回复  引用    

写得很好,很有文采嘛,呵呵
2007-03-13 23:50 | MICKEY [未注册用户]

#2楼    回复  引用  查看    

Email的格式有RFC定义(好像是RFC2822),而其中date用什么格式肯定有说明,你应该是没看RFC就直接DateTime.Now.ToString()了吧?这就当作一个小教训啦,以后做这类工作记得一定要看清楚RFC再下手。

当然,写入时要遵守RFC,并不代表读取时仅仅看RFC。因为别人的程序可能不遵守RFC,例如你之前的程序因为不遵守RFC而Outlook又没有兼容设计就出问题了,所以读取时要做到最大兼容。
2007-03-14 00:04 | Cat Chen      

#3楼    回复  引用  查看    

这是你写程序不按照标准做的问题……
与outlook无关……

我拜托大家了……能不能合作配合一点去兼容一下标准?

我很怒……因为我的生命很大上就是浪费在解析、兼容网络上各种不按标准的东西……

比方说,Email的时间……比方说,RSS……比方说……网页……

2007-03-14 00:24 | 问天      

#4楼    回复  引用  查看    

windows live mail仿佛不能用pop3收信,我注册了自己的live domains,发现不能用windows live mail desktop来收信,郁闷啊
2007-03-14 08:26 | JesseZhao      

#5楼    回复  引用    

@JesseZhao
说反了,是你的live domains不支持通过客户端pop3收信。
2007-03-14 10:35 | 阿毅 [未注册用户]

#6楼    回复  引用    

向楼主学习
2007-03-14 12:17 | 传世私服 [未注册用户]

#7楼    回复  引用  查看    

@问天
同意!就拿RSS来说吧,明明也是有日期格式标准的,但是大家都不去遵守,不同网站发布的RSS日期格式完全不同,导致写Feed Reader的话就要自己想办法去兼容,因此我个人也是极之讨厌那些不按标准编写的程序。
2007-03-14 12:31 | Cat Chen      

#8楼    回复  引用    

谢谢各位大侠的指正,写程序的时候确实也是很少去研究一下规范和标准。
2007-03-15 15:17 | LEX [未注册用户]

标题  
姓名  
主页
Email (博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
Google站内搜索
[推荐职位]上海盛大网络招聘架构师



China-pub 计算机图书网上专卖店!6.5万品种 2-8折!
近千种 9-95 新二手计算图书火热销售中!
开发者征途系统新作:《设计模式——基于C#的工程化实现及扩展》

相关文章:

相关链接: