linux安装mailx发邮件
文章目录
- linux安装mailx发邮件
-
- 原理
- 安装
- 配置qq的smtps服务器
- 配置Peer的证书发布者为信任
mailx
是mailx
命令的功能,并支持 MIME、IMAP、POP3、SMTP 和 S/MIME 扩展。mailx 在某些交互特性上更加强大,如缓冲邮件消息、垃圾邮件评分和过滤等。在 Linux 发行版上,mailx
命令的软链接。可以运行下面的命令从官方发行版仓库安装 这里是:使用外部 smtp 服务器(qq邮箱)发送邮件。
mail是mailx的别名,mail是MUA,sendmail是MTA
如果我们只是想要发送邮件 只需要mail 或者mailx 就可以了,如果我们需要发送邮件并且能收到对方的邮件 我们可能就需要sendmail 服务了。
原理
- MUA:Mail User Agent,邮件用户代理,用来编写,收发邮件
- MTA:Mail Transfer Agent,邮件传输代理,将邮件传输到正确目的地
- MDA:Mail Delivery Agent,邮件分发代理,将邮件分发到正确目的用户
以一个例子来说明上面的关系。假如A用户使用的是QQ邮箱,B用户使用的是163邮箱,A要向B发送一封邮件。流程如下: 1、A用户通过MUA编写好邮件,并发送 2、该邮件通过MTA,首先发送到QQ邮件服务器 3、QQ邮件服务器分析到目的邮箱地址是163,所以再通过MTA传送到163邮件服务器 4、163邮件服务器收到该邮件 5、由于使用163邮箱的用户有很多,再通过MDA把该邮件发送到正确的用户 6、B用户通过MUA就可以查看A用户发送的邮件。
安装
对于 Debian/Ubuntu 系统
代码语言:javascript复制apt-get install mailutils
对于 RHEL/CentOS 系统
代码语言:javascript复制yum install mailx
对于 Fedora 系统
代码语言:javascript复制dnf install mailx
配置qq的smtps服务器
代码语言:javascript复制vi /etc/mail.rc
代码语言:javascript复制# 在最后一行写入下面信息
# 这里填入smtp地址,这里的xxx为qq或者163
set smtp=smtps://smtp.qq.com:465
# 认证方式
set smtp-auth=login
# 这里输入邮箱账号
set smtp-auth-user=jenrey@foxmail.com
# 这里填入密码,这里是授权码而不是邮箱密码
set smtp-auth-password=xxxxxxxxxxxxxxx
# 忽略证书警告
set ssl-verify=ignore
# 证书所在目录
set nss-config-dir=/etc/pki/nssdb
# 设置发信人邮箱和昵称
set from=jenrey@foxmail.com
代码语言:javascript复制 QQ邮箱的授权码获取方式为:进入邮箱后–>设置–>账户,开启下图1中的SMTP,点击2生成授权码
echo '邮件内容'| mail -s '邮件标题' jenrey@foxmail.com
echo '123'| mail -s 'qwe' jenrey@foxmail.com
配置Peer的证书发布者为信任
代码语言:javascript复制Error in certificate: Peer’s certificate issuer has been marked as not trust 报错的意思是 证书错误:Peer的证书发布者被标记为不被信任。 这是由于使用加密通信,但客户端不能确认证书是否真实。 但是邮件可以正常发送。
[root@765850a4dacb /]# echo '123'| mail -s 'qwe' jenrey@foxmail.com
[root@765850a4dacb /]# Error in certificate: Peer's certificate issuer has been marked as not trusted by the.
解决方法如下:
代码语言:javascript复制# 修改配置(/etc/mail.rc)
将 set ssl-verify=ignore 改成 set ssl-verify=strict
# 获取邮件服务器证书
echo -n "" | openssl s_client -connect smtp.qq.com:465 | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p' > /etc/pki/nssdb/qq.crt
# 如果提示openssl: command not found,执行下面命令并再次“获取邮件服务器证书”
yum install openssl
# 将证书添加到受信任列表
certutil -A -n 'qq' -t "P,P,P" -d /etc/pki/nssdb -i /etc/pki/nssdb/qq.crt
# -A:表示添加
# -n:nickname,可以随意取,例如126或qq
# -t:表示受信任的标签,可取值是t/c/p三种或者其组合,
# -d:表示证书所在目录
# -i:指示证书文件的位置。
# 其它参数可以 man certutil 查看
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/179873.html原文链接:https://javaforall.cn