SpringBoot log打印及輸出方式
SpringBoot log打印及輸出
導(dǎo)入jar包
import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory;
代碼示例
private final Log log = LogFactory.getLog(AppController.class); //AppController.class為當(dāng)前class文件,后臺(tái)會(huì)輸出這個(gè)class文件的log
String input = "%CN%"; this.log.info(input);
后臺(tái)輸出日志如下:

日志輸出配置
在application.yml文件中添加配置
logging: path: D:\spring-boot-log //自定義輸出日志的地址
springboot切面技術(shù)打印log日志
項(xiàng)目的部分功能需要新增加日志的操作記錄,想了一圈還是使用切面技術(shù)比較方便解決。 相當(dāng)于代理,感覺(jué)比代理更牛逼。
說(shuō)一下關(guān)鍵詞 自己理解的。
@Aspect:把當(dāng)前類搞成一個(gè)切面類,提供容器讀取@Pointcut:定義切點(diǎn),掃描那個(gè)包下面的那個(gè)類,具體到那個(gè)方法。@Around:環(huán)繞增強(qiáng),相當(dāng)于MethodInterceptor@AfterReturning:后置增強(qiáng),相當(dāng)于AfterReturningAdvice,方法正常退出時(shí)執(zhí)行@Before:標(biāo)識(shí)一個(gè)前置增強(qiáng)方法,相當(dāng)于BeforeAdvice的功能,相似功能的還有@AfterThrowing:異常拋出增強(qiáng),相當(dāng)于ThrowsAdvice@After:final增強(qiáng),不管是拋出異?;蛘哒M顺龆紩?huì)執(zhí)行
mvaen 準(zhǔn)備 還有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");
//定義切點(diǎn)
@Pointcut("execution(* com.qszhuang.backstage.service.OrderService.updateOrder*(..))")
public void webLog() {
}
@Before("webLog()")
public void doBefore(JoinPoint joinPoint) {
// 接收到請(qǐng)求,記錄請(qǐng)求內(nèi)容
ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
if (!StringUtils.isEmpty(attributes)) {
HttpServletRequest request = attributes.getRequest();
// 記錄下請(qǐng)求內(nèi)容
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("訂單號(hào) : {},操作人:{}", Arrays.toString(joinPoint.getArgs()), stringClaimMap.get("adminUsername").asString());
}
}else {
orderLog.info("整點(diǎn)退款");
}
}
@AfterReturning(returning = "ret", pointcut = "webLog()")
public void doAfterReturning(Object ret) throws Throwable {
// 處理完請(qǐng)求,返回內(nèi)容
orderLog.info("操作返回值 : " + ret);
}
}
配置log4j
創(chuàng)建文件 log4j.properties 打印order 日志到指定目錄 當(dāng)然可以配置多個(gè)日志分別保存
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
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Springboot獲取前端反饋信息并存入數(shù)據(jù)庫(kù)的實(shí)現(xiàn)代碼
這篇文章主要介紹了Springboot獲取前端反饋信息并存入數(shù)據(jù)庫(kù)的實(shí)現(xiàn)代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03
SpringBoot application.yml和bootstrap.yml的區(qū)別
本文主要介紹了SpringBoot application.yml和bootstrap.yml的區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
IntelliJ IDEA之配置JDK的4種方式(小結(jié))
這篇文章主要介紹了IntelliJ IDEA之配置JDK的4種方式(小結(jié)),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10
Reactor中的onErrorContinue?和?onErrorResume
這篇文章主要介紹了Reactor中的onErrorContinue?和?onErrorResume,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下2022-09-09
Mybatis結(jié)果生成鍵值對(duì)的實(shí)例代碼
這篇文章主要介紹了Mybatis結(jié)果生成鍵值對(duì)的實(shí)例代碼,以及MyBatis返回Map鍵值對(duì)數(shù)據(jù)的實(shí)現(xiàn)方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下2017-02-02
Spring需要三個(gè)級(jí)別緩存解決循環(huán)依賴原理解析
這篇文章主要為大家介紹了Spring需要三個(gè)級(jí)別緩存解決循環(huán)依賴原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02

