Dovecot是一个开源的,为Linux/Unix-like系统提供IMAP,POP3服务的软件。Dovecot 是一个比较新的软件,由 Timo Sirainen 开发,最初发布于 2002年7月。作者将安全性考虑在第一,所以 Dovecot 在安全性方面比较出众。另外,Dovecot 支持多种认证方式,所以在功能方面也比较符合一般的应用。
下面我们来纪录记录一下它的安装:
这里我使用了CentOS系统自带的yum进行安装,安装非常简单,只需要一个包:dovecot
# yum install dovecot
就一切都搞定了
它的主要配置文件也只有一个,位于 /etc/dovecot.conf
base_dir = /var/run/dovecot/ # dovecot运行目录 protocols = pop3 pop3s # 使用协议 listen = * # 监听连接进来的ip地址,* => 所有的IPV4,[::] => 所有的IPV6 disable_plaintext_auth = no log_path = /var/log/dovecot.log #日志文件位置 info_log_path = /var/log/dovecot-info.log # debug信息 log_timestamp = “%Y-%m-%d %H:%M:%S ” ssl_disable = yes mail_location = maildir:/var/vmail/%u #用户的邮件目录位置,这里使用maildir方式存储 mail_privileged_group = mail protocol imap { } protocol pop3 { pop3_uidl_format = %08Xu%08Xv } protocol lda { postmaster_address = postmaster@example.com } auth_verbose = yes # 认证详细日志 auth_debug = yes # 认证的debug信息打开,可以显示出SQL查询语句,正常后可关闭 auth_debug_passwords = yes #可以显示密码失败的详细信息,正常后可关闭 auth default { mechanisms = plain login #认证机制 passdb pam { } passdb passwd-file { args = /etc/dovecot/passwd #密码文件 } userdb passwd { } userdb static { args = uid=vmail gid=vmail home=/var/vmail/%u #这里的uid和gid需要可以访问/home/vmail邮箱目录 } user = root socket listen { client { path = /var/spool/postfix/private/auth-client #postfix需要连接到这个sock进行认证 mode = 0660 user = postfix group = postfix } } } dict { } plugin { }
/etc/dovecot/passwd,可以使用明码或者是编码后的密码:
user1@example.com:{PLAIN}user1’s password user2@example.com:{PLAIN}user2’s password
这里使用了明文密码,也可以使用加密后的密码:
dovecotpw -s ssha Enter new password: foo Retype new password: foo {SSHA}dZ9TYI7DTM+J558QUBRAIMd/WCOoFGeU
在 /etc/dovecot/passwd
joe:{SSHA}dZ9TYI7DTM+J558QUBRAIMd/WCOoFGeU
以上介绍了帐号使用文件存储的方式,下面再介绍一下使用mysql数据库进行帐号存储,只需要修改auth default区块:
auth default { mechanisms = plain login passdb pam { } passdb sql { args = /etc/dovecot/dovecot-sql.conf } userdb passwd { } userdb sql { args = /etc/dovecot/dovecot-sql.conf } user = root socket listen { client { path = /var/spool/postfix/private/auth-client mode = 0660 user = postfix group = postfix } } }
/etc/dovecot/dovecot-sql.conf
driver = mysql connect = host=/tmp/mysql.sock dbname=postfix user=postfix password=mypassword default_pass_scheme = MD5-CRYPT # 如果使用postfixadmin管理,需要用这个加密方式 password_query = SELECT username as user, password from mailbox WHERE username = ‘%u’ user_query = SELECT maildir, 501 AS uid, 501 AS gid FROM mailbox WHERE username = ‘%u’ #这里uid和gid需要可以访问帐号邮件存储目录
就这么简单,配置完成了,下面我们来进行一下简单的测试:
helo mail.xxx.net 250 mail.xxx.net > auth login 334 VXNlcm5hbWU6 > dXNlcjFAZXhhbXBsZS5jb20= (Base64后的用户名:user1@example.com) 334 UGFzc3dvcmQ6 > Zm9vYmFy (Base64后的密码:foobar) 235 2.7.0 Authentication successful
用plain的方式认证
telnet localhost 25
220 mail.xxx.net ESMTP Postfix > auth plain 334 > AHVzZXIxQGV4YW1wbGUuY29tAGZvb2Jhcg== (Base64后的用户名和密码:\0user1@example.com\0foobar) 235 2.7.0 Authentication successful
使用plain方式认证需要注意,用户名和密码需要一起进行编码,用\0作为分隔符。
Base64的方式有很多,最后我们再介绍一个使用Ruby进行编码的方法:
inosin@mac:~ > ruby -rbase64 -e ‘puts Base64.encode64(“\0user1@example.com\0foobar”)’ AHVzZXIxQGV4YW1wbGUuY29tAGZvb2Jhcg== inosin@mac:~ > ruby -rbase64 -e ‘puts Base64.encode64(“user1@example.com”)’ dXNlcjFAZXhhbXBsZS5jb20= inosin@mac:~ > ruby -rbase64 -e ‘puts Base64.encode64(“foobar”)’ Zm9vYmFy
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
更新日志
2024年11月13日
2024年11月13日
- 魔兽世界wlk暗牧一键输出宏是什么 wlk暗牧一键输出宏介绍
- 群星.1996-红不让台语原唱2辑【福和唱片】【WAV+CUE】
- 郭书瑶.2009-爱的抱抱(EP)【种子音乐】【FLAC分轨】
- 郑瑞芬.1989-BE.MY.BABY【现代】【WAV+CUE】
- 花钱请人每周放30万只不咬人的蚊子 防治登革热传播
- 饭制《第一后裔》丧尸版弗蕾娜
- 贝克汉姆亲临!2024FC品类游戏嘉年华圆满落幕
- 「命轨爻错之翼」风之翼发放说明
- 《原神》前瞻特别节目回顾长图
- 米游币抽抽乐-原神专场现已开启!
- 黑鸭子2001《风情中国HQCD》[日本版][WAV+CUE]
- 陈杰洲1990-成人礼[滚石][WAV+CUE]
- MarkAanderud-HandsFree(2024)[24-44,1]FLAC
- 孙露《观心》1:1母盘直刻限量版[低速原抓WAV+CUE][361M]
- 钟志刚《汽车DJ玩主》[低速原抓WAV+CUE][1G]