1、用户同意授权,获取code
String redirecturi = HttpUtil.urlEnCode(domain + aliPay + QRCodeUrl);
SysPayChannel channel = payChannelService.selectByChannelType(PayTypeConstant.Alipay);
MyAliPayConfig aliPayConfig = new MyAliPayConfig();
aliPayConfig.setAppId(channel.getAppid());
// 授权页面地址
String requestUrl = aliPayConfig.getAuthgateway();
requestUrl = requestUrl.replace("APPID", aliPayConfig.getAppId()).replace("SCOPE", aliPayConfig.getScope()).replace("REDIRECT_URI", redirecturi);
// 重定向到授权页面
response.sendRedirect(requestUrl);
2、通过code,获取openid
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
//用户同意授权后,能获取到code
String code = request.getParameter("auth_code");
String aliuserid = "";
if (!redisService.exists(code)){
//用户同意授权
if (!code.equals("")) {
SysPayChannel channel = payChannelService.selectByChannelType(PayTypeConstant.Alipay);
MyAliPayConfig aliPayConfig = new MyAliPayConfig();
aliPayConfig.setAppId(channel.getAppid());
String certsrc = channel.getPayCertUrl();
Properties propertiesFile = PropertiesUtils.getPropertiesFile(certsrc);
if (propertiesFile != null) {
aliPayConfig.setPayeeAccount(propertiesFile.getProperty("ALI_PAYEE_ACCOUNT"));
aliPayConfig.setAppId(propertiesFile.getProperty("ALI_APP_ID"));
aliPayConfig.setAliPayPublicKey(propertiesFile.getProperty("ALI_ALIPAY_PUBLIC_KEY"));
aliPayConfig.setAppPayPublicKey(propertiesFile.getProperty("ALI_APP_PAY_PUBLIC_KEY"));
aliPayConfig.setAppPrivateKey(propertiesFile.getProperty("ALI_APP_PRIVATE_KEY"));
}
//获取网页授权access_token
AliPayOAuth2Token aliPayOAuth2Token = AliPayOAuth2Util.getOAuth2AccessToken(aliPayConfig,code);
//网页授权接口访问凭证
String accessToken = aliPayOAuth2Token.getAccessToken();
//用户标识
aliuserid = aliPayOAuth2Token.getUserid();
//aliuserid
redisService.setex(code, 60, aliuserid);
}
} else {
aliuserid = redisService.get(code);
}
3、解决刷新网页code过期
因为当通过auth_code来获取aliuserid时,auth_code只能使用一次,这里用了一个小技巧来解决刷新网页auth_code过期。当第一次获取到aliuserid时,将aliuserid缓存起来,刷新时会判断,如果aliuserid存在,就不用通过codeauth_code获取aliuserid了。当然这两行代码还有值得注意的地方就是缓存的key为auth_code值。