日志的环绕通知(ip地址的普通获取版)

来源:互联网 发布:houdini软件下载 编辑:程序博客网 时间:2024/04/25 19:22
/*  * Copyright (c) 2016, S.F. Express Inc. All rights reserved. */package com.sf.novatar.tpl.advice;import java.net.InetAddress;import java.net.UnknownHostException;import java.util.Date;import java.util.Map;import javax.servlet.http.HttpServletRequest;import org.aspectj.lang.ProceedingJoinPoint;import org.aspectj.lang.annotation.Around;import org.aspectj.lang.annotation.Aspect;import org.aspectj.lang.annotation.Pointcut;import org.aspectj.lang.reflect.MethodSignature;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import com.sf.novatar.cache.CacheManager;import com.sf.novatar.cache.ICache;import com.sf.novatar.plf.common.DateUtils;import com.sf.novatar.plf.common.SspConstants;import com.sf.novatar.tpl.bean.UmUser;import com.sf.novatar.tpl.servlet.HttpServletHolder;import com.sf.novatar.tpl.util.UserUtil;/** * 描述: *  * <pre> * HISTORY * **************************************************************************** *  ID   DATE           PERSON          REASON *  1    2016年1月22日      601008         Create * **************************************************************************** * </pre> *  * @author 601008 * @since 1.0 */@Aspectpublic class MethodAdvice {private final static Logger logger = LoggerFactory.getLogger(MethodAdvice.class);@Around(value = "anyMethod()")// @Around("execution(* com.sf.novatar.tpl.service.*.*(..))")public Object around(final ProceedingJoinPoint jPoint) throws Throwable {String methodName = ((MethodSignature) jPoint.getSignature()).getMethod().toString();long methodStart = System.currentTimeMillis();String logValve = SspConstants.LOGVALVE_ENABLE;try {try {ICache<String, Map<String,String>> configCache = CacheManager.getInstance().getCache(SspConstants.CACHE_KEY_CONFIG);Map<String,String> configMap = configCache.get("");logValve = configMap.get("logValve");} catch (Exception e) {}Object object = jPoint.proceed(jPoint.getArgs());if(SspConstants.LOGVALVE_ENABLE.equals(logValve)){logger.info("^*^|{}|{}|{}|{}|{}|{}|{}|{}|{}|", new Object[] {methodName, getRequestIp(),InetAddress.getLocalHost().getHostAddress(), userInfo(),getRequestUri(),System.currentTimeMillis() - methodStart , DateUtils.formatDateByFormat(new Date(methodStart), "yyyy-MM-dd HH:mm:ss"),SspConstants.SYSTEM_ID,""});}return object;} catch (Throwable e) {if(SspConstants.LOGVALVE_ENABLE.equals(logValve)){logger.info("^*^|{}|{}|{}|{}|{}|{}|{}|{}|{}|", new Object[] {methodName, getRequestIp(), InetAddress.getLocalHost().getHostAddress(), userInfo(),getRequestUri(),System.currentTimeMillis() - methodStart , DateUtils.formatDateByFormat(new Date(methodStart), "yyyy-MM-dd HH:mm:ss"),SspConstants.SYSTEM_ID,e.getClass()});}throw e;}}/** * 2016年3月3日 601008方法说明:在此方法上配置要监控的方法 void */@Pointcut("execution(* com.sf.novatar.tpl.service.*.*(..))"+ "||execution(* com.sf.novatar.plf.service.*.*(..))")public void anyMethod() {}public String userInfo() {HttpServletRequest request = HttpServletHolder.getCurrentRequest();if (null != request) {UmUser umUser = UserUtil.getCurrentUser();if (null != umUser) {return umUser.getUsername();}}return "system";}public String getRequestHostName() {HttpServletRequest request = HttpServletHolder.getCurrentRequest();String remoteHost = "";if (null != request) { remoteHost = request.getRemoteHost();}return remoteHost;}public String getRequestIp() {String ipAddress = null;HttpServletRequest request = HttpServletHolder.getCurrentRequest();if (null == request) {return "0.0.0.1";}ipAddress = request.getHeader("x-forwarded-for");if (ipAddress == null || ipAddress.length() == 0|| "unknown".equalsIgnoreCase(ipAddress)) {ipAddress = request.getHeader("Proxy-Client-IP");}if (ipAddress == null || ipAddress.length() == 0|| "unknown".equalsIgnoreCase(ipAddress)) {ipAddress = request.getHeader("WL-Proxy-Client-IP");}if (ipAddress == null || ipAddress.length() == 0|| "unknown".equalsIgnoreCase(ipAddress)) {ipAddress = request.getRemoteAddr();// 这里主要是获取本机的ip,可有可无if (ipAddress.equals("127.0.0.1")|| ipAddress.endsWith("0:0:0:0:0:0:1")) {// 根据网卡取本机配置的IPInetAddress inet = null;try {inet = InetAddress.getLocalHost();} catch (UnknownHostException e) {e.printStackTrace();}ipAddress = inet.getHostAddress();}}// 对于通过多个代理的情况,第一个IP为客户端真实IP,多个IP按照','分割if (ipAddress != null && ipAddress.length() > 15) { // "***.***.***.***".length()// = 15if (ipAddress.indexOf(",") > 0) {ipAddress = ipAddress.substring(0, ipAddress.indexOf(","));}}// 或者这样也行,对于通过多个代理的情况,第一个IP为客户端真实IP,多个IP按照','分割// return// ipAddress!=null&&!"".equals(ipAddress)?ipAddress.split(",")[0]:null;return ipAddress;}public String getRequestUri() {HttpServletRequest request = HttpServletHolder.getCurrentRequest();if (null == request) {return "";} else {return request.getRequestURI();}}}

0 0
原创粉丝点击