在微信中,需要鉴别用户身份的常用做法是什么?当然是微信授权,获取用户的openid进行确认身份。
如果是h5网页,那么需要使用微信公众号提供的网页授权接口实现,如果是小程序那就好办,个人小程序的 wx.login
接口也可以获取openid,那么问题来了,微信公众号提供的网页授权只有认证的服务号才有权限,个人根本没机会使用,这便是门槛。
但是我发现,企业微信的接口,个人也可以使用网页授权链接实现获取用户的openid,即便你的网页不是在企业微信环境下使用,也是可以获取到用户的openid,本次文章就是我要实现的。
准备
1、登录企业微信;
2、创建一个应用;
3、创建完毕之后,进入应用,获取 AgentId
和 Secret
4、获取 appid
以上3个参数准备好,就可以用代码实现了。
getCode.php
<?php
// 获取访问令牌的函数
function getAccessToken($corpid, $corpsecret) {
$url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=$corpid&corpsecret=$corpsecret";
$response = file_get_contents($url);
$data = json_decode($response, true);
if(isset($data['access_token'])) {
return $data['access_token'];
} else {
// 处理错误
return false;
}
}
// 从数组中检索访问令牌的函数
function getCachedAccessToken() {
if(file_exists('access_token.php')) {
include 'access_token.php';
return $access_token_data['access_token'];
} else {
// 如果文件不存在,返回空字符串
return '';
}
}
// 检查访问令牌是否过期的函数
function isAccessTokenExpired() {
if(file_exists('access_token.php')) {
include 'access_token.php';
return $access_token_data['expires_at'] < time();
} else {
// 如果文件不存在,返回 true 表示过期
return true;
}
}
// 将访问令牌保存到数组中的函数
function saveAccessToken($access_token) {
$access_token_data = array(
'access_token' => $access_token, // 设置访问令牌
'expires_at' => time() + 7200 // 设置过期时间为2小时后
);
file_put_contents('access_token.php', '<?php $access_token_data = ' . var_export($access_token_data, true) . ';');
}
// 你的企业微信 API 凭证
$corpid = '你的企业微信appid';
$corpsecret = '你的企业微信所创建的应用的Secret';
// 检查访问令牌是否过期或未缓存
if(isAccessTokenExpired()) {
// 从企业微信 API 获取新的访问令牌
$access_token = getAccessToken($corpid, $corpsecret);
if($access_token) {
// 将访问令牌保存到数组中
saveAccessToken($access_token);
} else {
// 处理错误
die("从企业微信 API 获取访问令牌失败。");
}
}
// 获取用户信息
function getUserInfo($access_token, $code) {
$url = "https://qyapi.weixin.qq.com/cgi-bin/auth/getuserinfo?access_token=$access_token&code=$code";
$response = file_get_contents($url);
$data = json_decode($response, true);
return $data;
}
// 从数组中检索访问令牌
$access_token = getCachedAccessToken();
// code
$code = $_GET['code'];
$userInfo = getUserInfo($access_token, $code);
if($userInfo['errcode'] == 0) {
// 判断当前是userid还是openid
if($userInfo['userid']) {
// userid
$openid = $userInfo['userid'];
}else {
// openid
$openid = $userInfo['openid'];
}
// 跳转到展示页面
echo '<script>location.href="showOpenid.php?openid='.$openid.'";</script>';
}else {
// 错误
echo $userInfo['errmsg'];
}
?>
<meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=0,viewport-fit=cover">
以上代码两处需要配置,这两处已经在上面准备阶段获取到了。
// 你的企业微信 API 凭证
$corpid = '你的企业微信appid';
$corpsecret = '你的企业微信所创建的应用的Secret';
showOpenid.php
<html>
<head>
<title>展示页面</title>
<meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=0,viewport-fit=cover">
</head>
<body>
<p style="width:90%;margin: 50px auto 0;text-align:center;padding:20px 5px;border:2px dashed #ccc;">
<?php
echo $_GET['openid'];
?>
</p>
</body>
</html>
以上两个php文件上传至你服务器即可。例如你的域名是:
https://www.qq.com
你将 getCode.php
和 showOpenid.php
上传至根目录下的 Auth
目录。
那么继续往下看:
构造网页授权链接
根据官方API文档可知:
构造格式如下:
https://open.weixin.qq.com/connect/oauth2/authorize?appid=CORPID&redirect_uri=REDIRECT_URI&response_type=code&scope=snsapi_base&state=STATE&agentid=AGENTID#wechat_redirect
CORPID: 替换为你的appid
redirect_uri: 替换为getCode.php页面的链接
AGENTID: 替换为你的AgentId
假设你的CORPID是:ww1f1289a1254d49b2
假设你的AGENTID是:1000002
最终的网页授权链接如下:
https://open.weixin.qq.com/connect/oauth2/authorize?appid=ww1f1289a1254d49b2&redirect_uri=https://www.qq.com/Auth/getCode.php&response_type=code&scope=snsapi_base&state=STATE&agentid=1000002#wechat_redirect
还要去配置一下网页授权的域名(应用管理点进去往下拉-网页授权及JS-SDK)
配置完授权域名后,也要配置信任IP,不然会提示你从不被允许的IP访问
将构造完成的链接发到微信:
点击即可获取到openid了!
注意:如果你用登录企业微信的微信扫码,可能就不是获取到openid了,而是获取到userid,因为文档说了,当用户为企业成员时(无论是否在应用可见范围之内)返回示例如下:
所以你要测试的话得找个不是你的企业微信成员的微信进行扫码,才可以看到openid,所以这一块要注意,你以后的业务逻辑也是需要对这一块进行特殊处理。
评论 (0)