创建 Maven 版的 Web 工程,打包war包

创建 Maven 版的 Web 工程,打包war包

1. 说明

使用 mvn archetype:generate 命令生成 Web 工程时,需要使用一个专门的 archetype。这个专门生成 Web 工程骨架的 archetype 可以参照官网看到它的用法:

在这里插入图片描述

参数 archetypeGroupId、archetypeArtifactId、archetypeVersion 用来指定现在使用的 maven-archetype-webapp 的坐标。和上一章中的 打包 jar中的: groupld,artfactld,version 表示坐标一个意思:

  • archetypeGroupId: 公司或组织域名的倒序,通常也会加上项目名称
    • 例如:com.baidu.maven,正序:maven.baidu.com 这样的域名,你知道的域名是 com
  • archetypeArtifactId: 模块的名称,将来作为 Maven 工程的工程名
  • archetypeVersion: 模块的版本号,根据自己的需要设定
    • 例如:SNAPSHOT 表示快照版本,正在迭代过程中,不稳定的版本,你不选择的话,默认Maven 就是这个。
    • 例如:RELEASE 表示正式版本

2. 操作

注意:同样的,想要执行 Maven 当中的插件,需要在 pom.xml文件的路径下才行。

注意:就是不能在一个Maven 的工程/模块当中创建,多个 pom.xml 文件,也就是说,不可以在已经存在 Maven的工程/模块当中,再创建一个Maven 的工程/模块,必须要在一个新的文件夹中,创建一个新的Maven工程/模块

如果在上一个工程的目录下执行 mvn archetype:generate 命令,那么 Maven 会报错:不能在一个非 pom 的工程下再创建其他工程。所以不要再刚才创建的工程里再创建新的工程,请回到工作空间根目录来操作。

这里我们在E:\Maven_workspane\spaceVideo 创建一个新的Maven工程/模块,名为:pro02-maven-web

进入该E:\Maven_workspane\spaceVideo路径下,执行命令:执行 mvn archetype:generate 创建一个 Maven工程/模块

注意:创建 web工程是:执行如下命令,大家复制粘贴上去就可以了,不需要修改。

mvn archetype:generate -DarchetypeGroupId=org.apache.maven.archetypes -DarchetypeArtifactId=maven-archetype-webapp -DarchetypeVersion=1.4

在这里插入图片描述

然后运行生成工程的命令:

mvn archetype:generate -DarchetypeGroupId=org.apache.maven.archetypes -DarchetypeArtifactId=maven-archetype-webapp -DarchetypeVersion=1.4

在这里插入图片描述

下面的操作按照提示执行:

Define value for property 'groupId': com.rainbowSea.maven 
Define value for property 'artifactId': pro02-maven-web 
Define value for property 'version' 1.0-SNAPSHOT: :【直接回车,使用默认值】
Define value for property 'package' com.rainbowSea.maven: :【直接回车,使用默认值】
Confirm properties configuration: groupId: com.rainbowSea.maven artifactId: 
pro02-maven-web version: 1.0-SNAPSHOT 
package: com.rainboweSea.maven Y: :【直接回车,表示确认】

在这里插入图片描述

3. 生成的pom.xml

如下在我们的:E:\Maven_workspane\spaceVideo 目录下就生成了一个:pro02-maven-web 文件了。

在这里插入图片描述

同样也是有一个:pom.xml该项目的配置文件的。

在这里插入图片描述

打开它确认打包的方式是不是 war 包形式

<packaging>war</packaging>

在这里插入图片描述

4. 生成的Web工程的目录结构

在这里插入图片描述

webapp 目录下有 index.jsp,WEB-INF 目录下有 web.xml。和我们在Tomcat当中学习的 目录结构是一样的。

5. 创建 Servlet

①在 main 目录下创建 java 目录

在这里插入图片描述

因为我们的 Maven 并没有为我们自动创建好对应是 java的目录结构,需要我们手动创建:

在这里插入图片描述

创建一个 java文件夹

在这里插入图片描述

②在 java 目录下创建 Servlet 类所在的包的目录

在这里插入图片描述

我们的路径为 :E:\Maven_workspane\spaceVideo\ pro02-maven-web\src\main\java\com\rainbowSea\maven

③在包下创建 Servlet 类

在这里插入图片描述

package com.rainbowSea.maven; // 注意需要写明包名
  
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.ServletException;
import java.io.IOException;
  
public class HelloServlet extends HttpServlet{
  
  protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    
    response.getWriter().write("hello maven web");
    
  }
  
}

④在 web.xml 中注册 Servlet

在:pro02-maven-web\src\main\webapp\WEB-INF\web.xml 中注册 Servlet

在这里插入图片描述

  <servlet>
    <servlet-name>helloServlet</servlet-name>
    <servlet-class>com.rainbowSea.maven.HelloServlet</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>helloServlet</servlet-name>
    <url-pattern>/helloServlet</url-pattern>
  </servlet-mapping>

6. 在 index.jsp 页面编写超链接

在:E:\Maven_workspane\spaceVideo\pro02-maven-web\src\main\webapp\index.jsp 路径当中

在这里插入图片描述

<html>
<body>
<h2>Hello World!</h2>
<a href="helloServlet">Access Servlet</a>
</body>
</html>

JSP全称是 Java Server Page,和 Thymeleaf 一样,是服务器端页面渲染技术。这里我们不必关心 JSP 语法细节,编写一个超链接标签即可。

7. 编译

此时直接执行 mvn compile 编译命令出错:

程序包 javax.servlet.http 不存在

程序包 javax.servlet 不存在

找不到符号

符号: 类 HttpServlet

……

在这里插入图片描述

上面的错误信息说明:我们的 Web 工程用到了 HttpServlet 这个类,而 HttpServlet 这个类属于 servlet-api.jar 这个 jar 包。此时我们说,Web 工程需要依赖 servlet-api.jar 包。

在这里插入图片描述

8. 配置对 servlet-api.jar 包的依赖

对于不知道详细信息的依赖可以到https://mvnrepository.com/网站查询。使用关键词搜索,然后在搜索结果列表中选择适合的使用。

在这里插入图片描述

比如,我们找到的 servlet-api 的依赖信息:

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

复制的信息,依赖的 javax.servlet 的jar包的,坐标位置如下:。

<!--为了能够正常使用 HttpServlet,需要导入 servlet-api依赖-->
<!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api -->
<dependency>
    <groupId>javax.servlet</groupId>
    <artifactId>javax.servlet-api</artifactId>
    <version>3.1.0</version>
    <scope>provided</scope>
</dependency>

这样就可以把上面的信息加入 pom.xml。重新执行 mvn compile 命令。

在这里插入图片描述

配置好以后,Ctrl +S 保存以下,我们重新执行mvn compile 编译。

这里我们执行:

mvn clean compile # 先将我们前面生成是.class 文件夹 target 删除了,再重新编译,这样编译的就是最新的了。

在这里插入图片描述

在这里插入图片描述

9. 将 Web 工程打包为 war 包

运行 mvn package 命令,生成 war 包的位置如下图所示:

mvn package

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

10. 将 war 包部署到 Tomcat 上运行

将 war 包复制到 我们安装的Tomcat 服务器当中:Tomcat/webapps 目录下

在这里插入图片描述

启动 Tomcat:

在这里插入图片描述

在这里插入图片描述

通过浏览器尝试访问:http://localhost:8080/pro02-maven-web/index.jsp

在这里插入图片描述

在这里插入图片描述

OK,可以正常运行。

说明:我们封装的 war 包,没有问题,可以正常执行。

11. 最后:感谢

该文章参考了,如下博主的分享。我们再此,真诚的感谢博主的技术的热情的分享。

⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐感谢如下博主的分享 ⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐

【1】:兵器|代码重工

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值