一、前沿:很多时候,我们都需要开发微信功能来实现我们的项目的功能逻辑,微信授权登陆方面的肯定也不少,所以我就封装了个简单的方法来实现,以方便后面使用。
目前创新互联公司已为数千家的企业提供了网站建设、域名、虚拟空间、网站托管、企业网站设计、万源网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。
二、流程文档
微信开发者文档:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1445241432
大概就是5个步骤:
1 :用户同意授权,获取code
2 :通过code换取网页授权access_token
3 :刷新access_token(如果需要)
4 :拉取用户信息(需scope为 snsapi_userinfo)
5: 附:检验授权凭证(access_token)是否有效
三、完善参考代码
/**
* 微信授权相关接口
*/
namespace Home\Controller;
use Think\Controller;
class WechatController extends Controller {
public $appid = ''; //微信APPID,公众平台配置文件
public $appsecret = ''; //微信APPSECREC,公众平台配置文件
public $index_url = "http://www.你的域名.cn/项目目录/index.php?m=分组&c=控制器&a=方法"; //微信回调地址,要跟公众平台的配置域名相同
public $code;
public $openid;
//初始化方法
public function _initialize()
{
if (!$_SESSION['openid']) { //如果$_SESSION中没有openid,说明用户刚刚登陆,就执行getCode、getOpenId、getUserInfo获取他的信息
$this->code = $this->getCode(); //获取code
$this->access_token = $this->getOpenId(); //获取access_token
$userInfo = $this->getUserInfo(); //获取用户微信信息
if ($userInfo) { //假设逻辑处理
$ins = M('Wechat_user_info');
$map['openid'] = $userInfo['openid'];
$result = $ins->where($map)->find();
if (!$result) {
$ins->add($userInfo);
}
session('openid', $userInfo['openid']); //写到$_SESSION中。微信缓存很坑爹,调试时请及时清除缓存再试。
}
}
}
/**
* @explain
* 获取code,用于获取openid和access_token
* @remark
* code只能使用一次,当获取到之后code失效,再次获取需要重新进入
* 不会弹出授权页面,适用于关注公众号后自定义菜单跳转等,如果不关注,那么只能获取openid
**/
public function getCode()
{
if (isset($_GET["code"])) {
return $_GET["code"];
} else {
$str = "location: https://open.weixin.qq.com/connect/oauth3/authorize?appid=" . $this->appid . "&redirect_uri=" . $this->index_url . "&response_type=code&scope=snsapi_userinfo&state=1#wechat_redirect";
header($str);
exit;
}
}
/**
* @explain
* 用于获取用户openid
**/
public function getOpenId()
{
$access_token_url = "https://api.weixin.qq.com/sns/oauth3/access_token?appid=" . $this->appid . "&secret=" . $this->appsecret . "&code=" . $this->code . "&grant_type=authorization_code";
$access_token_json = $this->https_request($access_token_url);
$access_token_array = json_decode($access_token_json, TRUE);
return $access_token_array;
}
/**
* @explain
* 通过code获取用户openid以及用户的微信号信息
* @return
* @remark
* 获取到用户的openid之后可以判断用户是否有数据,可以直接跳过获取access_token,也可以继续获取access_token
* access_token每日获取次数是有限制的,access_token有时间限制,可以存储到数据库7200s. 7200s后access_token失效
**/
public function getUserInfo()
{
$userinfo_url = "https://api.weixin.qq.com/sns/userinfo?access_token=".$this->access_token['access_token'] ."&openid=" . $this->access_token['openid']."&lang=zh_CN";
$userinfo_json = $this->https_request($userinfo_url);
$userinfo_array = json_decode($userinfo_json, TRUE);
return $userinfo_array;
}
/**
* @explain
* 发送http请求,并返回数据
**/
public function https_request($url, $data = null)
{
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
if (!empty($data)) {
curl_setopt($curl, CURLOPT_POST, 1);
curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
}
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$output = curl_exec($curl);
curl_close($curl);
return $output;
}
}