本文以PHP为例
文件1.php
<?php
// 设置微信公众号的appid (建议保存到数据库直接获取)
$appid = '********';
$redirect_uri = urlencode ( 'http://XXX你的路径XX/文件2.php' );
$url ="https://open.weixin.qq.com/connect/oauth2/authorize?appid=$appid&redirect_uri=$redirect_uri&response_type=code&scope=snsapi_base&state=1#wechat_redirect";
header("Location:".$url);
?>
文件2.php
<?php
// 开启session
session_start();
header("Content-type: text/html; charset=utf-8");
// 获取微信公众号appid和appsercet(建议保存在数据库中获取)
$appid = $row['appid'];
$secret = $row['appsecret'];
// 判断code是否获取到
if(!$_SESSION['code']){
// 防止微信自身302重定向
// 从而获取到两次code
// 导致无法获取 openid
$_SESSION['code'] = $_GET["code"];
}
date_default_timezone_set("Asia/Shanghai");
// 设置全局变量access_token
$access_token = '';
//第一步:取全局access_token
//
/**
* 先判断上一次获取到的access_token有没有过期(大于两小时)
* 如果过期,重新获取并保存至数据库 更新时间
* 否则,直接取用数据库信息
*/
$datetime2twohour = date("Y-m-d H:i:s",strtotime("-2 hour"));
// 获取到数据库保存的上一次access_token保存的时间
if(strtotime(数据库时间)>strtotime($datetime2twohour)){
// 未过期 赋值全局变量
$access_token = $row_token['access_token'];
}else{
// 已过期 重新获取
$url="https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=".$appid."&secret=".$secret;
$token = getJson($url);
$token['access_token'];
// var_dump($token);
// 赋值全局变量
$access_token = $token['access_token'];
// 获取到access_token,将其存进数据库,并更新时间
// var_dump($token);
}
//第二步:取得openid
$code = $_SESSION['code'];
$oauth2Url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=$appid&secret=$secret&code=$code&grant_type=authorization_code";
$oauth2 = getJson($oauth2Url);
// var_dump($oauth2);
//第三步:根据全局access_token和openid查询用户信息
// $access_token = $token["access_token"];
$openid = $oauth2['openid'];
$get_user_info_url = "https://api.weixin.qq.com/cgi-bin/user/info?access_token=$access_token&openid=$openid&lang=zh_CN";
$userinfo = getJson($get_user_info_url);
// //打印用户信息
print_r($userinfo);
// 这里需要清空session['code']
$_SESSION['code'] = '';
function getJson($url){
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$output = curl_exec($ch);
curl_close($ch);
return json_decode($output, true);
}
?>
至此 获取到用户信息 结束