HistoryLogsAdapter.java 2.4 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
import org.maxkey.domain.HistoryLogs;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
7
import org.maxkey.domain.UserInfo;
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
8
import org.maxkey.persistence.service.HistoryLogsService;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
9 10 11 12 13 14 15 16
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;
MaxKey单点登录官方's avatar
MaxKey单点登录官方 已提交
17 18
import org.springframework.context.annotation.Configuration;
import org.springframework.stereotype.Component;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
19 20 21 22 23 24 25 26 27 28 29
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
MaxKey单点登录官方 已提交
30
@Component
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
31
public class HistoryLogsAdapter extends HandlerInterceptorAdapter {
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
32
	
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
33
	private static final Logger _logger = LoggerFactory.getLogger(HistoryLogsAdapter.class);
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
34 35
	
	 @Autowired
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
36 37
	 @Qualifier("historyLogsService")
	 private HistoryLogsService historyLogsService;
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
38 39 40 41 42 43 44 45 46 47
	
	// after the handler is executed
	@Override
	public void postHandle(HttpServletRequest request,HttpServletResponse response, Object handler,ModelAndView modelAndView) throws Exception {
		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单点登录官方 已提交
48
				HistoryLogs logs = new HistoryLogs(
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
49 50 51 52 53 54 55 56 57 58 59
					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(),
					""
				);
				_logger.debug("insert db logs content : "+logs);
MaxKey单点登录官方's avatar
m-11/6  
MaxKey单点登录官方 已提交
60
				historyLogsService.insert(logs);//日志插入数据库
MaxKey单点登录官方's avatar
init  
MaxKey单点登录官方 已提交
61 62 63 64 65 66 67
				if(message.getMessageScope() == MessageScope.DB) {//message类型仅插入数据库
					WebContext.clearMessage();//清除message
				}
			}
		}
	}
}