BaseController.java 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511
  1. package com.yihu.figure.web;
  2. import com.fasterxml.jackson.databind.ObjectMapper;
  3. import com.yihu.figure.model.IdEntity;
  4. import org.apache.commons.lang3.StringUtils;
  5. import org.json.JSONArray;
  6. import org.json.JSONObject;
  7. import org.slf4j.Logger;
  8. import org.slf4j.LoggerFactory;
  9. import org.springframework.beans.factory.annotation.Autowired;
  10. import org.springframework.data.domain.Page;
  11. import org.springframework.util.ReflectionUtils;
  12. import javax.servlet.http.HttpServletRequest;
  13. import java.lang.reflect.Field;
  14. import java.util.*;
  15. public class BaseController {
  16. private static Logger logger = LoggerFactory.getLogger(BaseController.class);
  17. @Autowired
  18. protected HttpServletRequest request;
  19. /**
  20. * 獲取髮送請求用戶的uid
  21. *
  22. * @return
  23. */
  24. public String getUID() {
  25. try {
  26. String userAgent = request.getHeader("userAgent");
  27. if (StringUtils.isEmpty(userAgent)) {
  28. userAgent = request.getHeader("User-Agent");
  29. }
  30. JSONObject json = new JSONObject(userAgent);
  31. return json.getString("uid");
  32. } catch (Exception e) {
  33. return null;
  34. }
  35. }
  36. /**
  37. * 獲取髮送請求用戶的uid
  38. *
  39. * @return
  40. */
  41. public String getLastUid() {
  42. try {
  43. String userAgent = request.getHeader("userAgent");
  44. if (StringUtils.isEmpty(userAgent)) {
  45. userAgent = request.getHeader("User-Agent");
  46. }
  47. JSONObject json = new JSONObject(userAgent);
  48. return json.getString("lastUid");
  49. } catch (Exception e) {
  50. return null;
  51. }
  52. }
  53. public String getOpenid() {
  54. try {
  55. String userAgent = request.getHeader("userAgent");
  56. if (StringUtils.isEmpty(userAgent)) {
  57. userAgent = request.getHeader("User-Agent");
  58. }
  59. JSONObject json = new JSONObject(userAgent);
  60. return json.getString("openid");
  61. } catch (Exception e) {
  62. return null;
  63. }
  64. }
  65. /**
  66. * 获取用户ID
  67. *
  68. * @return
  69. */
  70. public long getId() {
  71. try {
  72. String userAgent = request.getHeader("userAgent");
  73. if (StringUtils.isEmpty(userAgent)) {
  74. userAgent = request.getHeader("User-Agent");
  75. }
  76. JSONObject json = new JSONObject(userAgent);
  77. return json.getLong("id");
  78. } catch (Exception e) {
  79. return 0;
  80. }
  81. }
  82. public String getIMEI() {
  83. try {
  84. String userAgent = request.getHeader("userAgent");
  85. if (StringUtils.isEmpty(userAgent)) {
  86. userAgent = request.getHeader("User-Agent");
  87. }
  88. JSONObject json = new JSONObject(userAgent);
  89. return json.getString("imei");
  90. } catch (Exception e) {
  91. return null;
  92. }
  93. }
  94. public String getToken() {
  95. try {
  96. String userAgent = request.getHeader("userAgent");
  97. if (StringUtils.isEmpty(userAgent)) {
  98. userAgent = request.getHeader("User-Agent");
  99. }
  100. JSONObject json = new JSONObject(userAgent);
  101. return json.getString("token");
  102. } catch (Exception e) {
  103. return null;
  104. }
  105. }
  106. public void error(Exception e) {
  107. logger.error(getClass().getName() + ":", e.getMessage());
  108. e.printStackTrace();
  109. }
  110. public void warn(Exception e) {
  111. logger.warn(getClass().getName() + ":", e.getMessage());
  112. e.printStackTrace();
  113. }
  114. public void infoMessage(String message) {
  115. logger.info(message);
  116. }
  117. /**
  118. * 返回接口处理结果
  119. *
  120. * @param code 结果码,成功为200
  121. * @param msg 结果提示信息
  122. * @return
  123. */
  124. public String error(int code, String msg) {
  125. try {
  126. Map<Object, Object> map = new HashMap<Object, Object>();
  127. ObjectMapper mapper = new ObjectMapper();
  128. map.put("status", code);
  129. map.put("msg", msg);
  130. return mapper.writeValueAsString(map);
  131. } catch (Exception e) {
  132. error(e);
  133. return null;
  134. }
  135. }
  136. /**
  137. * 接口处理成功
  138. *
  139. * @param msg
  140. * @return
  141. */
  142. public String success(String msg) {
  143. try {
  144. Map<Object, Object> map = new HashMap<Object, Object>();
  145. ObjectMapper mapper = new ObjectMapper();
  146. map.put("status", 200);
  147. map.put("msg", msg);
  148. return mapper.writeValueAsString(map);
  149. } catch (Exception e) {
  150. error(e);
  151. return null;
  152. }
  153. }
  154. public String write(int code, String msg) {
  155. try {
  156. Map<Object, Object> map = new HashMap<Object, Object>();
  157. ObjectMapper mapper = new ObjectMapper();
  158. map.put("status", code);
  159. map.put("msg", msg);
  160. return mapper.writeValueAsString(map);
  161. } catch (Exception e) {
  162. error(e);
  163. return null;
  164. }
  165. }
  166. /**
  167. * 返回接口处理结果
  168. *
  169. * @param code 结果码,成功为200
  170. * @param msg 结果提示信息
  171. * @param key 结果数据
  172. * @return
  173. */
  174. public String write(int code, String msg, String key, List<?> list) {
  175. try {
  176. Map<Object, Object> map = new HashMap<Object, Object>();
  177. ObjectMapper mapper = new ObjectMapper();
  178. map.put("status", code);
  179. map.put("msg", msg);
  180. map.put(key, list);
  181. return mapper.writeValueAsString(map);
  182. } catch (Exception e) {
  183. error(e);
  184. return error(-1, "服务器异常,请稍候再试!");
  185. }
  186. }
  187. /**
  188. * 返回接口处理结果
  189. *
  190. * @param code 结果码,成功为200
  191. * @param msg 结果提示信息
  192. * @param value 结果数据
  193. * @return
  194. */
  195. public String write(int code, String msg, String key, JSONObject value) {
  196. try {
  197. JSONObject json = new JSONObject();
  198. json.put("status", code);
  199. json.put("msg", msg);
  200. json.put(key, value);
  201. return json.toString();
  202. } catch (Exception e) {
  203. error(e);
  204. return error(-1, "服务器异常,请稍候再试!");
  205. }
  206. }
  207. /**
  208. * 返回接口处理结果
  209. *
  210. * @param code 结果码,成功为200
  211. * @param msg 结果提示信息
  212. * @param value 结果数据
  213. * @return
  214. */
  215. public String write(int code, String msg, String key, JSONArray value) {
  216. try {
  217. JSONObject json = new JSONObject();
  218. json.put("status", code);
  219. json.put("msg", msg);
  220. json.put(key, value);
  221. return json.toString();
  222. } catch (Exception e) {
  223. error(e);
  224. return error(-1, "服务器异常,请稍候再试!");
  225. }
  226. }
  227. /**
  228. * 返回接口处理结果
  229. *
  230. * @param code 结果码,成功为200
  231. * @param msg 结果提示信息
  232. * @param total 总数
  233. * @param value 结果数据
  234. * @return
  235. */
  236. public String write(int code, String msg, int total, String key, JSONArray value) {
  237. try {
  238. JSONObject json = new JSONObject();
  239. json.put("status", code);
  240. json.put("msg", msg);
  241. json.put("total", total);
  242. json.put(key, value);
  243. return json.toString();
  244. } catch (Exception e) {
  245. error(e);
  246. return error(-1, "服务器异常,请稍候再试!");
  247. }
  248. }
  249. /**
  250. * 返回接口处理结果
  251. *
  252. * @param code 结果码,成功为200
  253. * @param msg 结果提示信息
  254. * @param value 结果数据
  255. * @return
  256. */
  257. public String write(int code, String msg, String key, Object value) {
  258. try {
  259. Map<Object, Object> map = new HashMap<Object, Object>();
  260. ObjectMapper mapper = new ObjectMapper();
  261. map.put("status", code);
  262. map.put("msg", msg);
  263. map.put(key, value);
  264. return mapper.writeValueAsString(map);
  265. } catch (Exception e) {
  266. error(e);
  267. return error(-1, "服务器异常,请稍候再试!");
  268. }
  269. }
  270. /**
  271. * 返回接口处理结果
  272. *
  273. * @param code 结果码,成功为200
  274. * @param msg 结果提示信息
  275. * @param key 结果数据
  276. * @return
  277. */
  278. public String write(int code, String msg, String key, Page<?> list) {
  279. try {
  280. Map<Object, Object> map = new HashMap<Object, Object>();
  281. ObjectMapper mapper = new ObjectMapper();
  282. map.put("status", code);
  283. map.put("msg", msg);
  284. // 是否为第一页
  285. map.put("isFirst", list.isFirst());
  286. // 是否为最后一页
  287. map.put("isLast", list.isLast());
  288. // 总条数
  289. map.put("total", list.getTotalElements());
  290. // 总页数
  291. map.put("totalPages", list.getTotalPages());
  292. map.put(key, list.getContent());
  293. return mapper.writeValueAsString(map);
  294. } catch (Exception e) {
  295. error(e);
  296. return error(-1, "服务器异常,请稍候再试!");
  297. }
  298. }
  299. /**
  300. * 返回接口处理结果
  301. *
  302. * @param code 结果码,成功为200
  303. * @param msg 结果提示信息
  304. * @param key 结果数据
  305. * @return
  306. */
  307. public String write(int code, String msg, String key, Page<?> page, JSONArray array) {
  308. try {
  309. JSONObject json = new JSONObject();
  310. json.put("status", code);
  311. json.put("msg", msg);
  312. // 是否为第一页
  313. json.put("isFirst", page == null ? false : page.isFirst());
  314. // 是否为最后一页
  315. json.put("isLast", page == null ? true : page.isLast());
  316. // 总条数
  317. json.put("total", page == null ? 0 : page.getTotalElements());
  318. // 总页数
  319. json.put("totalPages", page == null ? 0 : page.getTotalPages());
  320. json.put(key, array);
  321. return json.toString();
  322. } catch (Exception e) {
  323. error(e);
  324. return error(-1, "服务器异常,请稍候再试!");
  325. }
  326. }
  327. /**
  328. * 返回接口处理结果
  329. *
  330. * @param code 结果码,成功为200
  331. * @param msg 结果提示信息
  332. * @param value 结果数据
  333. * @return
  334. */
  335. public String write(int code, String msg, String key, Map<?, ?> value) {
  336. try {
  337. Map<Object, Object> map = new HashMap<Object, Object>();
  338. ObjectMapper mapper = new ObjectMapper();
  339. map.put("status", code);
  340. map.put("msg", msg);
  341. map.put(key, value);
  342. return mapper.writeValueAsString(map);
  343. } catch (Exception e) {
  344. error(e);
  345. return error(-1, "服务器异常,请稍候再试!");
  346. }
  347. }
  348. /**
  349. * 返回接口处理结果
  350. *
  351. * @param code 结果码,成功为200
  352. * @param msg 结果提示信息
  353. * @param value 结果数据
  354. * @return
  355. */
  356. public String write(int code, String msg, String key, String value) {
  357. try {
  358. Map<Object, Object> map = new HashMap<Object, Object>();
  359. ObjectMapper mapper = new ObjectMapper();
  360. map.put("status", code);
  361. map.put("msg", msg);
  362. map.put(key, value);
  363. return mapper.writeValueAsString(map);
  364. } catch (Exception e) {
  365. error(e);
  366. return error(-1, "服务器异常,请稍候再试!");
  367. }
  368. }
  369. /**
  370. * 返回接口处理结果
  371. *
  372. * @param code 结果码,成功为200
  373. * @param msg 结果提示信息
  374. * @param key 结果数据
  375. * @return
  376. */
  377. public String write(int code, String msg, String key, IdEntity entity) {
  378. try {
  379. Map<Object, Object> map = new HashMap<Object, Object>();
  380. ObjectMapper mapper = new ObjectMapper();
  381. map.put("status", code);
  382. map.put("msg", msg);
  383. map.put(key, entity);
  384. return mapper.writeValueAsString(map);
  385. } catch (Exception e) {
  386. error(e);
  387. return error(-1, "服务器异常,请稍候再试!");
  388. }
  389. }
  390. /**
  391. * 返回接口处理结果
  392. *
  393. * @param code 结果码,成功为200
  394. * @param msg 结果提示信息
  395. * @param key 结果数据
  396. * @return
  397. */
  398. public String write(int code, String msg, boolean isFirst, boolean isLast, long total, int totalPages, String key, Object values) {
  399. try {
  400. JSONObject json = new JSONObject();
  401. json.put("status", code);
  402. json.put("msg", msg);
  403. // 是否为第一页
  404. json.put("isFirst", isFirst);
  405. // 是否为最后一页
  406. json.put("isLast", isLast);
  407. // 总条数
  408. json.put("total", total);
  409. // 总页数
  410. json.put("totalPages", totalPages);
  411. json.put(key, values);
  412. return json.toString();
  413. } catch (Exception e) {
  414. logger.error("BaseController:", e.getMessage());
  415. return error(-1, "服务器异常,请稍候再试!");
  416. }
  417. }
  418. public String trimEnd(String param, String trimChars) {
  419. if (param.endsWith(trimChars)) {
  420. param = param.substring(0, param.length() - trimChars.length());
  421. }
  422. return param;
  423. }
  424. /**
  425. * 无效用户消息返回
  426. *
  427. * @param e
  428. * @param defaultCode
  429. * @param defaultMsg
  430. * @return
  431. */
  432. public String invalidUserException(Exception e, int defaultCode, String defaultMsg) {
  433. try {
  434. // if (e instanceof UndeclaredThrowableException) {
  435. // UndeclaredThrowableException ute = (UndeclaredThrowableException) e;
  436. // InvalidUserException iue = (InvalidUserException) ute.getUndeclaredThrowable();
  437. // if (iue != null) {
  438. // return error(iue.getCode(), iue.getMsg());
  439. // }
  440. // }
  441. return error(defaultCode, defaultMsg);
  442. } catch (Exception e2) {
  443. return null;
  444. }
  445. }
  446. public List<Map<String, Object>> copyBeans(Collection<? extends Object> beans, String... propertyNames) {
  447. List<Map<String, Object>> result = new ArrayList<>();
  448. for (Object bean : beans) {
  449. result.add(copyBeanProperties(bean, propertyNames));
  450. }
  451. return result;
  452. }
  453. /**
  454. * 复制特定属性。
  455. *
  456. * @param bean
  457. * @param propertyNames
  458. * @return
  459. */
  460. public Map<String, Object> copyBeanProperties(Object bean, String... propertyNames) {
  461. Map<String, Object> simplifiedBean = new HashMap<>();
  462. for (String propertyName : propertyNames) {
  463. Field field = ReflectionUtils.findField(bean.getClass(), propertyName);
  464. if (field != null) {
  465. field.setAccessible(true);
  466. Object value = ReflectionUtils.getField(field, bean);
  467. simplifiedBean.put(propertyName, value == null ? "" : value);
  468. } else {
  469. simplifiedBean.put(propertyName, "");
  470. }
  471. }
  472. return simplifiedBean;
  473. }
  474. }