官方文档:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140842
1、在需要获取用户openid的网页访问(一般在首页)
https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect这个链接,各参数意义见官方文档,特别注意redirect_uri的作用和配置过程(需要在公众平台上设置->公众号设置-功能设置-网页授权域名)
2、通过第一步在页面上能获取到code,通过code访问自己服务,获取openid
服务demo
public static final String GET_OAUTH_TOKEN_URL = "https://api.weixin.qq.com/sns/oauth2/access_token";
@RequestMapping("/getOPenidByCode")
@ResponseBody
public MvcSuccessResult getOPenidByCode(String code){
logger.info("WechatOAuthController getOPenidByCode:"+code);
String url = WechatConfig.GET_OAUTH_TOKEN_URL + "?appid="+WechatConfig.APP_ID+"&secret="+WechatConfig.APP_SECRET+"&code="+code+"&grant_type=authorization_code";
try {
StringBuffer sb = HttpUtils.doURLGet(url, null);
JSONObject json = JSONObject.parseObject(sb.toString());
String openid = json.getString("openid");
logger.info("WechatOAuthController getOPenidByCode:"+sb.toString());
return new MvcSuccessResult(openid);//openid;
} catch (Exception e) {
logger.error("WechatOAuthController getOPenidByCode:"+code,e);
}
logger.error("WechatOAuthController getOPenidByCode:"+code);
return null;
}
3、获取用户详细信息可以根据第二步返回的结果json(注意第一步state参数)
StringBuffer sb;
String SNS_USERINFO_URL = "https://api.weixin.qq.com/sns/userinfo";
String url = SNS_USERINFO_URL+"?access_token="+json.getString("access_token")+"&openid="+json.getString("openid")+"&lang=zh_CN";
sb = HttpUtils.doURLGet(url, null);
logger.info("UserBookServiceImpl updateOpenId detail:"+sb.toString());