WxaUserApiController.java
3.18 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
package com.rnt.controller;
import com.jfinal.aop.Duang;
import com.jfinal.kit.Kv;
import com.jfinal.kit.StrKit;
import com.jfinal.weixin.sdk.api.ApiConfigKit;
import com.jfinal.weixin.sdk.api.ApiResult;
import com.jfinal.weixin.sdk.cache.IAccessTokenCache;
import com.jfinal.wxaapp.api.WxaUserApi;
import com.jfinal.wxaapp.jfinal.WxaController;
/**
* 微信小程序用户api接口
* @author L.cm
*/
public class WxaUserApiController extends WxaController {
// 微信用户接口api
protected WxaUserApi wxaUserApi = Duang.duang(WxaUserApi.class);
/**
* 登陆接口
*/
public void login() {
String jsCode = getPara("code");
if (StrKit.isBlank(jsCode)) {
Kv data = Kv.by("errcode", 500)
.set("errmsg", "code is blank");
renderJson(data);
return;
}
// 获取SessionKey
ApiResult apiResult = wxaUserApi.getSessionKey(jsCode);
// 返回{"session_key":"nzoqhc3OnwHzeTxJs+inbQ==","expires_in":2592000,"openid":"oVBkZ0aYgDMDIywRdgPW8-joxXc4"}
if (!apiResult.isSucceed()) {
renderJson(apiResult.getJson());
return;
}
// 利用 appId 与 accessToken 建立关联,支持多账户
IAccessTokenCache accessTokenCache = ApiConfigKit.getAccessTokenCache();
String sessionId = StrKit.getRandomUUID();
accessTokenCache.set("wxa:session:" + sessionId, apiResult.getJson());
renderJson("sessionId", sessionId);
}
/**
* 服务端解密用户信息接口
* 获取unionId
*/
public void info() {
String signature = getPara("signature");
String rawData = getPara("rawData");
String encryptedData = getPara("encryptedData");
String iv = getPara("iv");
// 参数空校验 不做演示
// 利用 appId 与 accessToken 建立关联,支持多账户
IAccessTokenCache accessTokenCache = ApiConfigKit.getAccessTokenCache();
String sessionId = getHeader("wxa-sessionid");
if (StrKit.isBlank(sessionId)) {
Kv data = Kv.by("errcode", 500)
.set("errmsg", "wxa_session Header is blank");
renderJson(data);
return;
}
String sessionJson = accessTokenCache.get("wxa:session:" + sessionId);
if (StrKit.isBlank(sessionJson)) {
Kv data = Kv.by("errcode", 500)
.set("errmsg", "wxa_session sessionJson is blank");
renderJson(data);
return;
}
ApiResult sessionResult = ApiResult.create(sessionJson);
// 获取sessionKey
String sessionKey = sessionResult.get("session_key");
if (StrKit.isBlank(sessionKey)) {
Kv data = Kv.by("errcode", 500)
.set("errmsg", "sessionKey is blank");
renderJson(data);
return;
}
// 用户信息校验
boolean check = wxaUserApi.checkUserInfo(sessionKey, rawData, signature);
if (!check) {
Kv data = Kv.by("errcode", 500)
.set("errmsg", "UserInfo check fail");
renderJson(data);
return;
}
// 服务端解密用户信息
ApiResult apiResult = wxaUserApi.getUserInfo(sessionKey, encryptedData, iv);
if (!apiResult.isSucceed()) {
renderJson(apiResult.getJson());
return;
}
// 如果开发者拥有多个移动应用、网站应用、和公众帐号(包括小程序),可通过unionid来区分用户的唯一性
// 同一用户,对同一个微信开放平台下的不同应用,unionid是相同的。
String unionId = apiResult.get("unionId");
renderJson("{}");
}
}