1. 程式人生 > >SpringBoot入門(四)日誌輸出

SpringBoot入門(四)日誌輸出

Java程式,日誌輸出,我認為是第一位的,把它的應用拿到這裡。

spring-Boot對日誌的處理,和我們往常的處理完全可以一致,通過logback.xml進行處理,即使有更先進的東西,我們也不用去管它。

這裡,為了簡便,我們任然使用前一篇的工程spring-boot-sample-data

第一步,在src/main/resources中增加logback.xml檔案,檔案內容為(這裡僅最簡單的,根據工程情況,進行相應的配置):

<?xml version="1.0" encoding="UTF-8"?>
<configuration  scan="true" scanPeriod
="60 seconds" debug="false">
<contextName>logback</contextName> <property name="log.path" value="E:\\test\\logback.log" /> <!--輸出到控制檯--> <appender name="console" class="ch.qos.logback.core.ConsoleAppender"> <!-- <filter class="ch.qos.logback.classic.filter.ThresholdFilter"> <level>ERROR</level> </filter>-->
<encoder> <pattern>%d{HH:mm:ss.SSS} %contextName [%thread] %-5level %logger{36} - %msg%n</pattern> </encoder> </appender> <!--輸出到檔案--> <appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender"> <file
>
${log.path}</file> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <fileNamePattern>logback.%d{yyyy-MM-dd}.log</fileNamePattern> </rollingPolicy> <encoder> <pattern>%d{HH:mm:ss.SSS} %contextName [%thread] %-5level %logger{36} - %msg%n</pattern> </encoder> </appender> <root level="info"> <appender-ref ref="console" /> <appender-ref ref="file" /> </root> <!-- logback為java中的包 --> <logger name="com.dudu.controller"/> <!--logback.LogbackDemo:類的全路徑 --> <logger name="com.dudu.controller.LearnController" level="WARN" additivity="false"> <appender-ref ref="console"/> </logger> </configuration>

注:1、控制檯和日誌檔案的字符集

   2、日誌檔案的存放位置,須要遵守Linux的命名規則

第二步,改造HelloController檔案,改造結果如下

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

@RestController
@RequestMapping("/controller")
public class HelloController {
    @Autowired
    private PersonProperties mPersonProperties;
    protected static Logger logger=LoggerFactory.getLogger(HelloController.class);
    @GetMapping(value="/helloctrl")
    @DeleteMapping
    public String say(@RequestParam(value="id",required=false,defaultValue="20") Integer myid) {
         logger.info("訪問helloName,Name={}",myid);  
         logger.info("訪問");
         logger.error("error");
        return "id"+myid;
    }
}

注:在新增引用時,日誌的包一定是org.slf4j.Logger、org.slf4j.LoggerFactory
第三步、測試

1、執行程式