目录一、修改密码1.1 创建修改密码控制器1.2 创建修改密码路由1.3 测试效果二、绑定邮箱 2.1 绑定邮箱控制器2.2 创建对应路由2.3 创建发送邮件的类2.4 测
运行命令PHP artisan make:controller Auth/PassWordController
写入修改密码方法:
public function updatePassword(Request $request) {
$request->validate([
'old_password' => 'required|min:6|max:16',
'password' => 'required|min:6|max:16|confirmed',
], [
'old_password.required' => '旧密码不能为空',
'old_password.min' => '旧密码最少6个字符',
'old_password.max' => '旧密码最多16个字符',
]);
// 旧密码
$old_password = $request->input('old_password');
// 用户实例
$user = auth('api')->user();
// 验证旧密码是否正确
if (!password_verify($old_password, $user->password)) {
return $this->response->errorBadRequest('旧密码不正确');
}
// 更新用户密码
$user->password = bcrypt($request->input('password'));
$user->save();
return $this->response->noContent();
}
// 修改密码
$api->post('password/update', [PasswordController::class, 'updatePassword']);
运行命令php artisan make:controller Auth/BindController
创建绑定邮箱的控制器:
写入发送邮箱验证码和更新邮箱的处理函数:
<?php
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\BaseController;
use App\Mail\SendEmailCode;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Mail;
class BindController extends BaseController
{
public function emailCode(Request $request) {
$request->validate([
'email' => 'required|email'
]);
// 发送验证码到邮件
Mail::to($request->input('email'))->queue(new SendEmailCode($request->input('email')));
return $this->response->noContent();
}
public function updateEmail(Request $request) {
$request->validate([
'email' => 'required|email',
'code' => 'required'
], [
'code.required' => "验证码不能为空",
]);
// 验证code是否正确
if (cache($request->input('email')) != $request->input('code')) {
return $this->response->errorBadRequest('验证码或邮箱错误!');
}
// 更新邮箱
$user = auth('api')->user();
$user->email = $request->input('email');
$user->save();
return $this->response->noContent();
}
}
如果修改了队列了,就要重启队列,命令sudo supervisorctl restart all
// 发送邮件验证码
$api->post('email/code', [BindController::class, 'emailCode']);
// 更新邮箱
$api->post('email/update', [BindController::class, 'updateEmail']);
运行命令php artisan make:mail SendEmailCode
:
写入:
<?php
namespace App\Mail;
use Illuminate\Bus\Queueable;
use Illuminate\Mail\Mailable;
use Illuminate\Queue\SerializesModels;
use Illuminate\Support\Facades\Cache;
class SendEmailCode extends Mailable
{
use Queueable, SerializesModels;
protected $email;
public function __construct($eamil)
{
$this->email = $eamil;
}
public function build()
{
// 生成code
$code = rand(1000, 9999);
// 获取邮箱
// 使用缓存邮箱对应的code
Cache::put($this->email, $code, now()->addMinute(5)); // 5分钟过期
return $this->view('emails.send-email-code', ['code' => $code]);
}
}
创建发送邮件的模版:
模版写入:
<h3>邮箱验证码是:{{$code}}</h3>
<h3>验证码5分钟内有效,请及时使用!</h3>
可以看到这边收到邮箱验证码。
测试更新的输入邮箱不正确或者验证码不正确:
输入正确的邮箱和验证码就会修改了。
到此这篇关于laravel的用户修改密码与绑定邮箱的文章就介绍到这了,更多相关laravel修改密码内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: laravel的用户修改密码与绑定邮箱的详细操作
本文链接: https://lsjlt.com/news/134951.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0