
1. 用以下命令查看系统是否安装了sendmail:
[root@mail /root]# rpm –qa |grep sendmail
sendmail-8.11.0-8
2. 卸载sendmail:
[root@mail /root]# rpm -e sendmail –nodeps
3. 用以下命令杀死运行中的sendmail进程:
[root@mail /root]# killall sendmail
如果系统提示:
sendmail: no process killed
则说明当前系统中没有sendmail进程。
4. 安装postfix:
[root@mail /root]# rpm -ivh postfix-20010228release-2.i386.rpm
若已经安装,则此步可以省略。(注:安装时最好用rpm包,会自动创建postfix用户和postfix组)
5. 安装imap
rpm –ivh /mnt/cdrom/RedHat/RPMS/ imap-4.7c2-12.rpm
imap使pop3有效,即打开110端口。(注:安装时最好用rpm包)
若已经安装,则此步可以省略。
6. 检查系统中是否安装了cyrus-sasl
执行以下命令查看系统中是否安装了cyrus-sasl:
rpm –qa |grep cyurs
如果您看到以下提示,则说明已经安装了cyrus-sasl
[root@test bye2000]# rpm -qa |grep sasl
cyrus-sasl-devel-1.5.24-17
cyrus-sasl-1.5.24-17
否则,请用rpm –ivh 命令先安装所需sasl-cyrus包。
7.修改postfix用户
同时应该让该用户不能登录到系统,也即不为该用户指定可执行的登录外壳程序和可用
的用户宿主目录。
编辑/etc/passwd文件中的相关条目如下所示:
postfix:x:89:89::/no/where:/no/shell [编辑后,只修改蓝色部分就可以了]
即:修改用户的Home directory和Shell 参照 /etc/passwd文件
8.编辑postfix的主要配置文件/etc/postfix/main.cf,根据需求只需修改以下几个参数:
1)mydomain
指明你的域名,在这里我们指定:
mydomain = xx.com
2)myorigin
myorigin参数指明发件人所在的域名。如果你的用户的邮件地址为user@domain.com,则该参数指定@后面的域名。在这里我们指定:
myorigin = $mydomain
3)inet_interfaces
inet_interfaces = all 监听所有端口
4)mydestination
mydestination参数指定postfix接收邮件时收件人的域名,换句话说,也就是你的postfix
系统要接收什么样的邮件。通常与myorigin一样:
mydestination = $mydomain
5)mynetworks_style
设置网络类型,我们指定:
mynetworks_style = subnet
6)ynetworks
定义可以使用的此smtp服务器发信的客户ip地址,因为公司的ip范围已知,所以我们
指定:
mynetworks = 192.168.1.0/24
注:此项可根据情况而定,主要是指定ip范围,假如公司的ip划分是按照网段来的,例如:10.10.1.0~10.10.1.9,10.10.3.0~10.10.3.9等等更细。根据需要,该项可以不设置。
7)SMTP的配置
为了告诉postfix采用sasl来进行SMTP的用户认证,我们必须在/etc/postfix/main.cf文件的最后添加以下几行:
smtpd_sasl_auth_enable = yes
smtpd_recipient_restrictions = permit_sasl_authenticated
permit_auth_destination reject
broken_sasl_auth_clients = yes
smtpd_sasl_security_options = noanonymous
说明如下:
smtpd_sasl_auth_enable:告诉SMTP客户,该SMTP服务器需要进行用户认证。
smtpd_recipient_restrictions = permit_sasl_authenticated
permit_auth_destination reject
仅仅中继通过SMTP认证的客户端邮件,以及接收本postfix为最后一站的邮件。
broken_sasl_auth_clients = yes
有一些Microsoft 的SMTP客户端,比如Outlook Express 4.X采用的是非标准的SMTP认证协议,将该选项设置为yes可以解决这类不兼容问题。
smtpd_sasl_security_options = noanonymous
控制本地SMTP认证所采用的机制,这里是允许任何非匿名认证方法。
9.配置SASL
进入/usr/lib/sasl/目录,用touch新建这样一个文件:
[root@test sasl]# touch smtpd.conf
在该文件中加入以下内容:
[root@test sasl]# more smtpd.conf
pwcheck_method:pam
也就是指定通过PAM来进行用户认证。
10.配置PAM
进入/etc/pam.d/目录,用touch新建这样一个文件:
[root@test pam.d]# touch smtp
在该文件中加入如下内容:
[root@test pam.d]# more smtp
#%PAM-1.0
auth required /lib/security/pam_stack.so service=system-auth
account required /lib/security/pam_stack.so service=system-auth
也即和/etc/pam.d/pop文件的内容是一致的。
11.修改/etc/shadow文件权限
因为PAM最终要去读取/etc/shadow文件的内容来进行用户认证,但是/etc/shadow文件
权限是设置为只有root用户可以读写,而我们的postfix是运行在postfix用户权限之下,所以我们要合理的设置/etc/shadow文件权限,以便让pam可以读取其内容。
执行以下命令,让root组也可以读取shadow:
[root@test /etc]# chmod 640 /etc/shadow
然后再将postfix用户加入root组,采用以下命令:
[root@test /etc]# usermod -G root postfix
12.编辑postfix的主要配置文件/etc/postfix/master.cf
# ==========================================================================
# service type private unpriv chroot wakeup maxproc command + args
# (yes) (yes) (yes) (never) (100)
# ==========================================================================
smtp inet n - n - - smtpd
这里开始
#smtps inet n - n - - smtpd
# -o smtpd_tls_wrappermode=yes -o smtpd_sasl_auth_enable=yes
#submission inet n - n - - smtpd
# -o smtpd_enforce_tls=yes -o smtpd_sasl_auth_enable=yes
这里结束
#628 inet n - n - - qmqpd
把我标的注释部分去掉即可。
13.配置pop3
RedHat7.0已经使用xinetd代替了以前的inetd,为了使pop3服务启动,我们编辑
/etc/xinetd.d/ipop3文件,将其中的disable = yes改为disable = no 以便启动pop3
服务。
为了使改动生效,执行以下命令:
/etc/rc.d/init.d/xinetd reload
14.启动postfix
执行以下命令启动postfix:
/etc/rc.d/init.d/postfix start
这样,一个支持SMTP认证的postfix邮件服务器就配好了。
Linux系统下常见的邮件客户端有Thunderbird, Evolution, KMail, Geary, Sylpheed, Claws Mail, Mailspring (之前的Nylas N1), Mutt等。出于个人喜好,每次都是无脑装Thunderbird。直到去年换了工作,新单位邮箱服务器是Exchange协议的,我就呵呵了。虽然Thunderbird可以装owl等插件,扩展对Exchange协议的支持,但使用一段时间提示license快到期 -_-# 。
最近换了Mailspring尝尝鲜,还是不支持Exchange协议,但可以开DavMail中转一把,估计后面还是会转回Thunderbird吧。
sudo apt-get install davmail
然后如下图简单的配置一下,填上单位的EWS邮箱服务器地址,这里注意POP或IMAP/SMTP的本地端口,后面要用到的哦。
后面就可以配置邮件客户端了,服务器填本地的127.0.0.1,POP/IMAP/SMTP的端口和DavMail中设置的保持一致。收完邮件收工。
Linux下的SMTP服务的配置,比较复杂一些,且各发行版本有些差异,以下是一个示例,供参考(建议使用第三个方法)
linux下smtp配置方法有几种,具体如下:
方法一,使用mail函数发送邮件;使用时时需要在本地系统上正确设置SMTP,否则将不能发送邮件。由于对系统的依赖性比较大,很多时候很不稳定,在一些提供虚拟主机服务的代理商中使用mail函数发送邮件往往很不好用,所以不推荐使用这种方法。
方法二,使用管道的形式发送邮件,主要是使用php中的popen函数。使用管道的方法发送邮件属于比较底层的 *** 作,它取决于用户调用程序的稳定性。所以相比mail函数,这是一种可选的发送邮件的方式,但是这些本地的邮件系统都太复杂了,用户可能不会配置。
方法三(推荐),使用phpmailer。phpmailer类是一个开源的发送邮件类,可以从http://phpmailer.sourceforge.net官网下载,它含两个文件class.smtp.php和class.phpmailer.php。代码如下
include_once("class.phpmailer.php")
/**
* 定义邮件模块配制信息
*/
define("SMTP_HOST","smtp.mail.yahoo.com") // SMTP 主机
define("SMTP_MAIL"," XXXX@yahoo.cn") // SMTP 用户email
define("SMTP_PASS"," XXXX") // SMTP 用的密码
define("SERVICE_MAIL"," XXXX@yahoo.cn")// SMTP 用户email
define("SERVICE_NAME","PHPBOOK邮件测试")// SMTP 用的名字
/**
* 使用phpmailer发邮件模块
*
* @param string $email
* @param string $user
* @param string $subject
* @param string $body
* @return bool
*/
function sendMail($email,$user,$subject,$body)
{
$mail = new PHPMailer()
//$this
$mail->IsSMTP() // 设置使用SMTP
$mail->Host = SMTP_HOST // 设置SMTP服务器地址
$mail->SMTPAuth = true// 打开SMTP权限验证
$mail->Username = SMTP_MAIL // SMTP 用户名
$mail->Password = SMTP_PASS// SMTP 服务器密码
$mail->From = SERVICE_MAIL // 设置发送者地址
$mail->FromName = SERVICE_NAME // 设置发送者名字
$mail->AddAddress($email, $user) // 添加接收者地址
$mail->AddReplyTo(SERVICE_MAIL, SERVICE_NAME)// 设置回复地址
$mail->WordWrap = 50 // 设置显示格式
$mail->IsHTML(true)// 设置邮件支持html
$mail->Subject = $subject
$mail->Body= $body
$mail->AltBody = "" // 文本类型的邮件
if(!$mail->Send())
{
return $mail->ErrorInfo
}
return true
}
//开始发送测试邮件ng: fsockopen() [function.fsockopen]: php_network_getaddresses: getaddrinfo failed: Name or service not known in /var/www/xiehui/admin/mail/class.smtp.php on line 89
$tomail = " XXXX@126.com"
$user = " XXXXlinux"
$_mailSubject = "邮件测试示例!"// 发给用户的邮件标题小组
$_mailBody = "新浪网"// 邮件内容小组
sendMail($tomail,$user,$_mailSubject,$_mailBody)
?>
实验证明yahoo的smtp很好用,号称sina的其实并不好用,我卡在着好长时间。
方法四,给予socket编写的程序,源代码如下
使用socket发送邮件的封装类:
class sendmail{
var $lastmessage//记录最后返回的响应信息
var $lastact//最后的动作,字符串形式
var $welcome//用在HELO后面,欢迎用户
var $debug//是否显示调试信息
var $smtp//smtp服务器
var $port//smtp端口号
var $fp//socket句柄
//发送邮件函数
function send_mail($smtp, $welcome="", $debug=false) {
if(empty($smtp)) die("SMTP不能为空!")
$this->smtp=$smtp
if(empty($welcome)) {
$this->welcome=gethostbyaddr("localhost")
}else
$this->welcome=$welcome
$this->debug=$debug
$this->lastmessage=""
$this->lastact=""
$this->port="25"
}
//显示调试信息
function show_debug($message, $inout) {
if ($this->debug) {
if($inout=="in"){ //响应信息
$m='<<'
}else
$m='>>'
if(!ereg("\n$", $message))
$message .= "
"
$message=nl2br($message)
echo "${m}${message}"
}
}
//执行传递的命令
function do_command($command, $code) {
$this->lastact=$command
$this->show_debug($this->lastact, "out")
fputs ( $this->fp, $this->lastact )
$this->lastmessage = fgets ( $this->fp, 512 )
$this->show_debug($this->lastmessage, "in")
if(!ereg("^$code", $this->lastmessage))
return false
else
return true
}
//邮件发送处理
function send( $to,$from,$subject,$message) {
//连接服务器
$this->lastact="connect"
$this->show_debug("连接到SMTP 服务器: ".$this->smtp, "out")
$this->fp = fsockopen ( $this->smtp, $this->port )
if ( $this->fp ) {
$this->set_socket_blocking( $this->fp, true )
$this->lastmessage=fgets($this->fp,512)
$this->show_debug($this->lastmessage, "in")
if (! ereg ( "^220", $this->lastmessage ) ) {
return false
}else{
$this->lastact="HELO " . $this->welcome . "\n"
if(!$this->do_command($this->lastact, "250")){
fclose($this->fp)
return false
}
$this->lastact="MAIL FROM: $from" . "\n"
if(!$this->do_command($this->lastact, "250")){
fclose($this->fp)
return false
}
$this->lastact="RCPT TO: $to" . "\n"
if(!$this->do_command($this->lastact, "250")){
fclose($this->fp)
return false
}
//开始发送邮件正文
$this->lastact="DATA\n"
if(!$this->do_command($this->lastact, "354")){
fclose($this->fp)
return false
}
//开始处理邮件主题头
$head="Subject: $subject\n"
if(!empty($subject) &&!ereg($head, $message)){
$message = $head.$message
}
//开始处理邮件From头
$head="From: $from\n"
if(!empty($from) &&!ereg($head, $message)) {
$message = $head.$message
}
//开始处理邮件To头
$head="To: $to\n"
if(!empty($to) &&!ereg($head, $message)) {
$message = $head.$message
}
//处理结束串
if(!ereg("\n\.\n", $message))
$message .= "\n.\n"
$this->show_debug($message, "out")
fputs($this->fp, $message)
$this->lastact="QUIT\n"
if(!$this->do_command($this->lastact, "250")){
fclose($this->fp)
return false
}
}
return true
}else{
$this->show_debug("连接失败!!", "in")
return false
}
}
}
?>
使用socket发送邮件示例:
include ("./sendmail.class.php")
$mail = new sendmail()
$email = "您好,这是一个测试邮件!"
$sendmail = new send_mail("smtp.mail.126.com","PHPBOOK",true)//显示调示信息
if($mail->send("XXXX@126.com", "XXXX@126.com", "测试SOCKET邮件", $email)) {
echo "发送成功!
"
}else{
echo "发送失败!
"
}
?>
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)