이 글은 주로 Laravel을 사용하여 Google QR 코드 유효성 검사기를 구현하는 방법에 대해 설명합니다. 관심 있는 친구들이 이에 대해 배울 수 있기를 바랍니다.
QrCode
를 설치하세요. 설치하지 않고도 할 수 있습니다. 다음에 설치됩니다.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
使用方法非常简单,主要为生成验证码和校验验证码
生产验证码使用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'); }
//登录验证 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]; } }
校验验证码一般用于绑定,登录认证中,使用CheckCode
方法即可,需要传入secrect
和onecode
即验证码即可进行校验,第一个为secrect
;返回true
或false
1 .실행 확장팩을 설치하려면 다음 코드를 사용하세요.
if(Google::CheckCode($google,$request->onecode)) { // 绑定场景:绑定成功,向数据库插入google参数,跳转到登录界面让用户登录 // 登录认证场景:认证成功,执行认证操作 dd("认证成功"); }else { // 绑定场景:认证失败,返回重新绑定,刷新新的二维码 return back()->with('msg','请正确输入手机上google验证码 !')->withInput(); // 登录认证场景:认证失败,返回重新绑定,刷新新的二维码 return back()->with('msg','验证码错误,请输入正确的验证码 !')->withInput(); }
2. 다운로드 및 설치가 완료될 때까지 기다리세요. config/app.php
에 서비스 공급자를 등록해야 합니다. 해당 파사드:
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]); }
3. 서비스가 삽입된 후 사용자 정의된 구성을 사용하려면 구성 파일을 config/views 디렉터리에 게시할 수도 있습니다. rrreee하나 사용(프로젝트에서 사용됨)
🎜 사용법은 매우 간단하며 주로 인증코드 생성과 인증코드를 인증합니다🎜🎜1. 인증코드 생성🎜🎜인증코드를 생성하려면CreateSecret
을 사용하여 QR코드를 생성해야 합니다. 모바일 앱으로 스캔하기 위한 콘텐츠입니다. 특정 콘텐츠는 google.blade.php
에 있습니다. 이미 성공적으로 구성되었습니다🎜🎜 🎜🎜🎜🎜rrreee🎜2. 검증 Code🎜rrree🎜 🎜 🎜🎜 🎜🎜 🎜🎜 🎜🎜를 확인하십시오. 1. 인증 코드 확인🎜🎜인증 인증 코드는 일반적으로 로그인 인증에 사용됩니다. CheckCode 메소드를 사용하면 secret
및 를 전달해야 합니다. >onecode
는 확인을 위한 인증 코드입니다. 첫 번째는 true
또는 false
🎜🎜🎜🎜를 반환합니다. rrreee🎜다음은 구체적인 실제 예입니다: 🎜rrreee🎜관련 튜토리얼: 🎜laravel 비디오 튜토리얼🎜🎜위 내용은 google-authenticator 구현 방법--Laravel에서 Google QR 코드 검사기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!