ApiBaseAction.java 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. package com.kmall.api.util;
  2. import com.alibaba.fastjson.JSONObject;
  3. import com.kmall.common.advice.CustomDateEditor;
  4. import com.kmall.common.advice.CustomSqlDateEditor;
  5. import com.kmall.common.advice.CustomTimestampEditor;
  6. import com.kmall.api.cache.UserTokenCache;
  7. import com.kmall.api.entity.TokenEntity;
  8. import com.kmall.api.interceptor.AuthorizationInterceptor;
  9. import org.apache.log4j.Logger;
  10. import org.apache.shiro.authz.UnauthorizedException;
  11. import org.springframework.beans.TypeMismatchException;
  12. import org.springframework.beans.factory.annotation.Autowired;
  13. import org.springframework.beans.propertyeditors.StringTrimmerEditor;
  14. import org.springframework.validation.BindException;
  15. import org.springframework.web.bind.MissingServletRequestParameterException;
  16. import org.springframework.web.bind.WebDataBinder;
  17. import org.springframework.web.bind.annotation.ExceptionHandler;
  18. import org.springframework.web.bind.annotation.InitBinder;
  19. import org.springframework.web.bind.annotation.ResponseBody;
  20. import org.springframework.web.context.request.WebRequest;
  21. import javax.servlet.http.HttpServletRequest;
  22. import javax.servlet.http.HttpServletResponse;
  23. import java.io.BufferedReader;
  24. import java.io.IOException;
  25. import java.sql.Timestamp;
  26. import java.util.Date;
  27. import java.util.HashMap;
  28. import java.util.Map;
  29. /**
  30. * @author Scott
  31. * @ClassName: ApiBaseAction
  32. * @Description: 基础控制类
  33. * @date 2016年9月2日
  34. */
  35. public class ApiBaseAction {
  36. protected Logger logger = Logger.getLogger(getClass());
  37. /**
  38. * 得到request对象
  39. */
  40. @Autowired
  41. protected HttpServletRequest request;
  42. /**
  43. * 得到response对象
  44. */
  45. @Autowired
  46. protected HttpServletResponse response;
  47. /**
  48. * 参数绑定异常
  49. */
  50. @ExceptionHandler({BindException.class, MissingServletRequestParameterException.class, UnauthorizedException.class, TypeMismatchException.class})
  51. @ResponseBody
  52. public Map<String, Object> bindException(Exception e) {
  53. if (e instanceof BindException) {
  54. return toResponsObject(1, "参数绑定异常", e.getMessage());
  55. } else if (e instanceof UnauthorizedException) {
  56. return toResponsObject(1, "无访问权限", e.getMessage());
  57. }
  58. return toResponsObject(1, "处理异常", e.getMessage());
  59. }
  60. /**
  61. * @param requestCode
  62. * @param msg
  63. * @param data
  64. * @return Map<String,Object>
  65. * @throws
  66. * @Description:构建统一格式返回对象
  67. * @date 2016年9月2日
  68. * @author zhuliyun
  69. */
  70. public Map<String, Object> toResponsObject(int requestCode, String msg, Object data) {
  71. Map<String, Object> obj = new HashMap<String, Object>();
  72. obj.put("errno", requestCode);
  73. obj.put("errmsg", msg);
  74. if (data != null)
  75. obj.put("data", data);
  76. return obj;
  77. }
  78. public Map<String, Object> toResponsSuccess(Object data) {
  79. Map<String, Object> rp = toResponsObject(0, "执行成功", data);
  80. logger.info("response:" + rp);
  81. return rp;
  82. }
  83. public Map<String, Object> toResponsMsgSuccess(String msg) {
  84. return toResponsObject(0, msg, "");
  85. }
  86. public Map<String, Object> toResponsSuccessForSelect(Object data) {
  87. Map<String, Object> result = new HashMap<>(2);
  88. result.put("list", data);
  89. return toResponsObject(0, "执行成功", result);
  90. }
  91. public Map<String, Object> toResponsFail(String msg) {
  92. return toResponsObject(1, msg, null);
  93. }
  94. /**
  95. * initBinder 初始化绑定 <br>
  96. * 这里处理了3种类型<br>
  97. * 1、字符串自动 trim 去掉前后空格 <br>
  98. * 2、java.util.Date 转换为 "yyyy-MM-dd HH:mm:ss" 格式<br>
  99. * 3、java.sql.Date 转换为 "yyyy-MM-dd" 格式<br>
  100. * 4、java.util.Timestamps 时间转换
  101. *
  102. * @param binder WebDataBinder 要注册的binder
  103. * @param request 前端请求
  104. */
  105. @InitBinder
  106. public void initBinder(WebDataBinder binder, WebRequest request) {
  107. // 绑定java.util.Date 类型转换
  108. // SimpleDateFormat dateFormat = new
  109. // SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); // 设定前后台的格式对应
  110. // dateFormat.setLenient(false);
  111. binder.registerCustomEditor(Date.class, new CustomDateEditor());
  112. // 绑定 java.sql.Date类型
  113. binder.registerCustomEditor(java.sql.Date.class, new CustomSqlDateEditor());
  114. // Timestamp 绑定
  115. binder.registerCustomEditor(Timestamp.class, new CustomTimestampEditor());
  116. // 字符串自动Trim
  117. binder.registerCustomEditor(String.class, new StringTrimmerEditor(false));
  118. }
  119. /**
  120. * 获取请求方IP
  121. *
  122. * @return 客户端Ip
  123. */
  124. public String getClientIp() {
  125. String xff = request.getHeader("x-forwarded-for");
  126. if (xff == null) {
  127. return request.getRemoteAddr();
  128. }
  129. return xff;
  130. }
  131. public JSONObject getJsonRequest() {
  132. JSONObject result = null;
  133. StringBuilder sb = new StringBuilder();
  134. try (BufferedReader reader = request.getReader();) {
  135. char[] buff = new char[1024];
  136. int len;
  137. while ((len = reader.read(buff)) != -1) {
  138. sb.append(buff, 0, len);
  139. }
  140. result = JSONObject.parseObject(sb.toString());
  141. } catch (IOException e) {
  142. e.printStackTrace();
  143. }
  144. return result;
  145. }
  146. /**
  147. * 获取请求的openId
  148. *
  149. * @return 客户端Ip
  150. */
  151. public String getOpenId() {
  152. String token = request.getHeader(AuthorizationInterceptor.LOGIN_TOKEN_KEY);
  153. //查询token信息
  154. TokenEntity tokenEntity = UserTokenCache.getUserInfoByToken(token);
  155. if (tokenEntity == null || tokenEntity.getExpireTime().getTime() < System.currentTimeMillis()) {
  156. return null;
  157. }
  158. return tokenEntity.getOpenId();
  159. }
  160. public Long getUserId() {
  161. String token = request.getHeader(AuthorizationInterceptor.LOGIN_TOKEN_KEY);
  162. //查询token信息
  163. TokenEntity tokenEntity = UserTokenCache.getUserInfoByToken(token);
  164. if (tokenEntity == null || tokenEntity.getExpireTime().getTime() < System.currentTimeMillis()) {
  165. return null;
  166. }
  167. return tokenEntity.getUserId();
  168. }
  169. /**
  170. * 获取请求的门店Id
  171. *
  172. * @return 客户端Ip
  173. */
  174. public Long getStoreId() {
  175. String token = request.getHeader(AuthorizationInterceptor.LOGIN_TOKEN_KEY);
  176. //查询token信息
  177. TokenEntity tokenEntity = UserTokenCache.getUserInfoByToken(token);
  178. if (tokenEntity == null || tokenEntity.getExpireTime().getTime() < System.currentTimeMillis()) {
  179. return null;
  180. }
  181. return tokenEntity.getStoreId();
  182. }
  183. /**
  184. * 获取请求的商户编号
  185. *
  186. * @return 客户端Ip
  187. */
  188. public String getMerchSn() {
  189. String token = request.getHeader(AuthorizationInterceptor.LOGIN_TOKEN_KEY);
  190. //查询token信息
  191. TokenEntity tokenEntity = UserTokenCache.getUserInfoByToken(token);
  192. if (tokenEntity == null || tokenEntity.getExpireTime().getTime() < System.currentTimeMillis()) {
  193. return null;
  194. }
  195. return tokenEntity.getMerchSn();
  196. }
  197. }