本篇文章主要讲述了用laravel实现google二维码验证器,具有一定的参考价值,希望感兴趣的朋友可以了解一下。
开发前的准备安装laravel 安装二维码生成器qrcode,没有安装也可以,接下来会安装安装拓展1、运行如下代码安装拓展包:
1 composer require "earnp/laravel-google-authenticator:dev-master"2 ### 安装二维码生成器3 ### 若composer require不到文件自行github 下载源码放入vendor相应的目录下4 composer require simplesoftwareio/simple-qrcode 1.3.*
2、等待下载安装完成,需要在config/app.php中注册服务提供者同时注册下相应门面:
'providers' => [ //........ earnp\googleauthenticator\googleauthenticatorserviceprovider::class, simplesoftwareio\qrcode\qrcodeserviceprovider::class,],'aliases' => [ //.......... 'google' => earnp\googleauthenticator\facades\googleauthenticator::class, 'qrcode' => simplesoftwareio\qrcode\facades\qrcode::class],
3、服务注入以后,如果要使用自定义的配置,还可以发布配置文件到config/views目录:
1 ###这一步可以不执行:视情况而定2 php artisan vendor:publish
使用一(项目中使用)使用方法非常简单,主要为生成验证码和校验验证码
1、生产验证码生产验证码使用createsecret即可,你需要将其内容生成二维码供手机app扫描,具体内容在google.blade.php中已经配置成功
public function adduser(request $request){ if($request->ismethod('get')){ // 创建谷歌验证码 $createsecret = googleauthenticator::createsecret(); //$createsecret = [ // "secret" => "njurupqn6xnygsf2" // "codeurl" => "otpauth://totp/?secret=njurupqn6xnygsf2" //] // 生成二维码 $createsecret["qrcode"] = qrcode::encoding('utf-8')->size(180)->margin(1)->generate($createsecret["codeurl"]); //发送页面 return view('auth.auth.add',['google'=>$createsecret]); } //获取数据 $user_from = $request->only(['role_id','username','pass','pass_confirmation','real_name','mobile','secret']); //保存入库 secret会存入数据库 $auth_user = new authuserservice(); $res = $auth_user->adduser($user_from); return redirect('admin/auth/index');}
2、校验验证码//登录验证public function login(array $param){ $model = new authusermodel(); //google 验证 if(!googleauthenticator::checkcode($userinfo['secret'],$param['secret'])){ return ['status'=>false,'msg'=>['secret'=>['验证码错误,请重新输入']]]; } $update = $model->editlogininfo($userinfo['id'], $update); if(!$update){ return ['status'=>false,'msg'=>['username'=>'更新登录信息失败']]; }else{ return ['status'=>true,'data'=>$userinfo]; }}
使用二(demo)1、校验验证码校验验证码一般用于绑定,登录认证中,使用checkcode方法即可,需要传入secrect和onecode即验证码即可进行校验,第一个为secrect;返回true或false
if(google::checkcode($google,$request->onecode)) { // 绑定场景:绑定成功,向数据库插入google参数,跳转到登录界面让用户登录 // 登录认证场景:认证成功,执行认证操作 dd("认证成功");}else { // 绑定场景:认证失败,返回重新绑定,刷新新的二维码 return back()->with('msg','请正确输入手机上google验证码 !')->withinput(); // 登录认证场景:认证失败,返回重新绑定,刷新新的二维码 return back()->with('msg','验证码错误,请输入正确的验证码 !')->withinput();}
这里有一个具体的实际事例:
use google;if ($request->ismethod('post')) { if (empty($request->onecode) && strlen($request->onecode) != 6) return back()->with('msg','请正确输入手机上google验证码 !')->withinput(); // google密钥,绑定的时候为生成的密钥;如果是绑定后登录,从数据库取以前绑定的密钥 $google = $request->google; // 验证验证码和密钥是否相同 if(google::checkcode($google,$request->onecode)) { // 绑定场景:绑定成功,向数据库插入google参数,跳转到登录界面让用户登录 // 登录认证场景:认证成功,执行认证操作 dd("认证成功"); }else { // 绑定场景:认证失败,返回重新绑定,刷新新的二维码 return back()->with('msg','请正确输入手机上google验证码 !')->withinput(); // 登录认证场景:认证失败,返回重新绑定,刷新新的二维码 return back()->with('msg','验证码错误,请输入正确的验证码 !')->withinput(); }}else { // 创建谷歌验证码 $createsecret = google::createsecret(); // 您自定义的参数,随表单返回 $parameter = [["name"=>"usename","value"=>"123"]]; return view('login.google.google', ['createsecret' => $createsecret,"parameter" => $parameter]);}
相关教程:laravel视频教程
以上就是laravel怎样实现google-authenticator--google二维码验证器的详细内容。