zoukankan      html  css  js  c++  java
  • 解析eml文件

    之前使用lumisoft解析eml,总是会出现很奇怪的问题,所以改使用微软自家的com库,确实厉害兼容性更好,代码

                string file = emailPath;
                    CDO.Message oMsg = new CDO.Message();
                    ADODB.Stream stm = null;
                    //读取EML文件到CDO.MESSAGE,做分析的话,实际是用了下面的部分
    
                    try
                    {
                        stm = new ADODB.Stream();
                        stm.Open(System.Reflection.Missing.Value,
                        ADODB.ConnectModeEnum.adModeUnknown,
                        ADODB.StreamOpenOptionsEnum.adOpenStreamUnspecified,
                        "", "");
                        stm.Type = ADODB.StreamTypeEnum.adTypeBinary;//二进制方式读入
    
                        stm.LoadFromFile(file); //将EML读入数据流
    
                        oMsg.DataSource.OpenObject(stm, "_stream"); //将EML数据流载入到CDO.Message,要做解析的话,后面就可以了。
                        CDO.IBodyParts ip = oMsg.Attachments;
                        int count = oMsg.Attachments.Count;
                        if (count != 0)
                        {
                            for (int i = 1; i <= count; i++)
                            {
    
                                ////获取到附件的文件名称+后缀
                                object FileName = oMsg.Attachments[i].FileName;
                                //object fileContext=oMsg.Attachments[i].GetStream();
                                //内容
                                oMsg.Attachments[i].SaveToFile(@"C:" + FileName);
                                //ip.GetEnumerator().Current;
                            }
                            MessageBox.Show("下载完成,保存到:C:\根目录");
                        }
                        else
                        {
                            MessageBox.Show("没有附件");
                        }
    
    
                    }
                    catch (IOException ex)
                    {
    
                    }
                    finally
                    {
                        stm.Close();
                     }

    上面是解析附件的一段代码,正文、主题等更简单了

  • 相关阅读:
    constraint更新表列约束默认值
    sql语句 关于日期时间、类型转换的东西
    SQL数据库完全复制
    SQLServer语句 汇总
    SQL Server Profiler使用方法
    SQL语句-批量插入表(表数据插表)
    VS 快捷键
    外部引用 jQuery 库
    mongodb笔记
    Ubuntu16.04安装live-server
  • 原文地址:https://www.cnblogs.com/rainbowzc/p/3285944.html
Copyright © 2011-2022 走看看