1、用户同意授权,获取code
String RequestURL = request.getRequestURL().toString();
String redirecturi = HttpUtil.urlEnCode(domain + rankingList);
WXPublicConfig publicConfig = new WXPublicConfig();
// 授权页面地址
String requestUrl = publicConfig.getAuthorizeinterface();
requestUrl = requestUrl.replace("APPID", publicConfig.getAppId()).replace("REDIRECT_URI", redirecturi).replace("SCOPE", publicConfig.getScope()).replace("STATE", publicConfig.getState());
// 重定向到授权页面
response.sendRedirect(requestUrl);
2、通过code,获取openid
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
// 用户同意授权后,能获取到code
String code = request.getParameter("code");
String openId = "";
if (!redisService.exists(code)){
// 用户同意授权
if (!"authdeny".equals(code)) {
WXPublicConfig publicConfig = new WXPublicConfig();
// 获取网页授权access_token
WeiXinOAuth2Token weixinOauth2Token = WeiXinOAuth2Util.getOAuth2AccessToken(publicConfig, code);
// 网页授权接口访问凭证
String accessToken = weixinOauth2Token.getAccessToken();
// 用户标识
openId = weixinOauth2Token.getOpenId();
//缓存openId
redisService.setex(code, 60, openId);
}
} else {
openId = redisService.get(code);
}
3、解决刷新网页code过期
因为当通过code来获取openid时,code只能使用一次,这里用了一个小技巧来解决刷新网页code过期。当第一次获取到openid时,将openid缓存起来,刷新时会判断,如果openid存在,就不用通过code来获取openid了。当然这两行代码还有值得注意的地方就是缓存的key为code值。