第一步:用户同意授权,获取code
使用get方法打开url
https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect
其中appid为自己的id 、
redirect_uri为自己回调的页面,code会带在这个页面链接的后面
response-type为code
Scope为应用授权作用域,snsapi_base (不弹出授权页面,直接跳转,只能获取用户openid),snsapi_userinfo (弹出授权页面,可通过openid拿到昵称、性别、所在地。并且,即使在未关注的情况下,只要用户授权,也能获取其信息)
State为STATE
后面其余的参数不变
使用一个Servlet接受返回的code值转发传过来的连接
response.sendRedirect("https://open.weixin.qq.com/connect/oauth2/authorize?appid=" + ConstansUtil.getAppid()
+ "&redirect_uri=" + URLEncoder.encode(ConstansUtil.REDIRECT_URI) + "&response_type=code&scope="
+ ConstansUtil.SCOPE + "&state=123#wechat_redirect");
再通过另一个Servlet接受code
<u>//1.获取code
String code = request.getParameter("code");
System.out.println("code33 + "+code);
//2.通过code获取授权accessToken
Map<String, String> htmlmap = ConstansUtil.getHTMLAccessTokenMap(code);
String htmlaccesstoken = htmlmap.get("HTML_access_token");
//System.out.println("HTML_access_token"+htmlaccesstoken);
String openid = htmlmap.get("openid");
//3.超时 刷新accesstoken
//4.获取用户信息
//access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN
LinkedHashMap<String, String> param2 = new LinkedHashMap<String, String>();
param2.put("access_token", htmlaccesstoken);
param2.put("openid", openid);
param2.put("lang", "zh_CN");
String userinfo_json = WXInterfaceUtil.getByUrl(ConstansUtil.GET_USER_INFO, param2);
System.out.println("用户信息json"+userinfo_json);
//application
ServletContext servletContext = request.getServletContext();
servletContext.setAttribute("userinfo_json", userinfo_json);
response.getWriter().write(userinfo_json);</u>
第二步:通过code换取网页授权access_token