博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SAE+Servlet+JSP实现微信公众平台OAuth2.0网页授权的使用
阅读量:6494 次
发布时间:2019-06-24

本文共 3067 字,大约阅读时间需要 10 分钟。

本帖最后由 王绪超丶 于 2014-5-23 08:36 编辑
一、微信公众号的申请
   略。(本篇为高级接口,连微信公众号都不会申请,那看这个也没用)
二、SAE平台创建应用
   其他帖子里有,比如→。我也不赘述了。
三、OAuth2.0接口的申请
   推荐使用官方的测试账号:申请地址→这里
四、进入正题
官方API我就不说了,直接说些重要地方!
1、网页授权回调域名
通俗地讲就是你的公众平台项目部署的地方,如果你实在SAE创建的话,下面一般填:xxxx.sinaapp.com
为什么要写这个呢,因为所有在这个链接的页面都可以调用OAuth2.0网络授权这个接口。
ps:xxxx为你再SAE上部署的应用的名字,前面不要加http://

2、授权回调请求处理程序

如果要在网页中得到用户信息,就必须先引导用户进入网页授权页面;用户同意授权后会跳转到回调地址redirect_uri,redirect_uri是授权回调请求处理程序的访问地址;在处理程序中,开发者能获得code,再通过code获取access_token,最终得到用户信息。

  授权回调请求处理程序部分代码如下:

public class OAuthServlet extends HttpServlet {private static final long serialVersionUID = -1847238807216447030L;[/align][align=left] public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {  request.setCharacterEncoding("gb2312");  response.setCharacterEncoding("gb2312");[/align][align=left]  // 用户同意授权后,能获取到code  String code = request.getParameter("code");[/align][align=left]  // 用户同意授权  if (!"authdeny".equals(code)) {   // 获取网页授权access_token   WeixinOauth2Token weixinOauth2Token = AdvancedUtil.getOauth2AccessToken("APPID", "APPSECRET", code);   // 网页授权接口访问凭证   String accessToken = weixinOauth2Token.getAccessToken();   // 用户标识   String openId = weixinOauth2Token.getOpenId();   // 获取用户信息   SNSUserInfo snsUserInfo = AdvancedUtil.getSNSUserInfo(accessToken, openId);[/align][align=left]   // 设置要传递的参数   request.setAttribute("snsUserInfo", snsUserInfo);  }  // 跳转到index.jsp  request.getRequestDispatcher("index.jsp").forward(request, response);}}
web.xml如下

oauthServlet
org.liufeng.course.servlet.OAuthServlet
oauthServlet
/oauthServlet
[/align][align=left]
index.jsp

3、编写目标页面

用户授权完成后,会通过redirect_uri跳转到目标页面 index.jsp,代码如下:

<%@ page language="java" pageEncoding="gb2312"%><%@ page import="org.liufeng.course.pojo.SNSUserInfo;"%>OAuth2.0网页授权
<% // 获取由OAuthServlet中传入的参数 SNSUserInfo user = (SNSUserInfo)request.getAttribute("snsUserInfo"); if(null != user) {%>
属性
OpenID <%=user.getOpenId()%>
昵称 <%=user.getNickname()%>
性别 <%=user.getSex()%>
国家 <%=user.getCountry()%>
省份 <%=user.getProvince()%>
城市 <%=user.getCity()%>
头像 <%=user.getHeadImgUrl()%>
特权 <%=user.getPrivilegeList()%>
<% } else out.print("用户不同意授权,未获取到用户信息!");%>

4、网络授权链接

https://open.weixin.qq.com/connect/oauth2/authorize?appid=wx5d2523ead18e4d17&redirect_uri=http%3A%2F%2Fxxxx.sinaapp.com%2FoauthServlet&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect

红色部分为你微信公众平台申请接口时的appid,当然这个是我随便写的!黑色部分就是你们在sae部署的项目的地址:http://xxxx.sinaapp.com/oauthServlet,不过进行了URL编码(utf-8)

编码规律(本人自己总结的):    :  -->  %3A

                                                  /  -->   %2F

其他不变。

你可以把这个授权链接放到菜单里,也可以直接发给用户,不过他们看到这么长会吓死吧!

最后还是得谢谢峰哥的教程,真赞!

下面是本人亲测的截图:

 好多求源码的,我贴个链接:http://url.cn/JE0h9i (密码:z3Mj),来自柳峰的书中第六章  

你可能感兴趣的文章
大白话Vue源码系列目录
查看>>
EffectKeyMap系列1(Ubuntu)
查看>>
iOS手势
查看>>
Webpack源码基础-Tapable从使用Hook到源码解析
查看>>
【转载】NBU异机恢复oracle
查看>>
魅族mx5详细打开usb调试模式的步骤
查看>>
php里关于文件下载的方法(两种)
查看>>
数据绑定(数据源控件 -- ObjectDataSource)
查看>>
微信点单
查看>>
selenium操作页面元素总结
查看>>
vim 命令
查看>>
Ubuntu 16.04 LTS安装sogou输入法详解
查看>>
计算几何专题
查看>>
GNU/Linux 正则表达式与三剑侠(grep,sed,awk)(精)
查看>>
36、自定义控件详解(一)-- 自定义属性
查看>>
DOM学习笔记二
查看>>
[Array]189. Rotate Array
查看>>
iuap
查看>>
inkscape
查看>>
关于C语言中单双引号的问题
查看>>