HistoryLogsAdapter.java 2.3 KB
Newer Older
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
1 2 3 4 5
package org.maxkey.web.interceptor;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
6 7
import org.maxkey.dao.service.HistoryLogsService;
import org.maxkey.domain.HistoryLogs;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
import org.maxkey.domain.UserInfo;
import org.maxkey.util.JsonUtils;
import org.maxkey.web.WebContext;
import org.maxkey.web.message.Message;
import org.maxkey.web.message.MessageScope;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;

/**
 * Contorller调用完成后进行日志操作
 * 
 * 日志处理需在parasec-servlet.xml中配置
 * mvc:interceptors  log
 * @author Crystal.Sea
 *
 */
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
28
public class HistoryLogsAdapter extends HandlerInterceptorAdapter {
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
29
	
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
30
	private static final Logger _logger = LoggerFactory.getLogger(HistoryLogsAdapter.class);
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
31 32
	
	 @Autowired
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
33 34
	 @Qualifier("historyLogsService")
	 private HistoryLogsService historyLogsService;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
35 36 37 38 39 40 41 42 43 44 45
	
	// after the handler is executed
	public void postHandle(HttpServletRequest request,HttpServletResponse response, Object handler,ModelAndView modelAndView) throws Exception {
		_logger.debug("postHandle");
		Message message = WebContext.getMessage();//读取session中message
		
		if(message != null){
			if(message.getMessageScope() == MessageScope.DB || message.getMessageScope() == MessageScope.DB_CLIENT) {//判断message类型
				UserInfo userInfo =WebContext.getUserInfo();//取得当前用户信息
				
				//创建日志记录
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
46
				HistoryLogs historyLogs = new HistoryLogs(
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
47 48 49 50 51 52 53 54 55 56
					message.getServiceName(),
					message.getCode(),
					message.getMessage(),
					JsonUtils.object2Json(message.getMessageObject()),
					message.getMessageType().toString(),
					message.getOperateType().toString(),
					userInfo==null?null:userInfo.getId(),
					userInfo==null?null:userInfo.getUsername(),
					""
				);
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
57 58
				_logger.debug("insert db historyLogs content : "+historyLogs);
				historyLogsService.insert(historyLogs);//日志插入数据库
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
59 60 61 62 63 64 65
				if(message.getMessageScope() == MessageScope.DB) {//message类型仅插入数据库
					WebContext.clearMessage();//清除message
				}
			}
		}
	}
}