微信扫码登陆
1 去微信开放平台创建应用
审核通过后会得到AppID和AppSecret(这两个很重要)
2 接入自己的网站
(1) 我用的是thinkphp框架,所以就用thinkphp给大家介绍
创建WxController控制器
classWxLoginControllerextendsController{
private$_appId;
private$_appSecret;
private$_webRoot;
private$_openUrlQrc;
private$_openUrlToken;
private$_openUrlUserInfo;
public function__construct()
{
$this->_appId='*********';//开放平台网站应用
$this->_appSecret='***********';
$this->_webRoot='**********';//返回的域名网址,必须跟网站应用的域名网址相同
$this->_openUrlQrc='https://open.weixin.qq.com/connect/qrconnect';//申请二维码接口
$this->_openUrlToken='https://api.weixin.qq.com/sns/oauth2/access_token';//申请token接口
$this->_openUrlUserInfo='https://api.weixin.qq.com/sns/userinfo';//申请用户信息接口
}
* 验证微信扫码后的用户数据
*/
public functionwxCheck(){
$code=I('code');//只能使用1次即销毁
$state=I('state');
if($state!=$_SESSION['wx_state']){
$this->error("请进入官网扫描二维码",'/Home/WxLogin/wxLogin');
exit();
}
session('wx_state',null);//清除这个session
//获取access_token和openid信息,还有用户唯一标识unionid
$ken=$this->wxToken($code);//:access_token,expires_in,refresh_token,openid,scope,unionid
if($ken['errcode']==40029){
$this->error("code参数已经过期");
}
//
// //判断是否已存在
$map=array(
'openid'=>$ken['openid'],
'unionid'=>$ken['unionid'],
);
$res=M('User')->field('user_id,user_name')->where(array('unionid'=>$map['unionid']))->find();//查询openid是否存在,而PC和微信端 openid不一致,只有unionid才是唯一标识
if($res){
session('user_name',$res['user_name']);//写入session
session('user_id',$res['user_id']);//写入session
}else{
$user=$this->wxUserInfo($ken['access_token'],$ken['openid']);//获取用户信息
session('unionid',$user['unionid']);
session('nickname',$user['nickname']);
session('img',$user['headimgurl']);
session('type','微信');
$this->redirect('User/qqBind');
}
$this->redirect('Index/index');
}
/**
* 提交微信登录请求
*/
public functionwxLogin(){
$stats=$this->getRandChar(16);//该参数可用于防止csrf攻击(跨站请求伪造攻击)
session('wx_state',$stats);//把随机字符串写入session,验证时对比
$url=$this->_openUrlQrc.'?appid='.$this->_appId.'&redirect_uri='.urlencode($this->_webRoot).'&response_type=code&scope=snsapi_login&state='.$stats;
redirect($url);//跳转到扫码
}
//CURL获取url返回值
functionhttpGet($url){
$oCurl=curl_init();//实例化
if(stripos($url,"https://")!==FALSE){
curl_setopt($oCurl,CURLOPT_SSL_VERIFYPEER,FALSE);
curl_setopt($oCurl,CURLOPT_SSL_VERIFYHOST,FALSE);
}
curl_setopt($oCurl,CURLOPT_URL,$url);
curl_setopt($oCurl,CURLOPT_RETURNTRANSFER,1);//是否返回值,1时给字符串,0输出到屏幕
$sContent=curl_exec($oCurl);//获得页面数据
$aStatus=curl_getinfo($oCurl);//获取CURL连接数据的信息
curl_close($oCurl);//关闭资源
//获取成功
$output_array=json_decode($sContent,true);//转换json格式
if(intval($aStatus["http_code"])==200){
return$output_array;
}else{
return false;
}
}
//获取token信息
public functionwxToken($code){
$url=$this->_openUrlToken.'?appid='.$this->_appId.'&secret='.$this->_appSecret.'&code='.$code.'&grant_type=authorization_code';
$sContent=$this->httpGet($url);//获取token数据
// dump($sContent);
return$sContent;
}
//延长token时间,默认token两个小时
public functionwxrefresh($refresh){
$url='https://api.weixin.qq.com/sns/oauth2/refresh_token?appid='.$this->_appId.'&grant_type=refresh_token&refresh_token='.$refresh;
return$this->httpGet($url);
}
//检验token授权是否有效
public functionwxchecktoken($token,$openid){
$url='https://api.weixin.qq.com/sns/auth?access_token='.$token.'&openid='.$openid;
return$this->httpGet($url);
}
//获取微信用户个人信息,但公众号和开放平台opendid 会不一样,unionid是用户唯一标识
public functionwxUserInfo($token,$openid){
$url=$this->_openUrlUserInfo.'?access_token='.$token.'&lang=zh-CN&openid='.$openid;
return$this->httpGet($url);
}
}