laravel中发送邮件
laravel中使用邮箱的163,QQ邮箱发送邮件
需要注意的是:使用QQ邮箱的话,需要开启POP3和SMTP服务。开启方式如下:
QQ邮箱 > 设置 > 账户
需要开启服务.png
当开启成功会生成**,这个东西会在配置中用到
生成**.png
开始进行配置
# 编辑邮件配置文件
$ vim laravel/config/mail.php
# mail.php
return [
'driver' => env('MAIL_DRIVER', 'smtp'),
'host' => env('MAIL_HOST', 'smtp.163.com'),
'port' => env('MAIL_PORT', 25),
'from' => ['address' => '[email protected]','name' => '发件人'],
'encryption' => env('MAIL_ENCRYPTION', 'tls'),
'username' => env('MAIL_USERNAME'),
'password' => env('MAIL_PASSWORD'),
'sendmail' => '/usr/sbin/sendmail -bs',
]
# 编辑环境配置文件
vim laravel/.env
# .env
MAIL_DRIVER=
MAIL_HOST=
MAIL_PORT=
[email protected]
MAIL_PASSWORD=password
MAIL_ENCRYPTION=
.env文件需要配置username和password其余为空,则会使用mail.php的配置。
-
driver
用于配置默认的邮件发送驱动,Laravel支持多种邮件驱动方式,包括smtp、Mailgun、Maildrill、Amazon SES、mail和sendmail,Mailgun和Amazon SES都是收费的Maildrill目前不支持中国区用户,这三个都是第三方邮件服务。mail驱动使用PHP提供的mail函数发送,sendmail驱动通过Sendmail/Postfix(Linux)提供的命令发送邮件,smtp驱动通过支持ESMTP的SMTP发送邮件。
就目前状况来看,使用smtp是最明智的选择,mail不安全,sendmail需要安装配置Sendmail/Postfix,其他要么付费要么不能用。 -
host
是邮箱所在主机,比如我们使用163邮箱,对应值是smtp.163.com
,使用QQ邮箱的话,对应值是smtp.qq.com
。 -
port
用于配置邮箱发送服务端口号,比如一般默认值是25,但如果设置SMTP使用SSL加密,该值为465。 -
from
配置项包含address和name,前者表示发送邮箱,后者表示发送邮件使用的用户名。 -
encryption
表示加密类型,可以设置为null表示不使用任何加密,也可以设置为tls或ssl。 -
username
表示邮箱账号,比如[email protected] -
password
表示上述邮箱登录对应登录密码。注意QQ邮箱的话应该开启POP3|SMTP服务时给的**。 -
sendmail
是在设置driver为sendmail时使用,用于指定sendmail命令路径。
/**
* 发送邮箱
*/
public function send_email(Request $request){
header("Access-Control-Allow-Origin: *"); //跨域
$leaveMsg = $request->input('leaveMsg')?:'空';
$email = $request->input('email')?:'空';
$name = $request->input('name')?:'空';
$number = $request->input('number')?:'空';
$content =['姓名'=>$name,'电话'=>$number,'邮箱'=>$email,'留言'=>$leaveMsg];
$send = [
'email'=>[
'[email protected]',
'[email protected]'
],
'name'=>'邮件标题',
'content'=>$content
];
//emails.send_email 为 resources/views/emails/send_email.blade.php
//引用的Mail类为php中的(use Mail)或者laravel中的门面类(use Illuminate\Support\Facades\Mail;)
Mail::send('emails.send_email', $send, function($message) use($send)
{
$emailArr = array_filter($send['email']); //去空值
foreach ($emailArr as $email){
$email ? $message->to($email)->subject($send['name']) : '';
}
});
return $data;
}
Mail::send();需要传三个参数,第一个为引用的模板,第二个为给模板传递的变量,第三个为一个闭包,参数绑定Mail类的一个实例。
发送纯文本邮件
Mail::raw('你好,我是PHP程序!', function ($message) {
$to = '[email protected]';
$message ->to($to)->subject('纯文本信息邮件测试');
});
邮件中发送附件
1网络图片
当然,可以在模板直接应用静态文件;但灵活性差,使用embed方法更灵活。
# test.blade.php
{{$name}}你好,这是一封测试文件。
<br>
<img src='{{$message->embed($image)}}'>
public function send()
{
$name = 'name';
$image = 'http://d.hiphotos.baidu.com/zhidao/pic/item/1ad5ad6eddc451da4ab93e2bb0fd5266d11632a6.jpg';
Mail::send('emails.test',['name'=>$name,'imgPath'=>$image],function($message){
$to = '[email protected]';
$message ->to($to)->subject('网络图片测试');
});
if(count(Mail::failures()) < 1){
echo '发送邮件成功,请查收!';
}else{
echo '发送邮件失败,请重试!';
}
}
2.本地图片
本地图片引用需要使用到Storage类,模板方法略有不同,在Storage/images文件夹中有一张图片。
embedData()两个参数,第一个为图片,第二个为自定义图片名称。
# test.blade.php
{{$name}},这是一封测试邮件
<br>
<img src="{{$message->embedData($image,'我的自拍照.jpg')}}">
# MailController.php
public function send(){
$image = Storage::get('images/obama.jpg');
Mail::send('emails.test',['image'=>$image],function($message){
$to = '[email protected]';
$message->to($to)->subject('[本地图片测试]');
});
if(count(Mail::failures()) < 1){
echo '发送邮件成功,请查收!';
}else{
echo '发送邮件失败,请重试!';
}
}
邮件附件
public function sendFile(){
$name = 'name';
Mail::send('emails.test',['name'=>$name],function($message){
$to = '[email protected]';
$message->to($to)->subject('邮件主题');
$attachment = storage_path('app/files/test.txt');
// 在邮件中上传附件
$message->attach($attachment,['as'=>'中文文档.txt']);
});
}
$message的attach方法上传附件,该方法第一个参数是附件地址,第二个参数为一些额外参数,这里我们通过as指定附件在邮件中的显示名称。
测试如果显示文件名乱码的话,就这样写
$message->attach($attachment,['as'=>"=?UTF-8?B?".base64_encode('中文文档')."?=.txt"]);