最近在调试微门户,需要获取微信openid,使用企业号的时候获取openid没有报错,同样的方法微信公众号获取的时候就报40163错误即code重复使用,百度了一下,基本没有正面回复,今天无意之间看到一条回复,说是使用了动态链接的原因,验证了下,果然正确,记之。
第一次将地址链接替换后第二次再调用的时候还是用的上一次的地址
private static final String APPID = "??";private static final String SECRET = "??";
private String requestUrl = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code";
@RequestMapping("/getOpenid")
public String getOpenid(HttpServletRequest request, HttpServletResponse response) {
String path = (String) request.getSession().getAttribute("reqPath");
// 用户同意授权后,能获取到code
String code = request.getParameter("code");
// 获取网页授权access_token
JSONObject object = getOauth2AccessToken(APPID, SECRET, code);
request.getSession().setAttribute("openid", object.getString("openid"));
return "redirect:" + path;
}
public JSONObject getOauth2AccessToken(String appId, String appSecret, String code) {
// 拼接请求地址
requestUrl = requestUrl.replace("APPID", appId).replace("SECRET", appSecret).replace("CODE", code);
// 获取网页授权凭证
JSONObject jsonObject = null;
try {
jsonObject = HttpUtil.getJsonForGet(requestUrl);
} catch (ParseException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return jsonObject;
}