laravel的用户修改密码与绑定邮箱

一、修改密码

1.1 创建修改密码控制器

运行命令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();
    }

在这里插入图片描述


1.2 创建修改密码路由

            // 修改密码
            $api->post('password/update', [PasswordController::class, 'updatePassword']);

在这里插入图片描述


1.3 测试效果

在这里插入图片描述


二、绑定邮箱

2.1 绑定邮箱控制器

运行命令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|unique:users,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|unique:users,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


2.2 创建对应路由

            // 发送邮件验证码
            $api->post('email/code', [BindController::class, 'emailCode']);

            // 更新邮箱
            $api->post('email/update', [BindController::class, 'updateEmail']);

在这里插入图片描述


2.3 创建发送邮件的类

运行命令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;
    /**
     * Create a new message instance.
     *
     * @return void
     */
    public function __construct($eamil)
    {
        $this->email = $eamil;
    }

    /**
     * Build the message.
     *
     * @return $this
     */
    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>

2.4 测试效果

在这里插入图片描述
可以看到这边收到邮箱验证码。
测试更新的输入邮箱不正确或者验证码不正确:
在这里插入图片描述
输入正确的邮箱和验证码就会修改了。

在学习的php的路上,如果你觉得本文对你有所帮助的话,那就请关注点赞评论三连吧,谢谢,你的肯定是我写博的另一个支持。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你华还是你华

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值