大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。
Jetbrains全系列IDE稳定放心使用
linux安装mailx发邮件
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 系统
apt-get install mailutils
对于 RHEL/CentOS 系统
yum install mailx
对于 Fedora 系统
dnf install mailx
配置qq的smtps服务器
vi /etc/mail.rc
# 在最后一行写入下面信息
# 这里填入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
QQ邮箱的授权码获取方式为:进入邮箱后–>设置–>账户,开启下图1中的SMTP,点击2生成授权码
echo '邮件内容'| mail -s '邮件标题' jenrey@foxmail.com
echo '123'| mail -s 'qwe' jenrey@foxmail.com
配置Peer的证书发布者为信任
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.
解决方法如下:
# 修改配置(/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 查看
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/179873.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...