前言
现在微信登录是一个网站、APP的标配,所以微信授权登录是我们应该要掌握的。微信授权登录有4种方式:
1、通过微信开放平台
2、通过认证的微信服务号
3、通过认证的微信订阅号
4、通过微信小程序曲线救国
今天我们就讲解的是微信服务号,通过OAuth2.0机制网页授权登录,获取用户基本信息。
流程
1、获取code
2、获取access_token
3、获取用户基本信息
获取code
通过以下接口即可获得,参数说明:
https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect
以上链接进行配置后,进行点击访问或跳转。
配置例子:
https://open.weixin.qq.com/connect/oauth2/authorize?appid=你公众号的APPID&redirect_uri=你服务器的接收code的页面链接&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect
点击允许,将会开始获取code,并且跳转到你的redirect_uri,redirect_uri就是你要接收code的页面。
redirect_uri代码可以这样写,getcode.php
<?php
header("Content-type:text/html;charset=utf-8");
$code = $_GET["code"];
echo $code;
?>
例如你的服务器域名是www.abc.com,你的代码放在服务器的wx目录下,那么你的redirect_uri应该是:
http://www.abc.com/wx/getcode.php
最后,你在微信内点击上面获取code的链接,那么就会弹窗问你是否允许获取用户信息的了。
允许后,就跳转到getcode.php进行下一步的操作。
获取access_token
通过以下接口可以获得,参数说明:
https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code
上面所需的参数基本都有,APPID、APPSECRET是你服务号的,CODE上面已经获取到了,那么直接请求接口,就能获得access_token了。
下面getcode.php页面的:
<?php
header("Content-type:text/html;charset=utf-8");
$code = $_GET["code"];
$appid = "你公众号的APPID";
$appsecret = "你公众号的APPSECRET";
$url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=".$appid."&secret=".$appsecret."&code=".$code."&grant_type=authorization_code ";
//发起请求
$getopenid = file_get_contents($url);
$getopenid_arr = json_decode($getopenid, true);
$openid = $getopenid_arr["openid"];
$access_token = $getopenid_arr["access_token"];
?>
以上代码直接就可以返回openid和access_token了,接下来直接通过另一个接口,就可以获得用户基本信息。
获取用户基本信息(头像、昵称)
通过以下接口即可获得,参数说明:
https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN
代码我就不上了,跟上面的请求方式是一样的。
扫码登录实现流程
我们上一步获得的access_token需要进行缓存,因为它是会失效的,我们应该进行缓存到服务器或者数据库,openid也是要储存到数据库。
1、在储存到数据库前,先查询数据库是否存在这个用户的openid,如果有,直接更新这个用户的信息,并且返回登录成功。如果没有,则初始化一条数据进去。
2、然后浏览器轮询这条数据的登录状态,如果用户扫码登录,获得头像和昵称,那么就把头像和昵称更新到刚才初始化的数据当中,如果还没有扫码登录,则一直在轮询,直到扫码登录后就停止轮询,建议设置一个过期时间,防止轮询时间过长造成服务器的不良。
作者
Author:TANKING
Date:2020-2-20
Web:LIKEYUNBA.COM
WeChat:face6009
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。