分享
 
 
 

Sendmail升级速成

王朝other·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

Sendmail作为邮件服务软件,一直以来,始终为各IT行业厂家的邮件服务器广泛使用,但由于Sendmail在设计当初,只考虑为用户提供邮件发送和接收等服务,并未对网络安全作过多考虑,因此这就为日后的网络黑客提供了攻击他人邮件服务器的可乘之机,即我们通常所说的"邮件转发"。

邮件黑客正是利用了Sendmail的这一漏洞,利用某些服务器的SMTP不设防的缺陷,将自己的私人邮件通过他人的邮件服务器发向目的地,以满足一己私欲;更有甚者,利用他人邮件服务器,肆意的向外界的任意地址发送"垃圾邮件",这样做,不仅给他人的网络维护造成巨大损失,同时也给接收方带来的诸多不便。

由于Sendmail自始至终一直作为邮件服务器的标准后台进程,并为广大服务器生产厂家所采纳,因此现阶段,想通过其它软件替代Sendmail做为邮件服务,似乎有远水难解近渴之感;当务之急,只有通过升级Sendmail来达到防止"邮件转发"的目的。

鉴于篇幅有限,现只对Sendmail的实现做具体说明,有关Sendmail的详细原理,请读者查询相关文档。

一. Sendmail的获取

在一般情况下,将sendmail升级到sendmail.8.9.3即可达防止邮件服务器转发的功能。

TIPS:可到以下WWW或FTP站点下在最新的sendmail版本:

http://www.sendmail.org

ftp://ftp.ncic.ac.cn

ftp://ftp.pku.ac.cn

ftp://ftp.tsinghua.edu.cn

sendmail的源代码文件为:sendmail..8.9.3.tar.gz

在获得sendmail.8.9.3.tar.gz后,可通过gunzip和tar命令将此文件解包。

二. Sendmail的生成

这是sendmail升级过程中较为重要的一步,它将生成sendmail可执行文件。

1. 进入当前目录下的/src目录,编辑文件Makefile.m4

将:MAPDEF= ifdef(`confMAPDEF', `confMAPDEF')

改为:MAPDEF= ifdef(`confMAPDEF', `confMAPDEF',`NDBM')

2. 在/src目录下,运行./Build进行编译。

TIPS:在编译过程中,可能会出现:sh groff not found 的提示信息。

可将Makefile.m4文件中有关groff的行注释掉即可:

#NROFF= ifdef(`confNROFF', `confNROFF', `groff -Tascii')

若想将编译结果直接安装到缺省目录下,可通过:

./Build install 来实现。

若出现gcc not found 或cc not found,可在/usr/bin下做如下软连接:

ln -s /usr/bin/gcc gcc的实际位置,或 ln -s /usr/bin/cc cc的实际位置。

如果还出现上述信息,则需要你重新安装gcc或cc编译器。

三. 生成配置文件sendmail.cf

1. 进入sendmail-8.9.3目录下的cf/cf目录,编辑tcpproto.mc文件:

将源代码:

divert(0)dnl

VERSIONID(`@tcpproto.mc 8.10 (Berkeley) 5/19/1998')

OSTYPE(*Your Os Type)

DOMAIN(*Your Domain Name)

FEATURE(access_db,dbm -o /etc/mail/access)

FEATURE(blacklist_recipients)

FEATURE(nouucp)

MAILER(local)

MAILER(smtp)

TIPS:在*Your Os Type一项中填写"你的系统类型"(例如:solaris2),该型文件可在sendmail-8.9.3目录下的/cf/ostype目录下查到。

在*Your Domain Name一项中填写你的域名,并用单引号括起(例如:'cstnet.net.cn')

这其中FEATURE(blacklist_recipients),也可省略。

2. 进入sendmail-8.9.3目录下的cf/domain目录,将文件"generic.m4"更名为"你的域名.m4"(例如:cstnet.net.cn.m4)。

3. 用m4编译生成sendmail.cf文件。在sendmail-8.9.3/cf/cf目录下执行: m4 ../m4/cf.m4 tcpproto.mcsendmail.cf 在m4编译过程中不应该出现任何错误提示。

四. 重新启动sendmail 在重新启动sendmail之前,需要做一些配置工作:

1. 检查在/etc目录下是否存在sendmail.cw和aliases文件,若没有,需要建立此二文件:touch /etc/sendmail.cw /etc/aliases

2. 检查是否存在/etc/mail目录,若没有,则建立此目录并在该目录下建立文本文件access,此文件非常重要,它是用来控制可用此邮件服务器发送邮件的IP地址。此文件将在后面做具体说明.

3. 在sendmail-8.9.3/makemap目录下,运行./Build,此时在当前目录下会生成一个obj.xxx目录,在此目录下,已经生成了makemap可执行文件。

TIPS:此时,可在/usr/bin下做makemap的软连接,以备将来使用: Ln -s /usr/bin/makemap makemap的实际位置

4. 下面,我们对access文件的格式加以说明: 左边 右边 解释说明

左边 右边 解释说明

159.226.8.5 RELAY RELAY必须大写,表示允许159.226.8.5主机通过此邮件服务器发送和接收邮件,其余IP格式相同。

159.226.8 RELAY RELAY必须大写,表示允许159.226.8这一个C通过此邮件服务器发送和接收邮件,其余网段格式相同。

*aaa@cstnet.net.cn OK或RELAY OK或RELAY必须大写,表示允许aaa@cstnet.net.cn这个邮箱可通过此邮件服务器发送和接收邮件。

*@cstnet.net.cn OK或RELAY OK或RELAY必须大写,表示允许域名 为cstnet.net.cn邮箱通过此邮件服务器发送和接收邮件。

注释:带*号的格式在实际升级过程中往往不成立,一般情况下请读者不要使用。

TIPS:在m4编译工程中,有可能出现:m4 not found的提示信息,此时之需要输入m4的完整路径(例如:/usr/bin/m4 ../m4/cf.m4 tcpproto.mcsendmail.cf)即可。

如果还未找到m4,那就需要你重新安装m4编译器了。

这时,可将生成的sendmail.cf文件拷贝到/etc目录下,以备日后使用。

5. 接下来需要用makemap(上文中已提到)将文本文件/etc/mail/access生成库文件:

makemap dbm /etc/mail/access

运行后,将在/etc/mail/目录下生成access.dir和access.pag两个库文件。

6. 最后启动Sendmail

执行:/usr/lib/sendmail -bd -q15m

如果sendmail在缺省目录下,可直接执行:sendmail -bd -q15m

如果sendmail.cf不再缺省目录下,则执行:/usr/lib/sendmail -bd -q15m -C"sendmail.cf的实际位置"。

五. 升级维护

当你需要添加/删除某些用户,允许/禁止他们通过本邮件服务器转发邮件时,只需按照以上格式修改/etc/mail/access文本文件,并执行:

makemap -dbm /etc/mail/access

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有