微信开发交流群:148540125html
系列文章参考地址 极速开发微信公众号
欢迎留言、转发、打赏git
项目源码参考地址 点我点我--欢迎Start数据库
前几篇文章已讲完如何导入项目,如何启动配置项目,如何成为开发者,重源码分析消息是如何交互、如何自定义菜单(若是以上不是很清楚能够看这里 极速开发微信公众号。这篇文章就来聊聊受权获取用户信息json
这里整理了一篇文章 理解OAuth2.0api
沙盒号(测试号)回调地址支持域名和ip,正式公众号回调地址只支持域名而且域名需使用字母、数字及“-”的组合,须经过ICP备案的验证,不支持端口号及短链。服务器
测试号:找到 网页受权获取用户基本信息>点击修改>设置域名
服务号:找到 开发>接口权限>网页受权获取用户基本信息>>点击修改>设置域名
微信
详细介绍参考官方文档微信开发
受权访问的URL:app
具体封装实现能够查看com.jfinal.weixin.sdk.api.SnsAccessTokenApi.getAuthorizeURL(....)
方法
以前博客使用Servlet 也写了一个简单的受权参考地址
封装以后使用就很是的简单,SnsAccessTokenApi.getAuthorizeURL(....)
appId
http://域名/oauth
state
重定向后会带上state参数,开发者能够填写a-zA-Z0-9的参数值,最多128字节 第四个参数 应用受权做用域,简单讲是否弹出受权页面 。 true
为不弹出受权页面应用受权做用域,snsapi_base (不弹出受权页面,直接跳转,只能获取用户openid),snsapi_userinfo (弹出受权页面,可经过openid拿到昵称、性别、所在地。而且,即便在未关注的状况下,只要用户受权,也能获取其信息)
具体实现代码以下
//跳转到受权页面 public void toOauth(){ String calbackUrl=PropKit.get("domain")+"/oauth"; String url=SnsAccessTokenApi.getAuthorizeURL(PropKit.get("appId"), calbackUrl, "111",false); redirect(url); }
oauth Controller 具体实现步骤以下:
{ "access_token":"ACCESS_TOKEN", "expires_in":7200, "refresh_token":"REFRESH_TOKEN", "openid":"OPENID", "scope":"SCOPE" }
{ "openid":" OPENID", " nickname": NICKNAME, "sex":"1", "province":"PROVINCE" "city":"CITY", "country":"COUNTRY", "headimgurl": "http://wx.qlogo.cn/mmopen/g3MonUZtNHkdmzicIlibx6iaFqAc56vxLSUfpb6n5WKSYVY0ChQKkiaJSgQ1dZuTOgvLLrhJbERQQ 4eMsv84eavHiaiceqxibJxCfHe/46", "privilege":[ "PRIVILEGE1" "PRIVILEGE2" ], "unionid": "o6_bmasdasdsad6_2sgVt7hMZOPfL" }
具体实现代码以下
public class WeiXinOauthController extends ApiController{ static Log log = Log.getLog(WeiXinOauthController.class); /** * 若是要支持多公众帐号,只须要在此返回各个公众号对应的 ApiConfig 对象便可 * 能够经过在请求 url 中挂参数来动态从数据库中获取 ApiConfig 属性值 */ public ApiConfig getApiConfig() { ApiConfig ac = new ApiConfig(); // 配置微信 API 相关常量 ac.setToken(PropKit.get("token")); ac.setAppId(PropKit.get("appId")); ac.setAppSecret(PropKit.get("appSecret")); /** * 是否对消息进行加密,对应于微信平台的消息加解密方式: * 1:true进行加密且必须配置 encodingAesKey * 2:false采用明文模式,同时也支持混合模式 */ ac.setEncryptMessage(PropKit.getBoolean("encryptMessage", false)); ac.setEncodingAesKey(PropKit.get("encodingAesKey", "setting it in config file")); return ac; } public void index() { int subscribe=0; //用户赞成受权,获取code String code=getPara("code"); String state=getPara("state"); if (code!=null) { String appId=ApiConfigKit.getApiConfig().getAppId(); String secret=ApiConfigKit.getApiConfig().getAppSecret(); //经过code换取网页受权access_token SnsAccessToken snsAccessToken=SnsAccessTokenApi.getSnsAccessToken(appId,secret,code); // String json=snsAccessToken.getJson(); String token=snsAccessToken.getAccessToken(); String openId=snsAccessToken.getOpenid(); //拉取用户信息(需scope为 snsapi_userinfo) ApiResult apiResult=SnsApi.getUserInfo(token, openId); log.warn("getUserInfo:"+apiResult.getJson()); if (apiResult.isSucceed()) { JSONObject jsonObject=JSON.parseObject(apiResult.getJson()); String nickName=jsonObject.getString("nickname"); //用户的性别,值为1时是男性,值为2时是女性,值为0时是未知 int sex=jsonObject.getIntValue("sex"); String city=jsonObject.getString("city");//城市 String province=jsonObject.getString("province");//省份 String country=jsonObject.getString("country");//国家 String headimgurl=jsonObject.getString("headimgurl"); String unionid=jsonObject.getString("unionid"); //获取用户信息判断是否关注 ApiResult userInfo = UserApi.getUserInfo(openId); log.warn(JsonKit.toJson("is subsribe>>"+userInfo)); if (userInfo.isSucceed()) { String userStr = userInfo.toString(); subscribe=JSON.parseObject(userStr).getIntValue("subscribe"); } Users.me.save(openId, WeiXinUtils.filterWeixinEmoji(nickName), unionid, headimgurl, country, city, province, sex); } setSessionAttr("openId", openId); if (subscribe==0) { redirect(PropKit.get("subscribe_rul")); }else { //根据state 跳转到不一样的页面 if (state.equals("2222")) { redirect("http://www.cnblogs.com/zyw-205520/"); }else { redirect("/login"); } } }else { renderText("code is null"); } } }
以上是受权获取用户信息的全过程。
欢迎留言、转发、打赏
项目源码参考地址 点我点我--欢迎Start