一、思路:
思路关键在于如何与微信端交互起来,毕竟目前微信登录只能是在微信端。
但是微信有一个特殊的方法用于生成自定义的二维码,这就让我们能够在PC上显示二维码,而二维码的值可以是我们定义的。另外看微信开发文档中存在一个scan事件,可以检测用户使用微信扫描二维码并获取值。其实问题的关键就在于这个值,这个值算是一个联通PC和微信的通信ID了。
二、具体实现流程
(下面代码使用了TP5的框架,有个大前提是存在一个服务号的公众号)代码如下:
控制器:
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);
}
}
}
model:
<div class="jb51code">
<pre class="brush:php;">
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'=>'<a href="https://www.jb51.cc/tag/huoqu/" target="_blank" class="keywords">获取</a><a href="https://www.jb51.cc/tag/erweima/" target="_blank" class="keywords">二维码</a><a href="https://www.jb51.cc/tag/cuowu/" target="_blank" class="keywords">错误</a>!无法写入数据到<a href="https://www.jb51.cc/tag/shujuku/" target="_blank" class="keywords">数据库</a>。请重试。'));
}
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'=>'<a href="https://www.jb51.cc/tag/huoqu/" target="_blank" class="keywords">获取</a>access_token发生<a href="https://www.jb51.cc/tag/cuowu/" target="_blank" class="keywords">错误</a>:<a href="https://www.jb51.cc/tag/cuowu/" target="_blank" class="keywords">错误</a><a href="https://www.jb51.cc/tag/daima/" target="_blank" class="keywords">代码</a>' . $access_token_array['errcode'] .',微信返回<a href="https://www.jb51.cc/tag/cuowu/" target="_blank" class="keywords">错误</a>信息:' . $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'=>'<a href="https://www.jb51.cc/tag/huoqu/" target="_blank" class="keywords">获取</a><a href="https://www.jb51.cc/tag/erweima/" target="_blank" class="keywords">二维码</a><a href="https://www.jb51.cc/tag/cuowu/" target="_blank" class="keywords">错误</a>!保存<a href="https://www.jb51.cc/tag/erweima/" target="_blank" class="keywords">二维码</a>失败。请重试。'));
}
}else{
$condition_login_qrcode['id'] = $qrcode_id;
$database_login_qrcode->where($condition_login_qrcode)->delete();
return(array('error_code'=>true,'msg'=>'发生<a href="https://www.jb51.cc/tag/cuowu/" target="_blank" class="keywords">错误</a>:<a href="https://www.jb51.cc/tag/cuowu/" target="_blank" class="keywords">错误</a><a href="https://www.jb51.cc/tag/daima/" target="_blank" class="keywords">代码</a> '.$json['errcode'].',微信返回<a href="https://www.jb51.cc/tag/cuowu/" target="_blank" class="keywords">错误</a>信息:'.$json['errmsg']));
}
}
}