1. 程式人生 > 實用技巧 >spring boot:thymeleaf給fragment傳遞引數的方法(spring boot 2.3.3)

spring boot:thymeleaf給fragment傳遞引數的方法(spring boot 2.3.3)

目前,前後端分離的架構已成主流,因此使用springboot構建應用是非常快速的,專案釋出到伺服器上的時候,只需要打成一個jar包,然後通過命令 : java -jar jar包名稱即可啟動服務了;

但在有些場景下,比如部署到外部的伺服器的時候,客戶方指定要以tomcat的形式啟動服務的時候,即需要由服務提供方提供一個war包的時候,該怎麼辦呢?

一開始沒有查詢資料,自己差點準備使用傳統的ssm框架改造服務的,後來思考和參考相關資料後,發現只需要擠出簡單的配置和改造就可以做到,下面是記載將springboot專案改造打包成war的流程,算是一個簡單的參考:

1、pom檔案新增如些依賴,

 <!--新增servlet-api的依賴,用來打war包  -->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <scope>provided</scope>
        </dependency>

這個依賴主要是用於在和jsp進行整合的使用,可酌情新增

2、排除springboot內建的tomcat干擾

 <!--最終打成war包,排除內建的tomcat-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-tomcat</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

有人說也可以新增一個tomcat的依賴,這種方式也許是可以的,但是我沒有嘗試,大多數推薦的還是上面一種,即排除掉內建的tomcat,

 <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-tomcat</artifactId>
      <scope>provided</scope>
</dependency>

3、改造啟動類

改造之前:

@SpringBootApplication
public class MainApp {

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

改造之後:

@SpringBootApplication
public class MainApp extends SpringBootServletInitializer {

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

    @Override
    protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
        return builder.sources(MainApp.class);
    }
}

這種改造方式也是官方比較推薦的方法

4、pom檔案中不要忘了maven編譯外掛

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

當然,在生成環境下,這裡可以做更加精細的配置,

5、如果在idea的環境下,依次執行窗口裡的 clean ,install即可,

執行完畢後,可以看到war包已經生成了,預設是在target目錄下,位置可以在pom檔案中進行配置,

6、使用tomcat進行部署啟動,


可以自己指定啟動埠和訪問的路徑,

然後啟動tomcat,看起來仍然像是springboot的啟動介面,

為了驗證,我們訪問一下專案裡面的介面,這裡訪問我們的swagger,可以看到,已經可以成功訪問了,

專案啟動的時候出現了亂碼,如下所示,

解決辦法如下,新增配置,-Dfile.encoding=UTF-8即可,