SpringBoot log打印及輸出方式
更新時間:2021年11月20日 14:32:43 作者:RYANRUN潤
這篇文章主要介紹了SpringBoot log打印及輸出方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
SpringBoot log打印及輸出
導入jar包
import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory;
代碼示例
private final Log log = LogFactory.getLog(AppController.class); //AppController.class為當前class文件,后臺會輸出這個class文件的log
String input = "%CN%"; this.log.info(input);
后臺輸出日志如下:

日志輸出配置
在application.yml文件中添加配置
logging: path: D:\spring-boot-log //自定義輸出日志的地址
springboot切面技術打印log日志
項目的部分功能需要新增加日志的操作記錄,想了一圈還是使用切面技術比較方便解決。 相當于代理,感覺比代理更牛逼。
說一下關鍵詞 自己理解的。
@Aspect:把當前類搞成一個切面類,提供容器讀取@Pointcut:定義切點,掃描那個包下面的那個類,具體到那個方法。@Around:環(huán)繞增強,相當于MethodInterceptor@AfterReturning:后置增強,相當于AfterReturningAdvice,方法正常退出時執(zhí)行@Before:標識一個前置增強方法,相當于BeforeAdvice的功能,相似功能的還有@AfterThrowing:異常拋出增強,相當于ThrowsAdvice@After:final增強,不管是拋出異?;蛘哒M顺龆紩?zhí)行
mvaen 準備 還有spring家族的
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.25</version>
</dependency>
創(chuàng)建 WebLogAcpect 類
@Aspect
@Component
public class WebLogAcpect {
private final static Logger orderLog = LoggerFactory.getLogger("order");
//定義切點
@Pointcut("execution(* com.qszhuang.backstage.service.OrderService.updateOrder*(..))")
public void webLog() {
}
@Before("webLog()")
public void doBefore(JoinPoint joinPoint) {
// 接收到請求,記錄請求內容
ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
if (!StringUtils.isEmpty(attributes)) {
HttpServletRequest request = attributes.getRequest();
// 記錄下請求內容
orderLog.info("URL : " + request.getRequestURL().toString());
// orderLog.info("HTTP_METHOD : " + request.getMethod());
orderLog.info("IP : " + HttpUtil.getIp(request));
//獲取操作人
if (!StringUtils.isEmpty(request.getCookies())) {
String cookieValueByName = HttpUtil.getCookieValueByName(request.getCookies(), WebSecurityConfig.TOKEN_HEADER);
Map<String, Claim> stringClaimMap = TokenUtil.verifyToken(cookieValueByName);
//方法名
// orderLog.info("CLASS_METHOD : " + joinPoint.getSignature().getDeclaringTypeName() + "." + joinPoint.getSignature().getName());
orderLog.info("訂單號 : {},操作人:{}", Arrays.toString(joinPoint.getArgs()), stringClaimMap.get("adminUsername").asString());
}
}else {
orderLog.info("整點退款");
}
}
@AfterReturning(returning = "ret", pointcut = "webLog()")
public void doAfterReturning(Object ret) throws Throwable {
// 處理完請求,返回內容
orderLog.info("操作返回值 : " + ret);
}
}
配置log4j
創(chuàng)建文件 log4j.properties 打印order 日志到指定目錄 當然可以配置多個日志分別保存
log4j.rootLogger=INFO,stdout
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = %d{ABSOLUTE} %5p %c{1}:%L - %m%n
#log4j.appender.timer_log=org.apache.log4j.DailyRollingFileAppender
#log4j.appender.timer_log.Append=true
#log4j.appender.timer_log.DatePattern='.'yyyy-MM-dd
#log4j.appender.timer_log.File=E:/logs/timer/timer.log
#log4j.appender.timer_log.Threshold=INFO
#log4j.appender.timer_log.layout=org.apache.log4j.PatternLayout
#log4j.appender.timer_log.layout.ConversionPattern=%d - %c [%t] %-5p %c %x %l - %m%n
log4j.logger.order=INFO,order_log
log4j.appender.order_log=org.apache.log4j.DailyRollingFileAppender
log4j.appender.order_log.Append=true
log4j.appender.order_log.DatePattern='.'yyyy-MM-dd
log4j.appender.order_log.File=../logs/order/order.log
log4j.appender.order_log.Threshold=INFO
log4j.appender.order_log.layout=org.apache.log4j.PatternLayout
log4j.appender.order_log.layout.ConversionPattern=[%p] [%d{yyyy-MM-dd HH:mm:ss}] %m%n
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
SpringBoot application.yml和bootstrap.yml的區(qū)別
本文主要介紹了SpringBoot application.yml和bootstrap.yml的區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-04-04
Reactor中的onErrorContinue?和?onErrorResume
這篇文章主要介紹了Reactor中的onErrorContinue?和?onErrorResume,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的朋友可以參考一下2022-09-09
Spring需要三個級別緩存解決循環(huán)依賴原理解析
這篇文章主要為大家介紹了Spring需要三個級別緩存解決循環(huán)依賴原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-02-02

