forked from APIJSON/APIJSON-Demo
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDemoParser.java
More file actions
135 lines (113 loc) · 4.3 KB
/
DemoParser.java
File metadata and controls
135 lines (113 loc) · 4.3 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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
/*Copyright ©2016 TommyLemon(https://github.com/TommyLemon/APIJSON)
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.*/
package apijson.demo;
import com.alibaba.fastjson.JSONObject;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpSession;
import apijson.RequestMethod;
import apijson.StringUtil;
import apijson.boot.DemoController;
import apijson.demo.model.Privacy;
import apijson.demo.model.User;
import apijson.framework.APIJSONObjectParser;
import apijson.framework.APIJSONParser;
import apijson.framework.APIJSONVerifier;
import apijson.orm.SQLConfig;
/**请求解析器
* 具体见 https://github.com/Tencent/APIJSON/issues/38
* @author Lemon
*/
public class DemoParser extends APIJSONParser<Long> {
public static final Map<String, HttpSession> KEY_MAP;
static {
KEY_MAP = new HashMap<>();
}
public DemoParser() {
super();
}
public DemoParser(RequestMethod method) {
super(method);
}
public DemoParser(RequestMethod method, boolean needVerify) {
super(method, needVerify);
}
private int maxQueryCount = 2000;
// // 可重写来设置最大查询数量
// @Override
// public int getMaxQueryCount() {
// return maxQueryCount;
// }
//
// @Override
// public int getMaxUpdateCount() {
// return 2000;
// }
//
// @Override
// public int getMaxObjectCount() {
// return getMaxUpdateCount();
// }
//
// @Override
// public int getMaxSQLCount() {
// return getMaxUpdateCount();
// }
@Override
public JSONObject parseResponse(JSONObject request) {
try { // 内部使用,可通过这种方式来突破限制,获得更大的自由度
HttpSession session = KEY_MAP.get(request.getString("key"));
//DemoVerifier.verifyLogin(session);
if (session != null) {
request.remove("key");
maxQueryCount = 1000;
}
} catch (Exception e) {}
return super.parseResponse(request);
}
@Override
public APIJSONObjectParser<Long> createObjectParser(JSONObject request, String parentPath, SQLConfig<Long> arrayConfig
, boolean isSubquery, boolean isTable, boolean isArrayMainTable) throws Exception {
return new DemoObjectParser(getSession(), request, parentPath, arrayConfig
, isSubquery, isTable, isArrayMainTable).setMethod(getMethod()).setParser(this);
}
// 实现应用层与数据库共用账号密码,可用于多租户、SQLAuto 等 <<<<<<<<<<<<<<<<
private boolean asDBAccount;
private String dbAccount;
private String dbPassword;
@Override
public APIJSONParser<Long> setSession(HttpSession session) {
Boolean asDBAccount = (Boolean) session.getAttribute(DemoController.AS_DB_ACCOUNT);
this.asDBAccount = asDBAccount != null && asDBAccount;
if (this.asDBAccount) {
// User user = (User) session.getAttribute(DemoController.USER_);
// this.dbAccount = user.getName();
Privacy privacy = (Privacy) session.getAttribute(DemoController.PRIVACY_);
this.dbAccount = privacy.getPhone();
this.dbPassword = privacy.get__password();
}
return super.setSession(session);
}
@Override
public JSONObject executeSQL(SQLConfig<Long> config, boolean isSubquery) throws Exception {
if (asDBAccount && config instanceof DemoSQLConfig) {
DemoSQLConfig cfg = (DemoSQLConfig) config;
if (StringUtil.isEmpty(cfg.getDBAccount())) {
cfg.setDBAccount(dbAccount);
}
if (StringUtil.isEmpty(cfg.getDBPassword())) {
cfg.setDBPassword(dbPassword);
}
}
return super.executeSQL(config, isSubquery);
}
// 实现应用层与数据库共用账号密码,可用于多租户、SQLAuto 等 >>>>>>>>>>>>>>>
}