php實現掃一掃功能的方法:1、產生二維碼,產生一個唯一標識uuid,並使用redis保存臨時資訊;2、透過一個長連接維持用戶請求和伺服器之間的通信;3、使用手機掃描二維碼取得唯一標識uuid,並判斷該標識是否有效。
本文操作環境:Windows7系統,PHP7.4版,Dell G3電腦。
php怎麼實作掃一掃功能?
PHP掃碼登入
掃碼登入具體實作方式
掃碼登入具體實作流程:
(uuid作為key,對應值設定為-1,-1表示未掃描,該標識的有效期限這裡設定為三分鐘,過期會重新產生一個二維碼)。
public function index(){ $uuid = self::createRandomStr('6'); $url = $this->code($uuid); //二维码链接地址 Redis::sAdd($uuid,'-1'); Redis::command('Expire',[$uuid,180]);//设置过期时间 return view('home.send.index',['url'=>$url,'uuid'=>$uuid]); } /** * 生成二维码url * @param $text */ public function code($uuid){ $host='http://'.$_SERVER["HTTP_HOST"].'/api/send'; $url='http://qr.liantu.com/api.php?text='.$host.'?uuid='.$uuid; return $url; }
(-1未掃描, 0表示用戶已掃描該二維碼ps:再次掃描該二維碼時提示已失效, 其餘的值表示用戶的主鍵id)
/** * 验证uuid是否过期 * @param Request $req * @return string|void */ public function confirm(Request $req){ $uuid = $req->uuid; $result = implode('',Redis::sort($uuid)); if($result == ''){//当uuid不存在时表示该标识已失效,重新生成二维码 return '该链接地址已过期'; } if($result == '-1'){ return ''; }elseif($result == '0'){ return '用户已扫描'; }else{ return '用户已确认登录';//获取用户的user_id 直接登录。 } }
public function index(Request $req){ $uuid = $req->uuid; $info = Code::getOne(['uuid'=>$uuid]); $result = implode('',Redis::sort($uuid)); if(!$result){ return $this->ajaxMsgError('该二维码已失效'); } Redis::sRem($code,'-1'); Redis::sadd($code ,0); return $this->ajaxMsgOk('扫描成功,请确认登录'); }
public function dologin(Request $req){ $user_id = $req->user_id; $uuid= $req->uuid; $user = User::getOne(['id'=>$user_id]); if($user){ if($user->status != 1){ return $this->ajaxMsgError('该用户已被禁用'); } Redis::sadd($uuid,$user_id); return $this->ajaxSuccess('登录成功'); }else{ //用户不存在 return $this->ajaxError('该用户不存在'); } }
推薦學習:《PHP影片教學》
以上是php怎麼實作掃一掃功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!