Laravel第二章

本文详细介绍如何在Laravel框架中实现随机验证码的生成、存储及验证,包括邮件和短信发送验证码的过程,以及如何设置验证码过期时间。同时,文章还讲解了如何创建自定义表单请求类和中间件来增强应用的安全性和功能性。

创建助手函数,随机验证码

1:在app目录下创建名叫helper.php的文件
2:在helper.php中写随机验证码的函数

function code_rand($len=4){
     $str='';
     for($i=0;$i<$len;$i++){
         $a=mt_rand(0,9);
         $str=$str.$a;
     }
     return $str;
}

3.这个文件是我们自己创建的,框架不会识别,需要我们在composer.json文件中处理自动加载,在更改了composer文件之后需要在Terminal终端中执行:composer dump;

 "autoload": {
         //自动加载数据库
        "classmap": [
            "database/seeds",
            "database/factories"
        ],
        "psr-4": {
        //自动加载类
            "App\\": "app/"
        },
        //自动加载文件
        "files": [
            "app/helper.php"
        ]
    },

邮箱发送验证码:

1:创建发送验证码的类:RegisterNotify这个类是laravel框架的内置类

php artisan make:notification RegisterNotify

2:设置邮箱发送的内容:RegisterNotify中的toMail

 public function toMail($notifiable)
    {
      return (new MailMessage)
      //$this->code是第3步中new RegisterNotify传到这个类中的构造方法里的
       ->line('您好,你注册我网需要的验证码:'.$this->code.',已经发送到您的邮箱,欢迎注册我网');
    }

3:利用邮箱发送验证码的逻辑代码:

//filter_var($request->username)是邮箱返回true
if(filter_var($request->username,FILTER_VALIDATE_EMAIL)){
    $type='email';
    firstOrNew这个方法的返回一个User的对象,比对邮箱,看数据库会不会有,有的话会返回一个这个消息的User对象,如果没有,就new一个空的对象,因为在调用notify时需要一个User对象
    $user=User::firstOrNew(['email'=>$request->username])?:new User();
    // 当是邮箱时给他发送邮件告知验证码,并且在new RegisterNotify给它把$code传过去
    $user->notify(New RegisterNotify($code));
            //未完

4:设置邮件发送时的配置

MAIL_DRIVER=SMTP
MAIL_HOST=smtpdm.aliyun.com
MAIL_PORT=80
MAIL_USERNAME=fs@mengju.mumeng.xyz
MAIL_PASSWORD=MJ123456fs
MAIL_ENCRYPTION=
MAIL_FROM_ADDRESS=fs@mengju.mumeng.xyz
MAIL_FROM_NAME=mengju.mumeng.xyz

给手机发送短信验证码

1:手机发送验证码的逻辑代码:

//给手机号码做正则匹配
}elseif ('/^\d{11}$/'){
        $type = 'mobile';
        //这个是hdjs封装好的短信模板
        $data = [
    //短信签名
        'sign'     => '牧夢哟',
        //短信模板
        'template' => 'SMS_144145970',
    //前台提交来的手机号码
        'mobile'   => $request->username,
    //模板变量
        'vars'     => ["code" => $code],
    ];
    //Aliyun这个类也是hdjs封装的函数,需要在Terminal终端中执行
    //composer require houdunwang/aliyun加载houdunwang/aliyun这个类库
        $res = Aliyun::instance('Sms')->send($data);

3.在AppServiceProvider配置短信发送的key和id,并且在这个类中的boot方法中引用这个方法,这样保证它可以在短信发送之前配置好


protected function loadConfig ()
    {
        Aliyun::config ( [
            /*
            |--------------------------------------------------------------------------
            | 根据服务器所在区域进行选择
            | https://help.aliyun.com/document_detail/40654.html?spm=5176.7114037.1996646101.1.OCtdEo
            */
            'regionId'  => 'cn-hangzhou' ,
            /*
            |--------------------------------------------------------------------------
            | 如果使用主账号访问,登陆阿里云 AccessKey 管理页面创建、查看
            | 如果使用子账号访问,请登录阿里云访问控制控制台查看
            */
            'accessId'  => 'LTAIcNOXhfU9jSMZ' ,
            /*
            |--------------------------------------------------------------------------
            | 如果使用主账号访问,登陆阿里云 AccessKey 管理页面创建、查看
            | 如果使用子账号访问,请登录阿里云访问控制控制台查看
            */
            'accessKey' => '5HOslwGi0vhX4l2xLUaKU4qTv8oB9k' ,
        ] );
    }

设置验证码过期时间:

1:在存储验证码时,存储验证码的过期时间

  public function saveToSession($code,$type,$request){
            session()->put('valid_code',[
               'code'=>$code,
                'type'=>$type,
                'username'=>$request->username,
                'expire'=>time()+$this->expire,//过期时间
            ]);
    }

2:判断验证码是否过期,过期后扔出异常消息提示

 public function checkexpire(){
     //取出存在session里的过期时间和现在的时间做比较
        $expire=session('valid_code.expire');
        if($expire&&$expire>time()){
            throw new ValidException('验证码发送过于频繁,请稍后再试');
        }
    }

邮件或者短信发送过程中的消息提示

1:创建一个异常类:这个类会生成在app/Exceptions下

php artisan make:exception ValidException

2:构建一个系统规定的方法render;

 public function render(){
 //response也是系统制定的一个对象,不能变
        return response()->json(['code'=>$this->code,'message'=>$this->getMessage()],401);
    }

3:调用:

 public function checkexpire(){
        $expire=session('valid_code.expire');
        if($expire&&$expire>time()){
        //抛出异常 throw调用
            throw new ValidException('验证码发送过于频繁,请稍后再试');
        }
    }

针对复杂的验证规则,需要一个自定义表单请求的类:

1.创建表单请求类:这个请求是专为User类做验证的

php artisan make:request UserRequest

2.在UserRequest这个类里的rules这个方法里写验证规则:

  public function rules()
    {
        return [
            'password'=>'required|confirmed''code'=>[
                'required',
                //   $value是传递到account里的值
                //这种复杂的验证规则可以在function体里
                function ($attribute,$value,$fail){
            if($value !=session('valid_code.code')){
                return $fail('验证不正确');
            }
            return true;
                }
            ]
        ];
    }

3.在User类的需要此验证规则就引用这个验证,引用方式如下:

//UserRequest是表示在引用第二步的验证规则;
 public function store(UserRequest $request)
    {
    //
    }

创建中间件:做验证拦截

1.创建中间件:

php artisan make:middleware AuthAdmin

2.在AuthAdmin类里的handle中写验证规则,做拦截:

 public function handle($request, Closure $next)
    {
    //符合此方法的逻辑,才能通过,进行下一步,负责会被拦截
        if(!\Auth::check()||auth()->user()->is_admin!=1){
            return redirect('/');
        }
        return $next($request);
    }

3.调用中间件,要在路由组里调用:

//middleware:中间件
Route::group(['middleware'=>['admin.auth'],'prefix'=>'admin','as'=>'admin.','namespace'=>'Admin'],function (){
        Route::get('/','HomeController@index')->name('home.index');

});
下载前可以先看下教程 https://pan.quark.cn/s/16a53f4bd595 小天才电话手表刷机教程 — 基础篇 我们将为您简单的介绍小天才电话手表新机型的简单刷机以及玩法,如adb工具的使用,magisk的刷入等等。 我们会确保您看完此教程后能够对Android系统有一个最基本的认识,以及能够成功通过magisk root您的手表,并安装您需要的第三方软件。 ADB Android Debug Bridge,简称,在android developer的adb文档中是这么描述它的: 是一种多功能命令行工具,可让您与设备进行通信。 该命令有助于各种设备操作,例如安装和调试应用程序。 提供对 Unix shell 的访问,您可以使用它在设备上运行各种命令。 它是一个客户端-服务器程序。 这听起来有些难以理解,因为您也没有必要去理解它,如果您对本文中的任何关键名词产生疑惑或兴趣,您都可以在搜索引擎中去搜索它,当然,我们会对其进行简单的解释:是一款在命令行中运行的,用于对Android设备进行调试的工具,并拥有比一般用户以及程序更高的权限,所以,我们可以使用它对Android设备进行最基本的调试操作。 而在小天才电话手表上启用它,您只需要这么做: - 打开拨号盘; - 输入; - 点按打开adb调试选项。 其次是电脑上的Android SDK Platform-Tools的安装,此工具是 Android SDK 的组件。 它包括与 Android 平台交互的工具,主要由和构成,如果您接触过Android开发,必然会使用到它,因为它包含在Android Studio等IDE中,当然,您可以独立下载,在下方选择对应的版本即可: - Download SDK Platform...
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值