SendCloud是一个比较适合国内的Mail服务商
也很适合新手测试开发,这里推荐给学习Laravel的同学使用
同时github上还有一个整合SendCloud的包Laravel-SendCloud ,后面我们也将使用到
注册并配置Sendcloud API_KEY
API_USER
如果是测试用户,每天都提供免费的邮件请求次数
下面需要在邮件模板中 添加我们的模板邮件 格式如下:
%name%
是我们传给邮件的参数,会自动解析
回到我们的Laravel框架
首先执行composer
命令安装laravel-sendcloud
包
composer require naux/sendcloud
在config/app.php
的provider
中添加我们的服务提供者
'providers' => [
// 添加这行
Naux\Mail\SendCloudServiceProvider::class,
];
然后在.env文件中 配置Sendcloud相关信息
MAIL_DRIVER=sendcloud
//以下需要自行添加
SEND_CLOUD_USER= #Step1中获取的API_USER
SEND_CLOUD_KEY= #Step1中获取的API_KEY
使用artisan命令 生成注册登录模块
php artisan make:auth
下面使用artisan命令创建用户数基表
php artisan migrate
Laravel中默认的用户注册中有Email这个字段,所以就不增加修改了
以上我们的配置环节就结束了
下面来到代码阶段
首先进入到App/Http/Controller/Auth/RegisterController.php
修改create
方法将用户信息传递给sendVerifyEmailTo()
方法
protected function create(array $data)
{
$user = User::create([
'name' => $data['name'],
'email' => $data['email'],
'password' => bcrypt($data['password']),
]);
$this->sendVerifyEmailTo($user);
return $user;
}
这里就到了我们最关键的部分
register
即Sendcloud中邮件模板调用名称
[email protected]
为我们默认的发送邮件账户
Laravel
即为发送邮件标题
这里特别需要注意的是我们的命名空间,在phpstorm中拷贝过来还需要重新敲一次
Mail
这里使用到的命名空间是use Illuminate\Support\Facades\Mail;
private function sendVerifyEmailTo($user){
$data = [
'name' => $user->name,
];
$template = new SendCloudTemplate('register', $data);
Mail::raw($template, function ($message) use($user) {
$message->from('[email protected]', 'Laravel');
$message->to($user->email);
});
}
当然,邮箱必须是真实可接收到的邮箱
然后在我们的邮箱中就应该可以看到我们从Laravel发送的邮件了
如果需要验证token的话,只需要在用户表中添加token和is_active字段,在传到邮件模板中添加回调验证url参数,再添加一个验证token的Controller即可
如果有什么疑惑或者问题可以在评论中回复