BaseController.java 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512
  1. package com.yihu.figure.controller;
  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. * @param value 结果数据
  123. * @return
  124. */
  125. public String error(int code, String msg) {
  126. try {
  127. Map<Object, Object> map = new HashMap<Object, Object>();
  128. ObjectMapper mapper = new ObjectMapper();
  129. map.put("status", code);
  130. map.put("msg", msg);
  131. return mapper.writeValueAsString(map);
  132. } catch (Exception e) {
  133. error(e);
  134. return null;
  135. }
  136. }
  137. /**
  138. * 接口处理成功
  139. *
  140. * @param msg
  141. * @return
  142. */
  143. public String success(String msg) {
  144. try {
  145. Map<Object, Object> map = new HashMap<Object, Object>();
  146. ObjectMapper mapper = new ObjectMapper();
  147. map.put("status", 200);
  148. map.put("msg", msg);
  149. return mapper.writeValueAsString(map);
  150. } catch (Exception e) {
  151. error(e);
  152. return null;
  153. }
  154. }
  155. public String write(int code, String msg) {
  156. try {
  157. Map<Object, Object> map = new HashMap<Object, Object>();
  158. ObjectMapper mapper = new ObjectMapper();
  159. map.put("status", code);
  160. map.put("msg", msg);
  161. return mapper.writeValueAsString(map);
  162. } catch (Exception e) {
  163. error(e);
  164. return null;
  165. }
  166. }
  167. /**
  168. * 返回接口处理结果
  169. *
  170. * @param code 结果码,成功为200
  171. * @param msg 结果提示信息
  172. * @param value 结果数据
  173. * @return
  174. */
  175. public String write(int code, String msg, String key, List<?> list) {
  176. try {
  177. Map<Object, Object> map = new HashMap<Object, Object>();
  178. ObjectMapper mapper = new ObjectMapper();
  179. map.put("status", code);
  180. map.put("msg", msg);
  181. map.put(key, list);
  182. return mapper.writeValueAsString(map);
  183. } catch (Exception e) {
  184. error(e);
  185. return error(-1, "服务器异常,请稍候再试!");
  186. }
  187. }
  188. /**
  189. * 返回接口处理结果
  190. *
  191. * @param code 结果码,成功为200
  192. * @param msg 结果提示信息
  193. * @param value 结果数据
  194. * @return
  195. */
  196. public String write(int code, String msg, String key, JSONObject value) {
  197. try {
  198. JSONObject json = new JSONObject();
  199. json.put("status", code);
  200. json.put("msg", msg);
  201. json.put(key, value);
  202. return json.toString();
  203. } catch (Exception e) {
  204. error(e);
  205. return error(-1, "服务器异常,请稍候再试!");
  206. }
  207. }
  208. /**
  209. * 返回接口处理结果
  210. *
  211. * @param code 结果码,成功为200
  212. * @param msg 结果提示信息
  213. * @param value 结果数据
  214. * @return
  215. */
  216. public String write(int code, String msg, String key, JSONArray value) {
  217. try {
  218. JSONObject json = new JSONObject();
  219. json.put("status", code);
  220. json.put("msg", msg);
  221. json.put(key, value);
  222. return json.toString();
  223. } catch (Exception e) {
  224. error(e);
  225. return error(-1, "服务器异常,请稍候再试!");
  226. }
  227. }
  228. /**
  229. * 返回接口处理结果
  230. *
  231. * @param code 结果码,成功为200
  232. * @param msg 结果提示信息
  233. * @param total 总数
  234. * @param value 结果数据
  235. * @return
  236. */
  237. public String write(int code, String msg, int total, String key, JSONArray value) {
  238. try {
  239. JSONObject json = new JSONObject();
  240. json.put("status", code);
  241. json.put("msg", msg);
  242. json.put("total", total);
  243. json.put(key, value);
  244. return json.toString();
  245. } catch (Exception e) {
  246. error(e);
  247. return error(-1, "服务器异常,请稍候再试!");
  248. }
  249. }
  250. /**
  251. * 返回接口处理结果
  252. *
  253. * @param code 结果码,成功为200
  254. * @param msg 结果提示信息
  255. * @param value 结果数据
  256. * @return
  257. */
  258. public String write(int code, String msg, String key, Object value) {
  259. try {
  260. Map<Object, Object> map = new HashMap<Object, Object>();
  261. ObjectMapper mapper = new ObjectMapper();
  262. map.put("status", code);
  263. map.put("msg", msg);
  264. map.put(key, value);
  265. return mapper.writeValueAsString(map);
  266. } catch (Exception e) {
  267. error(e);
  268. return error(-1, "服务器异常,请稍候再试!");
  269. }
  270. }
  271. /**
  272. * 返回接口处理结果
  273. *
  274. * @param code 结果码,成功为200
  275. * @param msg 结果提示信息
  276. * @param value 结果数据
  277. * @return
  278. */
  279. public String write(int code, String msg, String key, Page<?> list) {
  280. try {
  281. Map<Object, Object> map = new HashMap<Object, Object>();
  282. ObjectMapper mapper = new ObjectMapper();
  283. map.put("status", code);
  284. map.put("msg", msg);
  285. // 是否为第一页
  286. map.put("isFirst", list.isFirst());
  287. // 是否为最后一页
  288. map.put("isLast", list.isLast());
  289. // 总条数
  290. map.put("total", list.getTotalElements());
  291. // 总页数
  292. map.put("totalPages", list.getTotalPages());
  293. map.put(key, list.getContent());
  294. return mapper.writeValueAsString(map);
  295. } catch (Exception e) {
  296. error(e);
  297. return error(-1, "服务器异常,请稍候再试!");
  298. }
  299. }
  300. /**
  301. * 返回接口处理结果
  302. *
  303. * @param code 结果码,成功为200
  304. * @param msg 结果提示信息
  305. * @param value 结果数据
  306. * @return
  307. */
  308. public String write(int code, String msg, String key, Page<?> page, JSONArray array) {
  309. try {
  310. JSONObject json = new JSONObject();
  311. json.put("status", code);
  312. json.put("msg", msg);
  313. // 是否为第一页
  314. json.put("isFirst", page == null ? false : page.isFirst());
  315. // 是否为最后一页
  316. json.put("isLast", page == null ? true : page.isLast());
  317. // 总条数
  318. json.put("total", page == null ? 0 : page.getTotalElements());
  319. // 总页数
  320. json.put("totalPages", page == null ? 0 : page.getTotalPages());
  321. json.put(key, array);
  322. return json.toString();
  323. } catch (Exception e) {
  324. error(e);
  325. return error(-1, "服务器异常,请稍候再试!");
  326. }
  327. }
  328. /**
  329. * 返回接口处理结果
  330. *
  331. * @param code 结果码,成功为200
  332. * @param msg 结果提示信息
  333. * @param value 结果数据
  334. * @return
  335. */
  336. public String write(int code, String msg, String key, Map<?, ?> value) {
  337. try {
  338. Map<Object, Object> map = new HashMap<Object, Object>();
  339. ObjectMapper mapper = new ObjectMapper();
  340. map.put("status", code);
  341. map.put("msg", msg);
  342. map.put(key, value);
  343. return mapper.writeValueAsString(map);
  344. } catch (Exception e) {
  345. error(e);
  346. return error(-1, "服务器异常,请稍候再试!");
  347. }
  348. }
  349. /**
  350. * 返回接口处理结果
  351. *
  352. * @param code 结果码,成功为200
  353. * @param msg 结果提示信息
  354. * @param value 结果数据
  355. * @return
  356. */
  357. public String write(int code, String msg, String key, String value) {
  358. try {
  359. Map<Object, Object> map = new HashMap<Object, Object>();
  360. ObjectMapper mapper = new ObjectMapper();
  361. map.put("status", code);
  362. map.put("msg", msg);
  363. map.put(key, value);
  364. return mapper.writeValueAsString(map);
  365. } catch (Exception e) {
  366. error(e);
  367. return error(-1, "服务器异常,请稍候再试!");
  368. }
  369. }
  370. /**
  371. * 返回接口处理结果
  372. *
  373. * @param code 结果码,成功为200
  374. * @param msg 结果提示信息
  375. * @param value 结果数据
  376. * @return
  377. */
  378. public String write(int code, String msg, String key, IdEntity entity) {
  379. try {
  380. Map<Object, Object> map = new HashMap<Object, Object>();
  381. ObjectMapper mapper = new ObjectMapper();
  382. map.put("status", code);
  383. map.put("msg", msg);
  384. map.put(key, entity);
  385. return mapper.writeValueAsString(map);
  386. } catch (Exception e) {
  387. error(e);
  388. return error(-1, "服务器异常,请稍候再试!");
  389. }
  390. }
  391. /**
  392. * 返回接口处理结果
  393. *
  394. * @param code 结果码,成功为200
  395. * @param msg 结果提示信息
  396. * @param value 结果数据
  397. * @return
  398. */
  399. public String write(int code, String msg, boolean isFirst, boolean isLast, long total, int totalPages, String key, Object values) {
  400. try {
  401. JSONObject json = new JSONObject();
  402. json.put("status", code);
  403. json.put("msg", msg);
  404. // 是否为第一页
  405. json.put("isFirst", isFirst);
  406. // 是否为最后一页
  407. json.put("isLast", isLast);
  408. // 总条数
  409. json.put("total", total);
  410. // 总页数
  411. json.put("totalPages", totalPages);
  412. json.put(key, values);
  413. return json.toString();
  414. } catch (Exception e) {
  415. logger.error("BaseController:", e.getMessage());
  416. return error(-1, "服务器异常,请稍候再试!");
  417. }
  418. }
  419. public String trimEnd(String param, String trimChars) {
  420. if (param.endsWith(trimChars)) {
  421. param = param.substring(0, param.length() - trimChars.length());
  422. }
  423. return param;
  424. }
  425. /**
  426. * 无效用户消息返回
  427. *
  428. * @param e
  429. * @param defaultCode
  430. * @param defaultMsg
  431. * @return
  432. */
  433. public String invalidUserException(Exception e, int defaultCode, String defaultMsg) {
  434. try {
  435. // if (e instanceof UndeclaredThrowableException) {
  436. // UndeclaredThrowableException ute = (UndeclaredThrowableException) e;
  437. // InvalidUserException iue = (InvalidUserException) ute.getUndeclaredThrowable();
  438. // if (iue != null) {
  439. // return error(iue.getCode(), iue.getMsg());
  440. // }
  441. // }
  442. return error(defaultCode, defaultMsg);
  443. } catch (Exception e2) {
  444. return null;
  445. }
  446. }
  447. public List<Map<String, Object>> copyBeans(Collection<? extends Object> beans, String... propertyNames) {
  448. List<Map<String, Object>> result = new ArrayList<>();
  449. for (Object bean : beans) {
  450. result.add(copyBeanProperties(bean, propertyNames));
  451. }
  452. return result;
  453. }
  454. /**
  455. * 复制特定属性。
  456. *
  457. * @param bean
  458. * @param propertyNames
  459. * @return
  460. */
  461. public Map<String, Object> copyBeanProperties(Object bean, String... propertyNames) {
  462. Map<String, Object> simplifiedBean = new HashMap<>();
  463. for (String propertyName : propertyNames) {
  464. Field field = ReflectionUtils.findField(bean.getClass(), propertyName);
  465. if (field != null) {
  466. field.setAccessible(true);
  467. Object value = ReflectionUtils.getField(field, bean);
  468. simplifiedBean.put(propertyName, value == null ? "" : value);
  469. } else {
  470. simplifiedBean.put(propertyName, "");
  471. }
  472. }
  473. return simplifiedBean;
  474. }
  475. }