spring boot项目构建方式

页面上构建

构建页面

springboot中target文件夹的作用 springboot target目录作用_日志文件


springboot中target文件夹的作用 springboot target目录作用_sed_02


springboot中target文件夹的作用 springboot target目录作用_spring_03

maven构建

下面是spring boot项目的目录结构,和maven项目的目录结构十分相似,区别在于resources里面的两个文件夹和一个properties文件。

springboot中target文件夹的作用 springboot target目录作用_spring_04


这是maven的目录结构

springboot中target文件夹的作用 springboot target目录作用_日志文件_05


添加两个文件夹和一个文件就构成了springboot的目录结构

springboot中target文件夹的作用 springboot target目录作用_spring_06


接着就需要引入一些依赖

可以参考springboot的官网

下面这个父依赖一定要写,所有Spring Boot组件的基础引用

<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.1.6.RELEASE</version>
	</parent>

这个springboot插件也必须得加上,提供打包的支持

<plugin>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-maven-plugin</artifactId>
	</plugin>

其次就是springboot项目的启动器,这个根据项目需要的功能配置,这里只是单纯的创建一个web项目,只需要一个web的启动器,这里的web已经集成了springmvc

<dependency>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-web</artifactId>
	</dependency>

需要注意的是web项目也可以打成jar包,因为springboot内置了一个tomcat,只需要一个启动器

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class StartWeb {
    public static void main(String[] args) {
        SpringApplication.run(StartWeb.class,args);
    }
}

需要放在包的最外层,因为springmvc只能自动扫描这个启动器的层级及以下的包内的controller,这里的run方法只是为了执行这个类的加载器,关键在于
SpringBootApplication这个注解

接下来只需要启动这个main函数就可以了

Idea创建spring boot项目(常用)

创建一个Spring Initializr

springboot中target文件夹的作用 springboot target目录作用_sed_07


这里几乎和maven项目创建差不多,可以选择jar包或者war包都行

springboot中target文件夹的作用 springboot target目录作用_spring_08


接着就是选择项目的功能

springboot中target文件夹的作用 springboot target目录作用_spring_09


这样Idea就会自动帮我们创建相关的文件,引入依赖和web启动器

springboot中target文件夹的作用 springboot target目录作用_spring_10

SpringBoot的配置

配置流程

SpringBoot的配置一般是配置在application.properties中

springboot中target文件夹的作用 springboot target目录作用_日志文件_11


下面是配置的参数设置0

springboot中target文件夹的作用 springboot target目录作用_日志文件_12

#服务器端口配置
server.port=80
#调试模式开启(日志级别就是debug)
#debug=true
#上下文配置
server.servlet.context-path=/yoyo
#字符编码
spring.banner.charset=UTF-8
#关闭缓存(开发测试阶段建议关闭缓存)
spring.thymeleaf.cache=false
#日期格式配置(web中)
spring.mvc.date-format=yyyy-MM-dd
#日期格式配置(json中)
spring.jackson.date-format=yyyy-MM-dd
#设置时区
spring.jackson.time-zone=GMT+8
#配置日志输出
#logging.file=d:/logs/log01.log
#设置日志级别
#logging.level.ROOT=INFO
#logging.level.org.springframework=ERROR
#logging.level.org.apache=ERROR

但是这种配置方式并不直观,很容易看漏一些配置,所有还有一种方式来配置,就是使用yml文件来配置

同样建立一个application.yml文件,放在resources文件夹中,这种格式的文件,层次清晰,比起properties文件更容易找到想要查看的属性配置

server:
  port: 80
  servlet:
    context-path: /demo
spring:
  banner:
    charset: utf-8
  thymeleaf:
    cache: false
  mvc:
    date-format: yyyy-MM-dd
  jackson:
    date-format: yyyy-MM-dd
    time-zone: GMT+8

配置参数

常用的参数如下

springboot中target文件夹的作用 springboot target目录作用_日志文件_12

日期配置

这里主要设置两个地方的日期参数

#日期格式配置(web中)
spring.mvc.date-format=yyyy-MM-dd
#日期格式配置(json中)
spring.jackson.date-format=yyyy-MM-dd
#设置时区
spring.jackson.time-zone=GMT+8

spring.mvc.date-format设置的是web接收的请求日期参数,如果没有设置那么会出现以下的异常

springboot中target文件夹的作用 springboot target目录作用_spring_14


spring.jackson.date-format设置的则是json中的日期格式,如果没有设置那么会出现以下的错误输出

springboot中target文件夹的作用 springboot target目录作用_日志文件_15


spring.jackson.time-zone设置的则是时区,因为每个地区的时间不一样,所以需要设置所在的时区,才能显示正确的时间,这里中国是GMT+8

缓存
#关闭缓存(开发测试阶段建议关闭缓存)
spring.thymeleaf.cache=false

只有把spring.thymeleaf.cache设置为false也就是关闭缓存才能在更新页面时无需重启服务器就能刷新页面。

不过还得把下面的设置给勾上才能实现页面刷新。

springboot中target文件夹的作用 springboot target目录作用_sed_16

日志
springboot自带日志
#配置日志输出
logging.file=d:/logs/log01.log
#设置日志级别
logging.level.ROOT=INFO
logging.level.org.springframework=ERROR
logging.level.org.apache=ERROR

logging.file可以设置日志输出的位置

logging.level后面接上.和想要设置输出日志级别的文件

springboot自带的日志并不是很好用,一般都会用其他日志框架的日志

logback日志框架

其实springboot已经整合很多的日志框架,我们如果要使用只需要配置就可以了

springboot中target文件夹的作用 springboot target目录作用_日志文件_17


下面就是logback的配置文件logback.xml,同样只需要放在resources文件夹里就够了

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false">

    <property name="PROJECT" value="mysb1" />
    <!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径-->
    <property name="ROOT" value="d:/logs/${PROJECT}/" />
    <!--日志文件最大的大小-->
    <property name="FILESIZE" value="50MB" />
    <!--日志文件保留天数-->
    <property name="MAXHISTORY" value="100" />
    <timestamp key="DATETIME" datePattern="yyyy-MM-dd HH:mm:ss" />
    <!-- 控制台打印 -->
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder charset="utf-8">
            <pattern>[%-5level] %d{${DATETIME}} [%thread] %logger{36} - %m%n
            </pattern>
        </encoder>
    </appender>
    <!-- ERROR 输入到文件,按日期和文件大小 -->
    <!-- RollingFileAppender 按照每天生成日志文件 -->
    <appender name="ERROR" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <encoder charset="utf-8">
            <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
            <pattern>[%-5level] %d{${DATETIME}} [%thread] %logger{36} - %m%n
            </pattern>
        </encoder>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>ERROR</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!--日志文件输出的文件名-->
            <fileNamePattern>${ROOT}%d/error.%i.log</fileNamePattern>
            <!--日志文件保留天数-->
            <maxHistory>${MAXHISTORY}</maxHistory>
            <timeBasedFileNamingAndTriggeringPolicy
                    class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <!--日志文件最大的大小-->
                <maxFileSize>${FILESIZE}</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
    </appender>

    <!-- WARN 输入到文件,按日期和文件大小 -->
    <appender name="WARN" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <encoder charset="utf-8">
            <pattern>[%-5level] %d{${DATETIME}} [%thread] %logger{36} - %m%n
            </pattern>
        </encoder>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>WARN</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${ROOT}%d/warn.%i.log</fileNamePattern>
            <maxHistory>${MAXHISTORY}</maxHistory>
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>${FILESIZE}</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
    </appender>

    <!-- INFO 输入到文件,按日期和文件大小 -->
    <appender name="INFO" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <encoder charset="utf-8">
            <pattern>[%-5level] %d{${DATETIME}} [%thread] %logger{36} - %m%n
            </pattern>
        </encoder>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>INFO</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${ROOT}%d/info.%i.log</fileNamePattern>
            <maxHistory>${MAXHISTORY}</maxHistory>
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>${FILESIZE}</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
    </appender>
    <!-- DEBUG 输入到文件,按日期和文件大小 -->
    <appender name="DEBUG" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <encoder charset="utf-8">
            <pattern>[%-5level] %d{${DATETIME}} [%thread] %logger{36} - %m%n
            </pattern>
        </encoder>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>DEBUG</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${ROOT}%d/debug.%i.log</fileNamePattern>
            <maxHistory>${MAXHISTORY}</maxHistory>
            <timeBasedFileNamingAndTriggeringPolicy
                    class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>${FILESIZE}</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
    </appender>
    <!-- TRACE 输入到文件,按日期和文件大小 -->
    <appender name="TRACE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <encoder charset="utf-8">
            <pattern>[%-5level] %d{${DATETIME}} [%thread] %logger{36} - %m%n
            </pattern>
        </encoder>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>TRACE</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        <rollingPolicy
                class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${ROOT}%d/trace.%i.log</fileNamePattern>
            <maxHistory>${MAXHISTORY}</maxHistory>
            <timeBasedFileNamingAndTriggeringPolicy
                    class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>${FILESIZE}</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
    </appender>

    <!-- SQL相关日志输出-->
    <logger name="org.apache.ibatis" level="INFO" additivity="false" />
    <logger name="org.mybatis.spring" level="INFO" additivity="false" />
    <logger name="com.github.miemiedev.mybatis.paginator" level="INFO" additivity="false" />

    <!-- Logger 根目录 -->
    <!-- 日志输出级别 -->
    <root level="DEBUG">
        <appender-ref ref="STDOUT" />
        <appender-ref ref="DEBUG" />
        <appender-ref ref="ERROR" />
        <appender-ref ref="WARN" />
        <appender-ref ref="INFO" />
        <appender-ref ref="TRACE" />
    </root>
</configuration>

需要修改的主要就是日志输出的地址和需要输出的日志级别

下面是日志输出的文件夹

springboot中target文件夹的作用 springboot target目录作用_日志文件_18


每个级别的日志文件都可以单独输出到每个文件中

springboot中target文件夹的作用 springboot target目录作用_sed_19


设置需要输出的日志级别

springboot中target文件夹的作用 springboot target目录作用_日志文件_20


更多详细配置参考官网