IDEA+Maven+Tomcat构建Web项目的三种方法

  • 2020 年 2 月 19 日
  • 筆記

本文将介绍三种方法,一种是本地计算机已经下载安装了Tomcat,需要将项目的war包放在Tomcat容器中,第二种使用Tomcat的Maven插件嵌入到Maven项目中,该方式不需要本地拥有Tomcat环境,第三种,直接将Tomcat以依赖的方式嵌入进Web项目中。

第一种:容器式

0.准备

本文主要解决在IDEA上开发Maven-webapp项目关联Tomcat的问题。

首先,确保本地计算机下载解压了Tomcat压缩包,以及配置好了Java环境。

1.新建Mavne项目

2.IDEA关联Tomcat

打开项目,点击右上角Edit Configurations…

点开Defaults

配置Tomcat路径

点击 OK,继续点击 APPLY。

3.项目关联Tomcat

参考前面的步骤打开该页面

点击之后,弹出下图,一般来说啥都不需要干。

这里有必要说一下,下面这张图圈出来的路径是IDEA默认在浏览器打开的网址。

点击Deployment,点击右边的+号,这一步是把该项目构建所得的war包与Tomcat进行关联,不进行这一步,那只能404了。

点击OK即可。需要说明的是,因为是Maven web项目,所以默认已经存在弹出的demo:war,如果没有,一定要手动生成!

然后,Ok。

看到下图圈出的路径的吗?这就是配置项目路径的地方,默认/,也就是根目录。你也可以配置为/demo。

回到主页面,点击运行即可。

如果遇到404,检查上面我说的两个路径。

4.如何手动生成Artifact?

第二种:插件式

Maven项目引入依赖Servlet、Jsp等依赖:

       <!--Servlet web相关依赖 -->          <dependency>              <groupId>javax.servlet</groupId>              <artifactId>javax.servlet-api</artifactId>              <version>3.1.0</version>              <scope>provided</scope>          </dependency>          <dependency>              <groupId>javax.servlet.jsp</groupId>              <artifactId>jsp-api</artifactId>              <version>2.2</version>              <scope>provided</scope>          </dependency>          <!--可选的-->          <dependency>              <groupId>taglibs</groupId>              <artifactId>standard</artifactId>              <version>1.1.2</version>          </dependency>          <dependency>              <groupId>jstl</groupId>              <artifactId>jstl</artifactId>              <version>1.2</version>          </dependency>

引入Tomcat插件:

    <build>          <plugins>              <plugin>                  <groupId>org.apache.tomcat.maven</groupId>                  <artifactId>tomcat7-maven-plugin</artifactId>                  <version>2.2</version>                  <configuration>                      <hostName>localhost</hostName>                      <uriEncoding>UTF-8</uriEncoding>                      <path>/</path>                      <port>8080</port>                  </configuration>              </plugin>          </plugins>      </build>

运行当前项目,执行命令:mvn tomcat7:run

这种方式,打包依旧是war包,只是简化了Tomcat环境的搭建,如果想实现类似 Spring Boot 的 main 方法启动内嵌 Tomcat,使 Tomcat 作为 Web 项目的一部分,需要第三种方式。

第三种:内嵌式

Tomcat 官方提供了嵌入包,点击 Download,下载:

解压后导入即可,不过我喜欢用 maven 管理包依赖,所以可以全部替换成如下即可:

<dependency>      <groupId>org.apache.tomcat.embed</groupId>      <artifactId>tomcat-embed-core</artifactId>      <version>9.0.0.M6</version>  </dependency>  <dependency>      <groupId>org.apache.tomcat.embed</groupId>      <artifactId>tomcat-embed-jasper</artifactId>      <version>9.0.0.M6</version>  </dependency>  <dependency>      <groupId>org.apache.tomcat.embed</groupId>      <artifactId>tomcat-embed-el</artifactId>      <version>9.0.0.M6</version>  </dependency>  <dependency>      <groupId>org.apache.tomcat.embed</groupId>      <artifactId>tomcat-embed-websocket</artifactId>      <version>9.0.0.M6</version>  </dependency>  <dependency>      <groupId>org.apache.tomcat</groupId>      <artifactId>tomcat-dbcp</artifactId>      <version>9.0.0.M6</version>  </dependency>  <dependency>      <groupId>org.apache.tomcat.embed</groupId>      <artifactId>tomcat-embed-logging-juli</artifactId>      <version>9.0.0.M6</version>  </dependency>  <dependency>      <groupId>org.apache.tomcat</groupId>      <artifactId>annotations-api</artifactId>      <version>6.0.53</version>  </dependency>  <dependency>  <groupId>org.eclipse.jdt.core.compiler</groupId>      <artifactId>ecj</artifactId>      <version>4.6.1</version>  </dependency>  <dependency>      <groupId>org.apache.logging.log4j</groupId>      <artifactId>log4j-core</artifactId>      <version>2.12.1</version>  </dependency>

笔者后来发现版本也是个坑,读者注意。

新建一个 BootStrap 类并提供一个 Main 方法入口:

public class BootStrap {        public static void main(String[] args) throws LifecycleException, ServletException {          Tomcat tomcat = new Tomcat();          // 设置端口          tomcat.setPort(8080);            // 设置webapp目录,在IDEA运行没问题,打包为jar这一步会错          tomcat.addWebapp("/", BootStrap.class.getResource("/").getPath());            // 设置Tomcat工作目录          tomcat.setBaseDir(".");            // 启动Tomcat          tomcat.start();          tomcat.getServer().await();      }    }

启动这一步应该是没有问题的,但是打包为 jar 包还需要两步,一是打包为 jar 时添加其余依赖,二是指定 jar 包启动时的入口类,可以使用一个 maven 插件解决这个问题:

<plugin>      <groupId>org.apache.maven.plugins</groupId>      <artifactId>maven-assembly-plugin</artifactId>      <version>2.4.1</version>      <configuration>          <archive>              <manifest>                  <mainClass>com.github.yueshutong.BootStrap</mainClass>              </manifest>          </archive>          <descriptorRefs>              <descriptorRef>jar-with-dependencies</descriptorRef>          </descriptorRefs>      </configuration>      <!--下面是为了使用 mvn package命令,如果不加则使用mvn assembly-->      <executions>          <execution>              <id>make-assemble</id>              <phase>package</phase>              <goals>                  <goal>single</goal>              </goals>          </execution>      </executions>  </plugin>

如果webapp目录和resource目录分开,并且没有一同打包,可以手动指定:

<resources>      <resource>          <directory>src/main/resources</directory>          <includes>              <!--包含文件夹以及子文件夹下所有资源-->              <include>**/*.*</include>          </includes>      </resource>      <resource>          <directory>src/main/webapp</directory>          <includes>              <!--包含文件夹以及子文件夹下所有资源-->              <include>**/*.*</include>          </includes>      </resource>  </resources>

最后当你启动 jar 包,你会发现该应用启动失败,会提示你Webapp目录设置失败,因为你的webapp目录下的 jsp、html 等资源都被打包进了 jar 包内。

对此,我能想到的办法就是设定程序去解压 jar 包,感兴趣的小伙伴可以尝试下。

参考

https://geek-docs.com/servlet/servlet-tutorial/embeddedtomcat.html