改 ‘干掉“W32.Sobig.F@mm”病毒’
发表于:2007-05-25来源:作者:点击数:
标签:
程序经常dump掉,找到原因了! 应该是eps的问题,用正常示例程序代码,显示一封邮件都会dump掉。 估计是邮件经过编译,eps的函数不能正确识别下一个字段的值或结束符之类的标志,导致程序dump掉。所以我的程序也会dump掉。没法! 所以呢,全改了,不用C,用s
程序经常dump掉,找到原因了!
应该是eps的问题,用正常示例程序代码,显示一封邮件都会dump掉。
估计是邮件经过编译,eps的函数不能正确识别下一个字段的值或结束符之类的标志,导致程序dump掉。所以我的程序也会dump掉。没法!
所以呢,全改了,不用C,用shell程序算了!
代码如下:
[code:1:24c0144129]
#!/bin/sh
T=/tmp/filtemail
grep -a -E "Subject|From" > $T.$$
len=`grep "From" $T.$$ | awk -F: '{print length($2)}'`
grep -E "Re: Details|Re: Movie|Re: Application|Your application|Your details|That movie|Thank you!|Re: Approved|Re: Wicked screensaver" $T.$$ > /dev/null 2>&1
vir=`echo $?`
if [ $len -eq 0 ]
then
rm -f $T.$$
return 99
fi
if [ $vir -eq 0 ]
then
rm -f $T.$$
return 99
fi
rm -f $T.$$
return 0
[/code:1:24c0144129]
用法参考之间的‘干掉“W32.Sobig.F@mm”病毒’贴子
http://www.chinaunix.net/forum/viewtopic.php?t=155729
重新编辑原因:
繁忙的
服务器会同时运行的多个此程序,却只使用同一个临时文件,这样,当第一封邮件是有病毒的,而第二封却没有,程序就会把前一个临时文件覆盖,当第一个程序开始调用临时文件时,检查的却是第二封邮件的临时文件,就会说邮件没问题,而放过那封有病毒邮件。
由 $T.1 改为 $T.$$ 就是用程序的进程号作为临时文件的文件名,避免此问题。
如还有错误的地方,请大家更正。
又改了两个位置:
当检查到病毒邮件后,立即执行了退出代码,而临时文件却没有删除,所以在退出代码前增加了删除临时文件的命令。
低级错误,该打!
artxing 回复于:2003-09-08 16:27:23
|
不错,如果我想使所有虚拟域中的用户都拒收含有W32.Sobig.F@mm”病毒’ 的邮件,该怎么做呢?[/i]
|
wienne 回复于:2003-09-09 08:53:58
|
那就把每个域的.qmail-defualt文件都改掉啊
|
artxing 回复于:2003-09-09 10:57:38
|
晕~~虚拟域有200多个
|
wienne 回复于:2003-09-09 11:14:07
|
编个脚本程序啊,很简单的
|
artxing 回复于:2003-09-09 11:32:23
|
呵~嗯,收到
|
garfy 回复于:2003-09-09 16:55:57
|
/tmp/fitermail有大量的信息,但是带毒邮件还是没过滤掉
|
原文转自:http://www.ltesting.net
|