linux mail发邮件_python邮件发送

2022-11-01 15:51:24 浏览数 (1)

linux安装mailx发邮件

文章目录

  • linux安装mailx发邮件
    • 原理
    • 安装
    • 配置qq的smtps服务器
    • 配置Peer的证书发布者为信任

mail 命令是 Linux 终端发送邮件用的最多的命令。mailxmail 命令的更新版本,基于 Berkeley Mail 8.1,意在提供 POSIX mailx 命令的功能,并支持 MIME、IMAP、POP3、SMTP 和 S/MIME 扩展。mailx 在某些交互特性上更加强大,如缓冲邮件消息、垃圾邮件评分和过滤等。在 Linux 发行版上,mail命令是 mailx 命令的软链接。可以运行下面的命令从官方发行版仓库安装 mail 命令。

​ 这里是:使用外部 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

​ QQ邮箱的授权码获取方式为:进入邮箱后–>设置–>账户,开启下图1中的SMTP,点击2生成授权码

代码语言:javascript复制
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的证书发布者被标记为不被信任。 这是由于使用加密通信,但客户端不能确认证书是否真实。 但是邮件可以正常发送。

代码语言:javascript复制
[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

0 人点赞