首页 | 邮件资讯 | 技术教程 | 解决方案 | 产品评测 | 邮件人才 | 邮件博客 | 邮件系统论坛 | 软件下载 | 邮件周刊 | 热点专题 | 工具
网络技术 | 操作系统 | 邮件系统 | 客户端 | 电子邮箱 | 反垃圾邮件 | 邮件安全 | 邮件营销 | 移动电邮 | 邮件软件下载 | 电子书下载

邮件服务器

技术前沿 | Qmail | IMail | MDaemon | Exchange | Domino | 其它 | Foxmail | James | Kerio | JavaMail | WinMail | Sendmail | Postfix | Winwebmail | Merak | CMailServer | 邮件与开发 | 金笛 |
首页 > 邮件服务器 > Sendmail > 基于Sendmail和Perl的邮件附件过滤系统 > 正文

基于Sendmail和Perl的邮件附件过滤系统

出处:http://www.linuxforum.net 作者: 吴阿亭 时间:2004-10-26 14:08:00
一 前言:
   随着email在企业里广泛使用,它已经成为传播病毒的最主要的手段,保护企业
   用户免受可能带病毒的邮件附件的感染,尤其是可执行文件的邮件附件,我们
   需要过滤那些可能带有病毒的附件的邮件,当前主要的做法是在Sendmail把
   邮件送到用户信箱前由Procmail进行过滤,但是更好的方法是在SMTP传送期间
   由Sendmail本身进行过滤,本文就是重点在于讲述如何使用Sendmail在SMTP
   传输期间进行过滤。

二 基于Sendmail的过滤器的优点
   较之于传统的Procmail的邮件过滤器,基于Sendmail的有如下优点:

   1) 对每封邮件过滤一次,而不是对每个接收者过滤一次(传统的基于Procmail的做法)。
   2) 如果安装在企业的主邮件服务器上,可以在第一道入口拒绝进来的带有可执行附件的邮件。
   3) 可以利用internet上有经验的程序员写的过滤程序,而不是自己写的Procmail过滤程序。
   4) 可以防止企业内部用户发出可执行的附件的邮件给外部用户,成为好的internet公民。

三 所需软件
   我们选用开放源的基于Sendmail和Perl语言的MIMEDefang 过滤系统,它利用
   最新版本Sendmail提供的mail filter API且使用Perl语言写的程序和过滤规则。
   其主页在:
   http://www.roaringpenguin.com/mimedefang/

四 步骤
   a. 下载所需的相关软件

      一台正在工作的Linux服务器 (这里我用的是Redhat 7.2)
      Perl 5.001或者更高 (Redhat 7.2已经带有)
      四个所需的Perl附加模块
        MIME-tools-5.410.tar.gz 
        IO-stringy-1.212.tar.gz 
        MIME-Base64-2.11.tar.gz 
        MailTools-1.1401.tar.gz 
      Sendmail 8.12.1  
      MIMEDefang 2.1 
    
   b. 编译并安装四个Perl模块
        直接进入每个目录运行 perl Makefile.PL;make;make test;make install 即可。
        cd /root
        for i in ./*;do tar xvfz $i;done
        cd 每个相应的模块目录
        perl Makefile.PL
        make
        make test  (确保你测试成功)
        make install
  
   c. 编译Sendmail加入MILTER支持
        放下面的行在 devtools/Site/site.config.m4 (用VI创建该文件)
           APPENDDEF(`conf_sendmail_ENVDEF',`-DMILTER')  
        确保编译过程中看到Sendmail带参数 -DMILTER 进行编译。
        
        新的Sendmail版本加强了安全性,不再运行以suid,需要设置用户名和组名smmsp, 
        在/etc/passwd中加入下面的行:
        smmsp:x:25:25:Sendmail:/:
        在/etc/group中加入下面的行:
        smmsp:x:25:

        cd /root/sendmail-8.12.1
        cd sendmail
        sh Build 
        cd ../cf/cf
        cp generic-linux.mc sendmail.mc
        vi sendmail.mc (且放下面的行到该文件中)

 define(`confPRIVACY_FLAGS', `authwarnings,needmailhelo,novrfy,noexpn,restrictqrun')dnl
 INPUT_MAIL_FILTER(`mimedefang', `S=unix:/var/run/mimedefang.sock, F=T, T=S:60s;R:60s;E:5m')
 FEATURE(`smrsh',`/usr/sbin/smrsh')dnl
 FEATURE(`mailertable',`hash -o /etc/mail/mailertable.db')dnl
 FEATURE(`virtusertable',`hash -o /etc/mail/virtusertable.db')dnl
 FEATURE(`access_db')dnl
 FEATURE(redirect)dnl
 FEATURE(always_add_domain)dnl
 FEATURE(use_cw_file)dnl

 FEATURE(use_ct_file)dnl
 FEATURE(local_procmail,`',`procmail -t -Y -a $h -d $u')dnl
 MAILER(smtp)dnl
 MAILER(procmail)dnl
 Cwlocalhost.localdomain

其中 INPUT_MAIL_FILTER行是MIMEDefang所必需的。
       
        sh Build sendmail.cf
        sh Build install-cf
        cd ../..
        cd sendmail
        sh Build install
        cd ../libmilter 

        sh Build install  (创建libmilter库文件供MIMEDefang使用)

        对其它的各种应用程序目录,同样用sh Build install安装。

   d. 编译MIMEDefang
        cd sendmail-8.12.1
        mkdir -p /usr/local/include/sendmail
        cp -R include/* /usr/local/include/sendmail
        cp -R sendmail/*.h /usr/local/include/sendmail
        mkdir -p /usr/local/lib
        cp obj.Linux.2.4.9-7smp.i686/*/*.a /usr/local/lib
        注:用你的obj.Linux.xxxxx平台的文件代替上面的obj.Linux.2.4.9-7smp.i686
  
        cd mimedefang-2.1
        ./configure
        make
        make install
 
    e. 设置过滤器规则
        在mimedefang-2.1/example下面有各种预定义的规则,你需要拷贝一个到
 /etc/mimedefang-filter
        下面是我用的规则。

 我拷贝了suggested-minimum-filter-for-windows-clients到/etc/mail下且改成下面的

$Administrator = 'itsecurity@yourdomain.com';
$DaemonAddress = 'itsecurity@yourdomain.com';
$Stupidity{"flatten"} = 0;
$Stupidity{"NoMultipleInlines"} = 0;
sub filter_begin {
}
sub filter {
    my($entity, $fname, $ext, $type) = @_;
    if (re_match_ext($entity, '^\.(exe|com|bat|vbs|scr|shs|dll|vxd|pif|reg|ocx)$')) {
action_discard();
action_notify_sender("Your message with attachment '$fname' had been deleted by our mail server because of security issue\n");

return action_quarantine($entity, "The message with attchment '$fname' was deleted by mail server.");
   }
return action_accept();
}
1;

 上面的过滤规则表示删除带上面所列出的扩展名的邮件且通知发送者邮件被删除,
 接收其它所有的邮件。我也更改/usr/local/bin/mimedefang.pl文件以致不要
 保留邮件附件在/var/spool/MIMEDefang目录中,该文件有详细的自我解释,
 请编辑该文件去掉保留一份被删除邮件附件在硬盘上的部分。

     f.  启动系统并测试

 简单地拷贝example目录下的为redhat而写的redhat-sendmail-init-script到
 /etc/rc.d/init.d/sendmail并且更改Sendmail启动部分为

/usr/sbin/sendmail -L sm-mta -bd -q30m
/usr/sbin/sendmail -L sm-msp-queue -Ac -q30m

如果你的邮件服务器每天需要处理成千上万的邮件,则考虑拷贝另一个脚本
redhat-sendmail-init-script-with-multiplexor到/etc/rc.d/init.d/sendmail,
加快处理速度。


最后用/etc/rc.d/init.d/sendmail start启动sendmail,发送带.exe的附件进行测试。

,
相关文章 热门文章
  • sendmail中.forward文件的注意事项
  • Linux启动 Sendmail速度慢的解决办法
  • RHEL5.2 sendmail和openwebmail 、dpvecpt 配置总结
  • PEAR Mail软件包Sendmail Mail::Send()方式参数注入漏洞
  • Linux启动sendmail速度慢的解决办法
  • 为Sendmail添加邮件认证功能
  • FYI:商用Sendmail的安全和隔离要点
  • 在Perl和Sendmail的附件做过滤系统
  • sendmail做smtp SERVER
  • Sendmail Analyzer 5.3 发布
  • 如何限制Sendmail下邮件的大小
  • Fedora架设Sendmail邮件服务器
  • Sendmail8.12.9+RedHat 8.0建构邮件服务器
  • sendmail大全
  • Sendmail邮件服务器快速指南
  • SendMail上手指南
  • 用Sendmail配置你的第一台e-mail服务器
  • RedHatLinux AS3中SendMail的配置
  • 企业Sendmail邮件服务器的创建
  • Sendmail环境下对抗垃圾邮件的处理方法
  • Sendmail的邮件用户与系统用户分离
  • 我的qmail安装历程
  • 带SMTP认证功能的sendmail配置
  • Sendmail的relay用法汇总
  • 自由广告区
     
    最新软件下载
  • SharePoint Server 2010 部署文档
  • Exchange 2010 RTM升级至SP1 教程
  • Exchange 2010 OWA下RBAC实现的组功能...
  • Lync Server 2010 Standard Edition 标..
  • Lync Server 2010 Enterprise Edition...
  • Forefront Endpoint Protection 2010 ...
  • Lync Server 2010 Edge 服务器部署文档
  • 《Exchange 2003专家指南》
  • Mastering Hyper-V Deployment
  • Windows Server 2008 R2 Hyper-V
  • Microsoft Lync Server 2010 Unleashed
  • Windows Server 2008 R2 Unleashed
  • 今日邮件技术文章
  • 腾讯,在创新中演绎互联网“进化论”
  • 华科人 张小龙 (中国第二代程序员 QQ...
  • 微软推出新功能 提高Hotmail密码安全性
  • 快压技巧分享:秒传邮件超大附件
  • 不容忽视的邮件营销数据分析过程中的算..
  • 国内手机邮箱的现状与未来发展——访尚..
  • 易观数据:2011Q2中国手机邮箱市场收入..
  • 穿越时空的爱恋 QQ邮箱音视频及贺卡邮件
  • Hotmail新功能:“我的朋友可能被黑了”
  • 入侵邻居网络发骚扰邮件 美国男子被重..
  • 网易邮箱莫子睿:《非你莫属》招聘多过..
  • 中国电信推广189邮箱绿色账单
  • 最新专题
  • 鸟哥的Linux私房菜之Mail服务器
  • Exchange Server 2010技术专题
  • Windows 7 技术专题
  • Sendmail 邮件系统配置
  • 组建Exchange 2003邮件系统
  • Windows Server 2008 专题
  • ORF 反垃圾邮件系统
  • Exchange Server 2007 专题
  • ISA Server 2006 教程专题
  • Windows Vista 技术专题
  • “黑莓”(BlackBerry)专题
  • Apache James 专题
  • 分类导航
    邮件新闻资讯:
    IT业界 | 邮件服务器 | 邮件趣闻 | 移动电邮
    电子邮箱 | 反垃圾邮件|邮件客户端|网络安全
    行业数据 | 邮件人物 | 网站公告 | 行业法规
    网络技术:
    邮件原理 | 网络协议 | 网络管理 | 传输介质
    线路接入 | 路由接口 | 邮件存储 | 华为3Com
    CISCO技术 | 网络与服务器硬件
    操作系统:
    Windows 9X | Linux&Uinx | Windows NT
    Windows Vista | FreeBSD | 其它操作系统
    邮件服务器:
    程序与开发 | Exchange | Qmail | Postfix
    Sendmail | MDaemon | Domino | Foxmail
    KerioMail | JavaMail | Winwebmail |James
    Merak&VisNetic | CMailServer | WinMail
    金笛邮件系统 | 其它 |
    反垃圾邮件:
    综述| 客户端反垃圾邮件|服务器端反垃圾邮件
    邮件客户端软件:
    Outlook | Foxmail | DreamMail| KooMail
    The bat | 雷鸟 | Eudora |Becky! |Pegasus
    IncrediMail |其它
    电子邮箱: 个人邮箱 | 企业邮箱 |Gmail
    移动电子邮件:服务器 | 客户端 | 技术前沿
    邮件网络安全:
    软件漏洞 | 安全知识 | 病毒公告 |防火墙
    攻防技术 | 病毒查杀| ISA | 数字签名
    邮件营销:
    Email营销 | 网络营销 | 营销技巧 |营销案例
    邮件人才:招聘 | 职场 | 培训 | 指南 | 职场
    解决方案:
    邮件系统|反垃圾邮件 |安全 |移动电邮 |招标
    产品评测:
    邮件系统 |反垃圾邮件 |邮箱 |安全 |客户端
    广告联系 | 合作联系 | 关于我们 | 联系我们 | 繁體中文
    版权所有:邮件技术资讯网©2003-2010 www.5dmail.net, All Rights Reserved
    www.5Dmail.net Web Team   粤ICP备05009143号