Tomcat 作為一個(gè)輕量級(jí)服務(wù)器,深受 Java 程序開發(fā)者的青睞,經(jīng)常被應(yīng)用在 JavaWeb 應(yīng)用開發(fā)中。下面,我將和大家分享關(guān)于 SpringBoot 框架是如何將jar進(jìn)行打包,并把 jar 包部署到 Tomcat 服務(wù)器上。
1.詳細(xì)步驟
首先在pom.xml文件中做一些修改:
之前打war包需要修改打包方式,這次不需要了,因?yàn)槟J(rèn)就是 jar 包指定最終打成jar包的名稱手動(dòng)指定 resources 文件夾編譯打包的路徑添加SpringBoot內(nèi)嵌Tomcat解析jsp的依賴(僅僅是為這個(gè)實(shí)例而添加)
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.5</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.songzihao.springboot</groupId>
<artifactId>023-springboot-jar</artifactId>
<version>1.0.0</version>
<properties>
<java.version>11</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
<build>
<finalName>SpringBootJar</finalName>
<resources>
<resource>
<directory>src/main/webapp</directory>
<targetPath>META-INF/resources</targetPath>
<includes>
<include>*.*</include>
</includes>
</resource>
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.*</include>
</includes>
</resource>
</resources>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>1.4.2.RELEASE</version>
</plugin>
</plugins>
</build>
</project>
之后寫一個(gè)控制層,UserController
package com.songzihao.springboot.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import java.util.HashMap;
import java.util.Map;
/**
*
*/
@Controller
public class UserController {
@RequestMapping(value = "/user/detail")
public @ResponseBody Object userDetail() {
Map<String,Object> map=new HashMap<>();
map.put("id",1001);
map.put("username","張起靈");
return map;
}
@RequestMapping(value = "/user/page/detail")
public String userPageDetail(Model model) {
model.addAttribute("id",1001);
model.addAttribute("username","小哥");
return "userDetail";
}
}
在核心配置文件中,配置內(nèi)嵌Tomcat的端口號(hào)、上下文根,以及視圖解析器。
server.port=9090
server.servlet.context-path=/
spring.mvc.view.prefix=/
spring.mvc.view.suffix=.jsp
然后寫一個(gè)控制層中對(duì)應(yīng)的jsp頁面,用做模擬測試。
<%@ page contentType="text/html;charset=utf-8" language="java" %>
<html>
<head>
<title>$</title>
</head>
<body>
<h3>用戶編號(hào):${id}</h3>
<h3>用戶姓名:${username}</h3>
</body>
</html>
最后是SpringBoot項(xiàng)目的入口類。
package com.songzihao.springboot;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
1.1 在IDEA中啟動(dòng)測試
1.2 將項(xiàng)目打包部署之后,再次啟動(dòng)測試
之前打war包之后,我們需要將生成的這個(gè) .war 文件放到Tomcat的 webapps 目錄下。
而這次打的是jar包,生成的是一個(gè).jar 文件,這個(gè)文件我們隨便放在任意一個(gè)目錄下都可以。
將這個(gè) SpringBootJar.jar 拷貝在指定的目錄下,并且在當(dāng)前目錄下,輸入cmd,進(jìn)行命令行窗口。
之后輸入命令:java -jar SpringBootJar.jar ,啟動(dòng)?。?!
1.3 關(guān)于SpringBoot項(xiàng)目打jar包之后,Tomcat的端口號(hào)和上下文根的變化
之前打war包的時(shí)候,將項(xiàng)目部署在Tomcat之后,我們核心配置文件中的Tomcat端口號(hào)、上下文根就都失效了,要以本地Tomcat為準(zhǔn)。
而這次打的是jar包,因?yàn)檫@里并未部署到本地Tomcat,而是說,我們使用的仍然是SpringBoot框架為我們提供的內(nèi)嵌Tomcat,所以這個(gè)時(shí)候起作用的就應(yīng)該是 application.properties 這個(gè)核心配置文件中聲明的端口號(hào)和上下文根了!??!
以上就是關(guān)于 SpringBoot 中是如何將 jar 包打包并將其部署到 Tomcat 服務(wù)器的全部內(nèi)容,想要了解更多相關(guān) SpringBoot 的內(nèi)容請搜索W3Cschool以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,也希望大家以后多多支持!