linux 脚本 发送邮件,shell 脚本发送邮件

有时候会使用脚本完成一系列的自动化工作,工作完成后还需要邮件通知相关人员,此时可以使用第三方的工具:SendEmail,最新版本sendEmail-v1.56.tar.gz

下载地址:http://caspian.dotconf.net/menu/Software/SendEmail/

sendEmil的使用范例:

#!/bin/bash

email_reciver="oneway@163.com lin@126.com"

#发送者邮箱

email_sender=373850874@qq.com

#邮箱用户名

email_username=373850874

#邮箱密码

#使用qq邮箱进行发送需要注意:首先需要开启:POP3/SMTP服务,其次发送邮件的密码需要使用在开启POP3/SMTP服务时候腾讯提供的第三方客户端登陆码。

email_password=mialbjhzsmuobigf

file1_path="附件一路径"

file2_path="附件二路径"

#smtp服务器地址

email_smtphost=smtp.qq.com

email_title="iOS客户端更新"

email_content="谢谢!"

./sendEmail -f ${email_sender} -t ${email_reciver} -s ${email_smtphost} -u ${email_title} -xu ${email_username} -xp ${email_password} -m ${email_content} -a ${file1_path} ${file2_path} -o message-charset=utf-8

问题 1

要使用脚本发送邮件,必须设置发送邮箱开启IMAP/SMTP服务。否则将会报错。

IMAP,即Internet Message Access Protocol(互联网邮件访问协议),您可以通过这种协议从邮件服务器上获取邮件的信息、下载邮件等。IMAP与POP类似,都是一种邮件获取协议。

IMAP和POP有什么区别?

POP允许电子邮件客户端下载服务器上的邮件,但是您在电子邮件客户端的操作(如:移动邮件、标记已读等),这是不会反馈到服务器上的,比如:您通过电子邮件客户端收取了QQ邮箱中的3封邮件并移动到了其他文件夹,这些移动动作是不会反馈到服务器上的,也就是说,QQ邮箱服务器上的这些邮件是没有同时被移动的 。但是IMAP就不同了,电子邮件客户端的操作都会反馈到服务器上,您对邮件进行的操作(如:移动邮件、标记已读等),服务器上的邮件也会做相应的动作。也就是说,IMAP是“双向”的。

同时,IMAP可以只下载邮件的主题,只有当您真正需要的时候,才会下载邮件的所有内容。

问题 2

我使用的系统是Mac OSX EI Capitan, 运行命令时报错如下:

MaxOS: invalid SSL_version specified at /System/Library/Perl/Extras

/5.18/IO/Socket/SSL.pm line 368.

解决方案:

打开文件: /usr/share/perl5/IO/Socket/SSL.pm

找到: m{^(!?)(?:(SSL(?:v2|v3|v23|v2/3))|(TLSv1(?:_?[12])?))$}i

替换为:m{^(!?)(?:(SSL(?:v2|v3|v23|v2/3))|(TLSv1[12]?))}i

可是接下来的问题又出现了,当你修改完成后却无法保存,被告知权限不够,可是你明明使用的是sudo,超级管理员权限。

这是由于 OSX EI Capitan之后苹果采用了“Rootless”技术来保护系统内核,用户将没有权限操作系统文件。但是不要紧

苹果并没有把路封死。

执行以下命令:

% dsenableroot

username = wangwei

user password:

root password:

verify root password:

dsenableroot:: ***Successfully enabled root user.

命令执行后可以使sudo 获取正真的Root用户权限。sudo root用户的密码就是你刚刚设置的密码。

如果你希望自己的账户拥有root权限,那么你也可以通过添加 -U 参数来达到这一目的:

dsenableroot -u wangwei

#其中wangwei为你的用户名

此时你就可以更改/usr/share/perl5/IO/Socket/SSL.pm了。

关于root权限问题,苹果既然使用了Rootless技术来保护内核虽然给我们造成了一些麻烦,但是一定是有他的道理的,比如更加安全,防止了误操作等。

所以我们获取到最高权限后,最好再取消Root权限

取消用户的Root权限

取消用户Root权限只需要在命令后加参数:-d (disable)

% dsenableroot -d

username = wangwei (或者是root)

user password:

dsenableroot:: ***Successfully disabled root user.

取消特定用户的Root权限:

dsenableroot -d -u wangwei

关闭“Rootless”

sudo nvram boot-args="rootless=0"; sudo reboot

文章参考

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值