zoukankan      html  css  js  c++  java
  • 郁闷的OpenPOP的MIME Parser

    看样子,大家很少使用OpenPOP……所以,对关于OpenPOP/OpenSMTP/Mail.Net的一些东西…… 都没有啥反应……

    不过,我很想知道开发OpenPOP的灵感之源是没有看到这些讯息还是怎么回事呢?

    Well……偶又来说OpenPOP了……不过,只是要说其附带的MIME Parser而已……将email从RFC 822格式转换为Object的类……

    被它搞得真是很郁闷……

    它Parse的时候,很多地方都使用了Encoding.Default,不管email的具体编码是什么,全部都使用当前系统的编码去parse……

    因为,这个Parse在很多情况下都可以正确解码,并且源代码中有注释说明:
    <param name="encode">encoding method, "Default" is suggested</param>

    推荐使用系统默认编码……偶实在不明白其中奥妙……

    看其Parse Email Header部分的代码……似乎……也是有一个小bug……
    有时候时候charset的信息都是紧跟在content-type后面的……这样的情况,Parser可以正确获得Email的编码……

    但是,有的时候charset还是在content-type后面,但是,会换行,并且加一个tag,如:
    Content-Type: text/html;
     charset="us-ascii"

    这样的情况,Parser貌似就把charset给忽略掉了……

    或者,这就是Parse UTF-8编码的中文信件出错的原因……

    但是,还有另一个很严重的问题:解Quoted-Printable的函数有错……

    DecodeQP.cs中138行有这样的内容及注释:
    if(isBegin&& (count % 2==0)) //wait until even items to handle all character sets

    但,如果是UTF-8编码,每个字符都是三个字节……貌似,应该改为:
    if(isBegin&& (count % 3==0)) //wait until even items to handle all character sets including utf-8

    否则,会缺字。

    唉……郁闷的OpenPOP的MIME Parser……
  • 相关阅读:
    函数指针与函数声明
    long和int的区别
    pthread_create传递参数
    C语言中的static 详细分析
    linux 读写锁应用实例
    linux使用读写锁pthread_rwlock_t
    linux的<pthread.h>
    时间:UTC时间、GMT时间、本地时间、Unix时间戳
    等号赋值与memcpy的效率问题
    单链表带头结点&不带头结点
  • 原文地址:https://www.cnblogs.com/wuvist/p/292611.html
Copyright © 2011-2022 走看看