微信开发---->网页授权



第一步:用户同意授权,获取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

//1.获取code
		String code = request.getParameter("code");
		System.out.println("code33 + "+code);
		//2.通过code获取授权accessToken
		Map 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 param2 = new LinkedHashMap();
		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);
第二步:通过code换取网页授权access_token

根据上一步获得的code,使用get方法打开链接https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code
替代其中的code


其中获得网页的code后就可以根据开发文档执行相应的连接获得返回的数据,再通过gson处理数据

你可能感兴趣的:(微信开发---->网页授权)