一、添加增强日志AOP
引入依赖 pom.xml(base)
<!--AOP-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
IpUtil.java(base)
package com.lyj.common.base.util;
import javax.servlet.http.HttpServletRequest;
import java.net.InetAddress;
import java.net.UnknownHostException;
/**
* IP工具类
*/
public class IpUtil {
public static String getIpAddr(HttpServletRequest request) {
if (null == request) {
return "null";
}
String ipAddress = null;
try {
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();
if (ipAddress.equals("127.0.0.1") || ipAddress.equals("0:0:0:0:0:0:0:1")) {
// 根据网卡取本机配置的IP
InetAddress inet = null;
try {
inet = InetAddress.getLocalHost();
} catch (UnknownHostException e) {
e.printStackTrace();
}
ipAddress = inet.getHostAddress();
}
}
// 对于通过多个代理的情况,第一个IP为客户端真实IP,多个IP按照','分割
if (ipAddress != null && ipAddress.length() > 15) { // "***.***.***.***".length()
// = 15
if (ipAddress.indexOf(",") > 0) {
ipAddress = ipAddress.substring(0, ipAddress.indexOf(","));
}
}
} catch (Exception e) {
ipAddress = "";
}
// ipAddress = this.getRequest().getRemoteAddr();
return ipAddress;
}
}
Log.java(base)
package com.lyj.common.base.aspect;
import java.lang.annotation.*;
/**
* 日志AOP注解
*/
@Target({ElementType.METHOD, ElementType.PARAMETER})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface Log {
}
IpLogAspect.java(base)
package com.lyj.common.base.aspect;
import com.lyj.common.base.util.IpUtil;
import lombok.AllArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.Signature;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;
import javax.servlet.http.HttpServletRequest;
/**
* aop切面
* 增强@log注解
* 在controller前后记录请求信息
*/
@Component
@Aspect
@Slf4j
@AllArgsConstructor
public class IpLogAspect {
private final HttpServletRequest request;
//定义切点
@Pointcut("@annotation(com.lyj.common.base.aspect.Log)")
public void pointCut() {
}
@Pointcut("execution(public * com.lyj.service..api..*.*(..))")
public void controller() {
}
/**
* api 日志
*
* @param joinPoint
* @return
*/
@Around("controller()")
public Object around(ProceedingJoinPoint joinPoint) throws Throwable {
Signature signature = joinPoint.getSignature();
Object[] args = joinPoint.getArgs();
String ipAddr = IpUtil.getIpAddr(request);
String requestURL = request == null ? "" : request.getRequestURL().toString();
long start = System.currentTimeMillis();
log.info("start:{}|url:{}|method:{}|args:{}|customer_ip:{}", start, requestURL, signature, args, ipAddr);
Object proceed = null;
try {
proceed = joinPoint.proceed();
} finally {
log.info("end:{}|consume:{}|url:{}|method:{}|customer_ip:{}", System.currentTimeMillis(), System.currentTimeMillis() - start, requestURL, signature, ipAddr);
}
return proceed;
}
/**
* 内部方法
*
* @param joinPoint
* @return
*/
@Around("pointCut()")
public Object around1(ProceedingJoinPoint joinPoint) throws Throwable {
Signature signature = joinPoint.getSignature();
Object[] args = joinPoint.getArgs();
log.info("start:{}|method:{}|args:{}", System.currentTimeMillis(), signature, args);
Object proceed = null;
try {
proceed = joinPoint.proceed();
} finally {
log.info("end:{}|method:{}|args:{}", System.currentTimeMillis(), signature, args);
}
return proceed;
}
}
启动测试
增强前

增强后
二、集成Excel处理工具(easyexcel)
引入依赖
pom.xml(initMode)
<!--Excel处理工具-->
<easyexcel.version>3.0.5</easyexcel.version>
<dependency>
<groupId>io.jsonwebtoken</groupId>

最低0.47元/天 解锁文章
994

被折叠的 条评论
为什么被折叠?



