自定義註解+springMVC配置攔截器記錄用戶操作的日誌(寫入資料庫)
@SuppressWarnings({"unchecked","rawtypes"}) public class CommContextInterceptor implements HandlerInterceptor { private TSysOperateLogService tSysOperateLogService; /** 通過spring自動注入 */ public void setTSysOperateLogServiceImpl(TSysOperateLogService service) { this.tSysOperateLogService = service; } /** * preHandle方法是進行處理器攔截用的,顧名思義,該方法將在Controller處理之前進行調用,SpringMVC中的Interceptor攔截器是鏈式的,可以同時存在 * 多個Interceptor,然後SpringMVC會根據聲明的前後順序一個接一個的執行,而且所有的Interceptor中的preHandle方法都會在 * Controller方法調用之前調用。SpringMVC的這種Interceptor鏈式結構也是可以進行中斷的,這種中斷方式是令preHandle的返 * 回值為false,當preHandle的返回值為false的時候整個請求就結束了。 */ @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { HandlerMethod methodHandler = (HandlerMethod) handler; System.out.println("CommContextInterceptor............."+methodHandler.getMethod()); return true; } /** * 這個方法只會在當前這個Interceptor的preHandle方法返回值為true的時候才會執行。postHandle是進行處理器攔截用的,它的執行時間是在處理器進行處理之 * 後,也就是在Controller的方法調用之後執行,但是它會在DispatcherServlet進行視圖的渲染之前執行,也就是說在這個方法中你可以對ModelAndView進行操 * 作。這個方法的鏈式結構跟正常訪問的方向是相反的,也就是說先聲明的Interceptor攔截器該方法反而會後調用,這跟Struts2裡面的攔截器的執行過程有點像, * 只是Struts2裡面的intercept方法中要手動的調用ActionInvocation的invoke方法,Struts2中調用ActionInvocation的invoke方法就是調用下一個Interceptor * 或者是調用action,然後要在Interceptor之前調用的內容都寫在調用invoke之前,要在Interceptor之後調用的內容都寫在調用invoke方法之後。 */ @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { response.setContentType("text/html;charset=UTF-8"); } /** * 該方法也是需要當前對應的Interceptor的preHandle方法的返回值為true時才會執行。該方法將在整個請求完成之後,也就是DispatcherServlet渲染了視圖執行, * 這個方法的主要作用是用於清理資源的,當然這個方法也只能在當前這個Interceptor的preHandle方法的返回值為true時才會執行。 */ @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) { try { HttpSession session = request.getSession(); TBaseMember onlineUser = (TBaseMember)session.getAttribute(Constants.SESSION_USER_INFO); if(onlineUser!=null){ TSysOperateLog ywjcSysOperateLog=new TSysOperateLog(); //記錄日誌 String requestUri = request.getRequestURI(); String contextPath = request.getContextPath(); String url = requestUri.substring(contextPath.length()); ywjcSysOperateLog.setOperator(onlineUser.getId()); ywjcSysOperateLog.setOpTime(new Date()); ywjcSysOperateLog.setRequestUri(url); ywjcSysOperateLog.setIpAddress(CTools.getIpAddress(request)); if (handler instanceof HandlerMethod) { HandlerMethod methodHandler = (HandlerMethod) handler; //獲取訪問方法的註解 SysLog sysLog = methodHandler.getMethod().getAnnotation(SysLog.class); if (sysLog!=null) { ywjcSysOperateLog.setContent(sysLog.remark()); ywjcSysOperateLog.setOpModule(sysLog.operationModule()); ywjcSysOperateLog.setOpType(sysLog.operation()); //獲取請求的參數 Map parameters = request.getParameterMap(); if (parameters != null) { //獲取 他們請求數據的參數 String requestParameters = RequestMapUtil.readjson(request).toString(); ywjcSysOperateLog.setRequestParameter(requestParameters); } tSysOperateLogService.save(ywjcSysOperateLog); } } } } catch (Exception e) { e.printStackTrace(); } } }


TAG:程序員小新人學習 |