Heim > Artikel > Backend-Entwicklung > PHP implementiert die gemeinsame Nutzung von WeChat-PC-QR-Code-Anmeldecodes
Dieser Artikel stellt hauptsächlich die Implementierungsideen der PHP-WeChat-PC-QR-Code-Anmeldung vor. Ich hoffe, dass er für alle hilfreich ist.
1. Idee:
Der Schlüssel zur Idee ist, wie man mit WeChat interagiert. Schließlich kann die WeChat-Anmeldung derzeit nur über WeChat erfolgen.
Aber WeChat verfügt über eine spezielle Methode zum Generieren benutzerdefinierter QR-Codes, die es uns ermöglicht, den QR-Code auf dem PC anzuzeigen, und der Wert des QR-Codes kann sein, was wir definieren. Darüber hinaus gibt es in der WeChat-Entwicklungsdokumentation ein Scan-Ereignis, mit dem Benutzer erkannt werden können, die WeChat verwenden, um den QR-Code zu scannen und den Wert abzurufen. Tatsächlich liegt der Schlüssel zum Problem in diesem Wert. Dieser Wert wird als Kommunikations-ID zwischen China Unicom PC und WeChat angesehen.
2. Spezifischer Implementierungsprozess (Der folgende Code verwendet das TP5-Framework und eine Hauptvoraussetzung ist, dass es ein öffentliches Konto des Dienstkontos gibt)
1. Generieren Sie den QR-Code auf dem PC:
Der Code lautet wie folgt:
Controller:
namespace app\home\controller; class Recognition extends Base{ public function seeLoginQrcode(){ $qrcode_return = model('Recognition')->getLoginQrcode(); if($qrcode_return['error_code']){ return $this->returnJson("获取失败!",0); }else{ $data=array( 'url'=>$qrcode_return['ticket'], 'qrcode_id'=>$qrcode_return['id'], ); return $this->returnJson("获取成功!",1,$data); } } }
Modell:
namespace app\common\model; use think\Model; class Recognition extends Model{ protected $autoWriteTimestamp = false; //生成登录用的临时二维码 public function getLoginQrcode(){ $appid = config('THINK_SDK_WEIXIN.APP_KEY'); $appsecret = config('THINK_SDK_WEIXIN.APP_SECRET'); if(empty($appid) || empty($appsecret)){ return(array('error_code'=>true,'msg'=>'请联系管理员配置【AppId】【 AppSecret】')); } $database_login_qrcode = model('LoginQrcode'); $database_login_qrcode->where(array('add_time'=>array('lt',($_SERVER['REQUEST_TIME']-604800))))->delete(); $data_login_qrcode['add_time'] = $_SERVER['REQUEST_TIME']; $database_login_qrcode->save($data_login_qrcode); $qrcode_id = $database_login_qrcode->getLastInsID(); if(empty($qrcode_id)){ return(array('error_code'=>true,'msg'=>'获取二维码错误!无法写入数据到数据库。请重试。')); } import('Net.Http'); $http = new \Http(); //微信授权获得access_token $access_token_array = model('AccessTokenExpires')->getAccessToken(); if ($access_token_array['errcode']) { return(array('error_code'=>true,'msg'=>'获取access_token发生错误:错误代码' . $access_token_array['errcode'] .',微信返回错误信息:' . $access_token_array['errmsg'])); } $access_token = $access_token_array['access_token']; $qrcode_url='https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token='.$access_token; $post_data['expire_seconds'] = 604800; $post_data['action_name'] = 'QR_SCENE'; $post_data['action_info']['scene']['scene_id'] = $qrcode_id; $json = $http->curlPost($qrcode_url,json_encode($post_data)); if (!$json['errcode']){ $condition_login_qrcode['id']=$qrcode_id; $data_login_qrcode['id'] = $qrcode_id; $data_login_qrcode['ticket'] = $json['ticket']; if($database_login_qrcode->isUpdate(true)->save($data_login_qrcode)){ return(array('error_code'=>false,'id'=>$qrcode_id,'ticket'=>'https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket='.urlencode($json['ticket']))); }else{ $database_login_qrcode->where($condition_login_qrcode)->delete(); return(array('error_code'=>true,'msg'=>'获取二维码错误!保存二维码失败。请重试。')); } }else{ $condition_login_qrcode['id'] = $qrcode_id; $database_login_qrcode->where($condition_login_qrcode)->delete(); return(array('error_code'=>true,'msg'=>'发生错误:错误代码 '.$json['errcode'].',微信返回错误信息:'.$json['errmsg'])); } } }
Sie können sehen, dass es nach Erfolg zurückkehrt:
Code kopieren Der Code lautet wie folgt:
return(array('error_code'=>false,'id'=>$qrcode_id,'ticket'=>'https://mp.weixin .qq.com/cgi-bin/showqrcode ?ticket='.urlencode($json['ticket'])));
Es gibt einen ID-Wert, der tatsächlich den Wert des QR-Codes darstellt!
Dann ist das Ticket der Link zum QR-Code. Das heißt, der durch Scannen dieses QR-Codes im Scan-Ereignis erhaltene Wert ist diese ID.
Überprüfen Sie die WeChat-Verarbeitung unten
1. Nach dem Scannen des QR-Codes:
namespace app\mobile\controller; class Wechat extends Base{ public function index() { import('Wechat.Wechat'); $wechat = new \Wechat(); $data = $wechat->request(); list($content, $type) = $this->reply($data); if ($content) { $wechat->response($content, $type); } else { exit(); } } public function reply($data) { if ($data['MsgType'] == 'event') { $id = $data['EventKey']; switch (strtoupper($data['Event'])) { case 'SCAN': return $this->scan($id, $data['FromUserName']); case 'CLICK': //回复? return array('click', 'text'); break; case 'SUBSCRIBE': //关注 return array('Welcome', 'text'); break; case 'UNSUBSCRIBE': //取关 return array('BYE-BYE', 'text'); case 'LOCATION': //定位 break; } } else { if ($data['MsgType'] == 'text') { return array("测试成功!",'text'); } if ($data['MsgType'] == 'location') { } if (import('@.ORG.' . $data['MsgType'] . 'MessageReply')) { } } return false; } private function scan($id, $openid = '', $issubscribe = 0) { if ((1000000000 < $id) && $openid) { if ($user = model('Member')->field('id')->where(array('third_id' => $openid))->find()) { $data=array( 'id'=>$id, 'uid'=> $user['id'] ); model('LoginQrcode')->isUpdate()->save($data); return array('登陆成功', 'text'); } $data=array( 'id'=>$id, 'uid'=>-1 ); model('LoginQrcode')->isUpdate(true)->save($data); $return[] = array('点击授权登录', '',config('SITE_LOGO'), config('SITE_URL') . '/mobile/WechatBind/ajaxWebLogin?qrcode_id=' . $id); return array($return, 'news'); } } }
Die obige Scan-Methode hat dieses Urteil , können Sie sehen:
if ((1000000000 < $id) && $openid) {
Die $id ist der entsprechende QR-Code-Wert, der der ist id, die wir zuvor generiert haben (tatsächlich haben wir zur Unterscheidung verschiedener Ereignisse im Scan die Tabelle login_qrcode, in der sich die ID befindet, absichtlich ab 1000000000 erhöht).
Sehen Sie sich dann die Verarbeitung dahinter an, wenn:
if ($user = model('Member')->field('id')->where(array('third_id' => $openid))->find()) { $data=array( 'id'=>$id, 'uid'=> $user['id'] ); model('LoginQrcode')->isUpdate()->save($data); return array('登陆成功', 'text'); }
Wenn die Bedingungen erfüllt sind und es einen Benutzer mit der openid gibt, aktualisieren Sie die Tabelle login_qrcode und ändern Sie die uid zur Benutzer-ID. (Hier ist der Schlüssel, warum die UID der der ID entsprechenden Daten auf die Benutzer-ID aktualisiert wird, selbst wenn der Benutzer angemeldet ist.)
3. Schauen Sie sich weiterhin die PC-Seite an, nachdem Sie den QR-Code erhalten haben, sondern trainieren Sie stattdessen eine Methode:
* 微信登录异步请求 * @return \think\response\Json * created by sunnier<xiaoyao_xiao@126.com> */ public function ajaxWechatLogin(){ for ($i = 0; $i < 6; $i++) { $database_login_qrcode = model('LoginQrcode'); $condition_login_qrcode['id'] = input('get.qrcode_id'); if(empty($condition_login_qrcode['id'])){ return $this->returnJson('未获取到qrcode_id!',0); } $now_qrcode = $database_login_qrcode->field('`uid`')->where($condition_login_qrcode)->find(); if (!empty($now_qrcode['uid'])) { if ($now_qrcode['uid'] == -1) { $data_login_qrcode['uid'] = 0; $database_login_qrcode->where($condition_login_qrcode)->isUpdate(true)->save($data_login_qrcode); return $this->returnJson('请在微信公众号点击授权登录!',0); } $database_login_qrcode->where($condition_login_qrcode)->delete(); $result = model('Member')->autologin('id', $now_qrcode['uid']); if (empty($result['error_code'])) { return $this->returnJson('登录成功!',1,$result['user']); } else if ($result['error_code'] == 1001) { return $this->returnJson('没有查找到用户,请重新扫描二维码!',0); } else if ($result['error_code']) { return $this->returnJson('登陆失败!',0); } } if ($i == 5) { return $this->returnJson('登陆失败',0); } sleep(3); } }
Sie können sehen, dass die obige Methode die qrcode_id erhält, die in 1 zurückgegebene ID, und die andere Rückgabe ist der QR-Code.
Der Rotationstrainingsprozess besteht darin, diese ID zu verwenden, um den Status der Tabelle login_qrcode kontinuierlich zu überprüfen. Wenn die UID vorhanden ist, beweist dies, dass die Anmeldung erfolgreich war! Mit der UID können Sie sich automatisch anmelden.
4. Der Schlüssel zu dem oben genannten
ist, dass die Zwischentabelle login_qrcode als Brücke dient. Sie wird gleichzeitig zum Generieren von QR-Codes und zum Einfügen von Benutzer-UIDs verwendet , die PC-Seite erkennt die Tabelle. Die Statusänderung ermöglicht die Anmeldung.
Verwandte Empfehlungen:
Das obige ist der detaillierte Inhalt vonPHP implementiert die gemeinsame Nutzung von WeChat-PC-QR-Code-Anmeldecodes. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!