/**
 * 这里主要是想通过自己搭建smtp服务器,配置laravel5.2框架,实现邮箱发邮件功能,
* 主要内容是搭建smtp服务器,laravel5.2发邮件顺手提一下
*/ /**
* 1.laravel5.2通过Mail实现发邮件的功能
* 2.搭建自己的smtp服务器
* 3.修改mail的配置,将主机和账号修改为自己的smtp代理服务器
*
* 相关技术基础(php基础知识、laravel5.2框架的简单操作、Linux运维基础知识)
*/ /**
* 1.laravel5.2通过mail实现发邮件的功能
*
* 首先修改config里面关于mail的配置文件
* vim ./config/mail.php
return [
'driver' => 'smtp',
'host' => 'smtp.exmail.qq.com',
'port' => 465,
'from' => ['address' => 'anywhere', 'name' => '云享客'],
'encryption' => 'ssl',
'username' => 'myaccount@domain.com',
'password' => 'mypasswd',
'sendmail' => '/usr/sbin/sendmail -bs',
];
* driver是驱动为smtp,
* host就是smtp代理服务器,我有一个腾讯企业邮箱的账号,腾讯企业邮箱的smtp是smtp.exmail.qq.com
* port是465,encryption是ssl,这个是腾讯smtp服务器相关的,一般在邮箱的安全设置里面可以找到这些
* from里面的address可以随便写,name也是,这个属于邮件部分,跟发送影响不大
* username和password就是腾讯企业邮箱的账号,
* 有了这些配置之后,可以直接在控制器里面调用mail的send方法发送邮件。
*
*
* vim ./app/Http/Controllers/MailController.php
use Illuminate\Support\Facades\Mail;
//sendMail function
private function sendMail()
{
$name = $this->name;
$userid = $this->userid;
$token = $this->token;
$time = $this->time;
$telplate = $this->telplate;
$email = $this->email; $flag = Mail::send($telplate,['name'=>$name,'userid'=>$userid,'email'=>$email,'token'=>$token,'time'=>$time],function($message){
$to = $this->email;
$message ->to($to)->subject('your subject');
});
if($flag){
return true;
}else{
return false;
}
}
*
* 邮件发送的核心就是Mial::send();
* 其中$telplate就是邮件的详细内容部分,可以通过html和css定义为任意的样式,很灵活。
* 接着一个数组就是$telplate的参数部分,
* $to是发送到的邮箱地址,
* subject是邮件主题
* 模板同样放在views里面。比如$this->telplate = 'email.index',就是./resouces/views/email/index.blade.php
* 通常需要传递到模板的参数至少有时间,用户标识和token,
* 时间用来控制链接生效时间,token避免违法请求,用户唯一标识在用户认证激活的时候用来分辨是属于哪个用户。
* 这里只是达到发邮件的目的,其他内容在laravel框架分类里面会提及。
*/ /**
* 2.搭建自己的smtp服务器
* (在上面的配置里面,我们使用的smtp服务器是腾讯的企业邮箱代理服务器,
* 第三方的免费使用的代理服务器会有一些限制,比如说条数内容的限制,我们想搭建一台自己的
* smtp服务器来替代smtp.exmail.qq.com)
*
* 首先需要有一台物理主机,不管是租云服务器或者是去中关村买一台,根据需要自己配置。
* 我这里是租了一台测试版的阿里云ecs,可以满足我的简单的发邮件需求。
* 我的阿里云ecs装的centos6.5操作系统,现在我们一步一步的搭建配置我们自己的smtp服务器。
*
* 需要确定我们将使用postfix代替sendmail发送邮件,具体原因有很多,不赘述。
*
*
* 通过yum安装postfix dovecot cyrus-sasl
* 修改postfix的配置文件
* vim /etc/postfix/main.cf
*
* myhostname=test.mail.com
*
* mydomain=mail.com
*
* myorigin = $mydomain
*
* inet_interfaces = $myhostname,localhost
*
* inet_protocols = ipv4
*
* mydestination = $myhostname, localhost.$mydomain, localhost, $mydomain
*
* mynetworks = 0.0.0.0/0
*
* 加上以下配置禁止不验证就发送
smtpd_sasl_auth_enable = yes
smtpd_sasl_local_domain = $myhostname
smtpd_sasl_security_options = noanonymous
#smtpd_sender_restrictions = permit_mynetworks,reject_unauth_sender,reject_authenticated_sender_login_mismatch,reject_sender_login_mismatch
smtpd_sender_restrictions = permit_sasl_authenticated,reject_authenticated_sender_login_mismatch,reject_sender_login_mismatch
smtpd_recipient_restrictions = permit_sasl_authenticated,reject_non_fqdn_hostname,reject_non_fqdn_sender,reject_non_fqdn_recipient,reject_invalid_hostname,reject_unauth_destination
*
* 重启postfix:service postfix restart;
* failed, tail /var/log/maillog 报错host无法识别
* vim /etc/host 添加主机解析到域名:
* 121.xxx.xxx.xxx test.mail.com
* 121.xxx.xxx.xxx mail.com
* service postfix restart ok了
*
* 测试telnet 121.xxx.xxx.xxx 25
* Trying 121.xxx.xxx.xxx...
* Connected to 121.xxx.xxx.xxx.
* Escape character is '^]'.
* 220 test.mail.com ESMTP Postfix postfix
* ehlo mail.com
* 250-test.mail.com
* 250-PIPELINING
* 250-SIZE 10240000
* 250-VRFY
* 250-ETRN
* 250-AUTH PLAIN LOGIN
* 250-ENHANCEDSTATUSCODES
* 250-8BITMIME
* 250 DSN
* mail from:12223
* 250 2.1.0 Ok
* rcpt to:yhy19921013@163.com
* 504 5.5.2 <12223>: Sender address rejected:
* need fully-qualified address
*
* 这里被拒绝提示需要认证账号,因为我在配置文件里面做了这样的要求
* 我们新建用户
* useradd mymailer
* passwd mymailer
*
* 在用户模板下面创建用户邮箱目录授予700权限
* mkdir /etc/skel/Maildir
* chmod 700 /etc/skel/Maildir
*
* 为用户创建邮箱目录授予700权限,并将邮箱目录设置为用户所有
* mkdir /home/mymailer/Maildir
* chmod 700 /home/mymailer/Maildir/
* chown mymailer Maildir/
*
* 为用户设置smtp认证密码
* saslpasswd2 -u 121.42.148.193 -c mymailer
*
* 改变sasl的属性和所属组
* chgrp postfix /etc/sasldb2
* chmod 640 /etc/sasldb2
*
* 修改smtp.com,不使用系统用户密码作为用户的SMTP认证密码
* vim /etc/sasl2/smtpd.com
* pwcheck_method: auxprop
*
* 修改sasl配置
* vi /etc/sysconfig/saslauthd
* #MECH=pam
* FLAGS=sasldb
*
* 重启相关服务
* /etc/rc.d/init.d/saslauthd start
* service postfix restart
*
* 在本地
* [root@iZ28gk7b2avZ mymailer]# telnet test.mail.com 25
* Trying 121.xxx.xxx.xxx...
* Connected to test.mail.com.
* Escape character is '^]'.
* 220 test.mail.com ESMTP Postfix postfix
* ehlo mymailer
* 250-test.mail.com
* 250-PIPELINING
* 250-SIZE 10240000
* 250-VRFY
* 250-ETRN
* 250-AUTH PLAIN LOGIN
* 250-ENHANCEDSTATUSCODES
* 250-8BITMIME
* 250 DSN
* auth login
* 334 VXNlcm5hbWU6
* bXltYWlsZXI=
* 334 UGFzc3dvcmQ6
* MTIzNDU2
* 235 2.7.0 Authentication successful
* mail from:mymailler@mail.com
* 250 2.1.0 Ok
* rcpt to:xxxxxxx@qq.com
* 250 2.1.5 Ok
* data
* 354 End data with <CR><LF>.<CR><LF>
* test mail
* .
* 250 2.0.0 Ok: queued as D0251C03F3
* quit
*
* (auth login之后需要输入的经过base64处理的账号和密码,可以通过
* printf 'mymailer' |openssl base64
* printf 'mypass' |openssl base64
* 得到)
* 这里就算是搭建发送成功,如果出现没有收到邮件的意外情况,
* 可以查看/var/log/maillog
* 很有可能被退信了,比如我发往163
*
* to=<xxxxxxxxx@163.com>,
* relay=163mx01.mxmail.netease.com
* [220.181.14.137]:25, delay=21, delays=20/0.01/1.1/0.02,
* dsn=5.0.0, status=bounced
* (host 163mx01.mxmail.netease.com[220.181.14.137]
* said: 550 MI:SPF 163 mx36,
* VsCowAA3ayWf4stXRgB2BQ--.37232S2 1472979616
* http://mail.163.com/help/help_spam_16.htm?
* ip=121.42.148.193&hostid=mx36&time=1472979616 (in reply to
* MAIL FROM command))
*
* 因为域名没有解析,买个域名,解析到服务器就ok了,还不会被送往垃圾箱。
*/ /**
* 3.修改laravel中mail的配置,将主机和账号修改为自己的smtp代理服务器
* 假设你已经买了一个域名,并且已经成功解析:mail.domain.com
*
* 那么,vim ./config/main.php
return [
'driver' => 'smtp',
'host' => 'mail.domain.com',
'port' => 25,
'from' => ['address' => 'mymailer@spaceyun.com', 'name' => 'someone'],
'encryption' => 'ssl',
'username' => 'mymailer',
'password' => 'yourpass',
'sendmail' => '/usr/sbin/sendmail -bs',
];
* 然后测试一下,ok
*/

Linux搭建smtp服务器+laravel5.2发邮件配置的更多相关文章

  1. Linux 搭建SVN 服务器(转)

    一. SVN 简介 Subversion(SVN) 是一个开源的版本控制系統, 也就是说 Subversion 管理着随时间改变的数据. 这些数据放置在一个中央资料档案库 (repository) 中 ...

  2. 原 Linux搭建SVN 服务器2

    原 Linux搭建SVN 服务器 发表于1年前(2014-08-05 17:55)   阅读(12257) | 评论(3) 31人收藏此文章, 我要收藏 赞3 摘要 Linux搭建SVN 服务器 目录 ...

  3. 原 Linux搭建SVN 服务器

    原 Linux搭建SVN 服务器 发表于1年前(2014-08-05 17:55)   阅读(12257) | 评论(3) 31人收藏此文章, 我要收藏 赞3 摘要 Linux搭建SVN 服务器 目录 ...

  4. Linux搭建SVN 服务器

    Linux搭建SVN 服务器 1          安装SVN 2          使用客户端连接 2.1       使用windows的客户端 2.2       使用Linux下的命令行 3  ...

  5. Linux搭建SVN 服务器(转)

    转自:http://my.oschina.net/lionel45/blog/298305 Linux搭建SVN 服务器 作者: 沈小然    日期:2014年 8月 5日 1          安装 ...

  6. Linux 搭建SVN 服务器

    一. SVN 简介 Subversion(SVN) 是一个开源的版本控制系統, 也就是说 Subversion 管理着随时间改变的数据. 这些数据放置在一个中央资料档案库 (repository) 中 ...

  7. Linux搭建SVN服务器(服务端)

    Linux搭建SVN服务器(服务端) 1 安装SVN SVN客户端:TortoiseSVN,官网下载:https://tortoisesvn.net/downloads.html(客户端) # yum ...

  8. 使用Linux搭建FTP服务器实现文件共享

    使用Linux搭建FTP服务器实现文件共享... ---------------- Linux中的文件共享:FTPVSFTPDVSFTPD虚拟用户 FTP可以用在Linux与Linux 和Window ...

  9. Linux搭建DHCP服务器

    Linux搭建DHCP服务器   实验目标: 通过本实验掌握基于Linux的DHCP服务器搭建技能. 本实验包含内容为yum的认识与使用,磁盘挂载的概念与使用,DHCP原理及配置,systemctl服 ...

随机推荐

  1. Neo4j Index Notes

    Motivation GraphDatabasesBook: Robinson I., Webber J., Eifrem E. Graph Databases. 2013. 这本该是入门概念性质的书 ...

  2. 该应用的登录功能版本较旧,无法使用QQ账号登录,请升级到最新版本,如果还无法解决,请联系开发者升级。(错误码:100044)

    该原因应该是你的应用数据签名更改的原因 解决步骤已经写到我的公众号,二维码在下面. 欢迎观看我的CSDN学院课程,地址:http://edu.csdn.net/course/detail/2877 本 ...

  3. 配置recovery_min_apply_delay后重启standby节点报错:psql: FATAL: the database system is starting up

    环境: pg版本:PostgreSQL 9.4.4 on x86_64 系统版本:CentOS release 6.6 linux内核版本:2.6.32-504.8.1.el6.x86_64 今天测试 ...

  4. SSH 创建证书认证

    *******chmod 600 195-tempuser.txt******* useradd tempusersu tempusercdmkdir .sshchmod 700 .sshcd .ss ...

  5. Unity Shader——Writing Surface Shaders(3)——Surface Shader Lighting Examples

    Surface Shader 光照例子 这里有一些自定义光照模型和Surface Shaders的例子.通常的Surface Shader例子在这里. 由于延迟光照在某些自定义的逐材质光照模型中表现得 ...

  6. CompositeConfiguration的用法

    public class Mytest { private static ApplicationContext applicationContext; public static void main( ...

  7. Oracle调整联机日志大小

    近期一个项目反馈月底高峰期时系统整体性能下降,抓取对应的AWR和ASH查看,等待事件排第一位的竟然是redo日志切换.进一步看每秒的日志量是5M多,而日志文件大小仅有200M.建议项目上调整日志大小, ...

  8. Sedgewick的红黑树

    红黑树一直是数据结构中的难点,大部分关于算法与数据结构的学习资料(包括<算法导论>)对于这部分的讲解都是上来就下定义,告诉我们红黑树这个性质那个性质,插入删除要注意1234点,但是基本没有 ...

  9. Django缓存使用方法

    Django缓存分为Session和Cookie:Session为放在服务器端的缓存:Cookie为放在客户端(浏览器)的缓存. Session一般用来保存登录会话:Cookie一般用来保存一些个性化 ...

  10. sql 数据量高并发的数据库优化(转)

    Mysql 大数据量高并发的数据库优化 一.数据库结构的设计 如果不能设计一个合理的数据库模型,不仅会增加客户端和服务器段程序的编程和维护的难度,而且将会影响系统实际运行的性能.所以,在一个系统开始实 ...