前期准备
-
由于微信回调地址需要一个可访问的地址,所以使用内网穿透 获取到本机的一个临时域名。内网穿透
-
微信公众号开发,首先要搞一个公众号,开发阶段可以申请一个公众平台测试账号。
(进入到微信公众公众平台,找到开发者工具,点开公众平台测试账号)
获取到appId 和 appSecret
微信公众平台
将获取到的域名填写到 注意不带http
修改回调域名 这里填写临时域名 同样不带http
授权登录
利用授权码方式来授权微信登录 关于Oauth2.0和授权登录
- 请求code
function webAuthLogin() {
var appId = [[${wxConfig.appId}]];
var openId = [[${session.openId}]];
var redirectUri = [[${redirectUri}]];
if (openId == null) {
window.location.href = 'https://open.weixin.qq.com/connect/oauth2/authorize?appid='+appId +
'&redirect_uri='+redirectUri +
'&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect';
}else{
alert("您好:"+userInfo.nickname+",已经授权成功!");
}
}
redirectUri 通过这获取
- 获取到返回的code
//获取openid和access_token的连接
private static String getOpenId = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=APPSECRET&code=CODE&grant_type=authorization_code";
//获取用户基本信息的连接
private static String getUserInfo = "https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN";
@RequestMapping("getCode")
public String getCode(String code){
String getOpenIdUrl = getOpenId.replace("APPID", wxConfig.getAppId()).replace("APPSECRET", wxConfig.getAppSecret()).replace("CODE", code);
String response = HttpClientUtil.doGet(getOpenIdUrl);
JSONObject jsonObject = JSONObject.parseObject(response);
String accessToken = jsonObject.get("access_token") == null ? null :jsonObject.get("access_token").toString();
String openId = jsonObject.get("openid") == null ? null : jsonObject.get("openid").toString();
httpSession.setAttribute("accessToken",accessToken);
httpSession.setAttribute("openId",openId);
httpSession.setAttribute("userInfo",getUserInfo(openId,accessToken));
return "redirect:/";
}
这就是上面redirectUri 回调的地址 参数里面带有code 通过这里可以获取到
-
通过code去请求令牌
这里的令牌就是 通过访问getOpenId 这个链接后 返回的accessToken
有了这个令牌就可以获取到用户的信息 -
获取用户信息
//获取用户基本信息的连接
private static String getUserInfo = "https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN";
*/
private JSONObject getUserInfo(String openId,String accessToken){
String userInfoUrl = getUserInfo.replace("ACCESS_TOKEN",accessToken).replace("OPENID", openId);
String userInfo = HttpClientUtil.doGet(userInfoUrl);
JSONObject jsonObject = JSONObject.parseObject(userInfo);
return jsonObject;
}