【JavaEE】如何创建一个Servlet程序(包括如何使用smart Tomcat)保姆级教程

1. Servlet概念

Servlet 是一种实现动态页面的技术. 是一组 Tomcat 提供给程序猿的 API, 帮助程序猿简单高效的开发一个 web app.

构建动态页面的技术有很多, 每种语言都有一些相关的库/框架来做这件事.

Servlet 就是 Tomcat 这个 HTTP 服务器提供给 Java 的一组 API, 来完成构建动态页面这个任务.

2. Servlet 主要做的工作

  • 允许程序猿注册一个类, 在 Tomcat 收到某个特定的 HTTP 请求的时候, 执行这个类中的一些代码.
  • 帮助程序猿解析 HTTP 请求, 把 HTTP 请求从一个字符串解析成一个 HttpRequest 对象.
  • 帮助程序猿构造 HTTP 响应. 程序猿只要给指定的 HttpResponse 对象填写一些属性字段, Servlet 就会自动的安装 HTTP 协议的方式构造出一个 HTTP 响应字符串, 并通过 Socket 写回给客户端.

简而言之, Servlet 是一组 Tomcat 提供的 API, 让程序猿自己写的代码能很好的和 Tomcat 配合起来, 从而更简单的实现一个 web app. 而不必关注 Socket, HTTP协议格式, 多线程并发等技术细节, 降低了 web app 的开发门槛, 提高了开发效率.

3. 创建第一个 Servlet 程序

3.1 创建项目 (maven项目)

在这里插入图片描述

3.2 引入依赖(把servlet的jar给引入过来)

Maven 项目创建完毕后, 会自动生成一个 pom.xml 文件.
我们需要在 pom.xml 中引入 Servlet API 依赖的 jar 包

  • 中央仓库中搜索 “servlet”, 一般第一个结果就是.
    在这里插入图片描述
  • 选择版本. 一般使用 3.1.0 版本
    在这里插入图片描述
    Servlet 的版本要和 Tomcat 匹配.
    如果我们使用 Tomcat 8.5, 那么就需要使用 Servlet 3.1.0

可以在 点此跳转查询 这个链接查询版本对应关系.
在这里插入图片描述

  • 把中央仓库中提供的 xml 复制到项目的 pom.xml 中
    在这里插入图片描述
    修改后的 pom.xml 形如
    在这里插入图片描述

<dependencies> 标签内部放置项目依赖的 jar 包. 粘贴对应的xml代码后,maven 会自动下载依赖到本地.

补充 :关于 groupId, artifactId, version
如果要把写的代码发布到中央仓库上, 就需要设定好这几个 ID .
groupId: 表示组织名称
artifactId: 表示项目名称
version: 表示版本号
中央仓库是按照这三个字段来确定唯一一个包的.
在这里插入图片描述

红色方框圈出来的部分, 就是这个 jar 包的 groupId, artifactId, version

3.3 创建目录

当项目创建好了之后, IDEA 会帮我们自动创建出一些目录. 形如
在这里插入图片描述

这些目录的含义:

  • src 表示源代码所在的目录
  • main/java 表示源代码的根目录. 后续创建 .java 文件就放到这个目录中.
  • main/resources 表示项目的一些资源文件所在的目录. 此处暂时不关注.
  • test/java 表示测试代码的根目录. 此处暂时不关注.

这些目录还不够, 我们还需要创建一些新的目录/文件:

  • 创建 webapp 目录
    在 main 目录下, 和 java 目录并列, 创建一个 webapp 目录 (注意, 不是 webapps).
    在这里插入图片描述
  • 创建 web.xml
    然后在 webapp 目录内部创建一个WEB-INF 目录, 并创建一个 web.xml 文件
    在这里插入图片描述
  • 编写 web.xml
    往 web.xml 中拷贝以下代码.
<!DOCTYPE web-app PUBLIC
        "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
        "http://java.sun.com/dtd/web-app_2_3.dtd" >

<web-app>
    <display-name>Archetype Created Web Application</display-name>
</web-app>

webapp 目录就是未来部署到 Tomcat 中的一个重要的目录. 当前我们可以往 webapp 中放一些静态资源, 比如 html , css 等.
在这个目录中还有一个重要的文件 web.xml. Tomcat 找到这个文件才能正确处理 webapp 中的动态资源.

3.4 编写代码

在 java 目录中创建一个类 HelloServlet, 代码如下:

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@WebServlet("/hello")
public class HelloServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        System.out.println("hello world");
        resp.getWriter().write("hello world !"+System.currentTimeMillis());
    }
}

  • 创建一个类 HelloServlet , 继承自 HttpServlet
  • 在这个类上方加上 @WebServlet("/hello") 注解, 表示 Tomcat 收到的请求中, 路径为 /hello的请求才会调用 HelloServlet 这个类的代码. (这个路径未包含 Context Path),这个路径表示的是servlet path
  • 重写 doGet 方法. doGet 的参数有两个, 分别表示收到的 HTTP 请求 和要构造的 HTTP 响应. 这个方法会在 Tomcat 收到 GET 请求时触发
  • HttpServletRequest 表示 HTTP 请求. Tomcat 按照 HTTP 请求的格式把 字符串 格式的请求转成了一个 HttpServletRequest 对象. 后续想获取请求中的信息(方法, url, header, body 等) 都是通过这个对象来取.
  • HttpServletResponse 表示 HTTP 响应. 代码中把响应对象构造好(构造响应的状态码, header, body 等)
  • resp.getWriter() 会获取到一个流对象, 通过这个流对象就可以写入一些数据, 写入的数据会被构造成一个 HTTP 响应的 body 部分, Tomcat 会把整个响应转成字符串, 通过 socket 写回给浏览器.

这里写的代码并不是一个完整的程序, 而是 Tomcat 这个程序的一小部分逻辑,此时这里写的代码不是通过 main 方法作为入口了. main 方法已经被包含在 Tomcat 里, 这里的代码会被Tomcat 在合适的时机调用起来.

Tomcat 调用代码需要满足这三个条件 :

  • 创建的类需要继承自 HttpServlet
  • 这个类需要使用 @WebServlet 注解关联上一个 HTTP 的路径
  • 这个类需要实现 doXXX 方法

当这三个条件都满足之后, Tomcat 就可以找到这个类, 并且在合适的时机进行调用.

3.5 打包程序

使用 maven 进行打包. 打开 maven 窗口 (一般在 IDEA 右侧就可以看到 Maven 窗口, 如果看不到的话,
可以通过 菜单 -> View -> Tool Window -> Maven 打开)
在这里插入图片描述
打包成功的话, 能够看到 SUCCESS 这样的字样.
在这里插入图片描述
打包成功后, 可以看到在 target 目录下, 生成了一个 jar 包 ,

但是这样的 jar 包并不是我们需要的, Tomcat 需要识别的是另外一种 war 包格式.

补充 :
war 包和 jar 包的区别:
jar 包是普通的 java 程序打包的结果. 里面会包含一些 .class 文件.
war 包是 java web 的程序, 里面除了会包含 .class 文件之外, 还会包含 HTML, CSS, JavaScript, 图片, 以及其他的 jar 包. 打成 war 包格式才能被 Tomcat 识别.

在 pom.xml 中新增一个 packing 标签, 表示打包的方式是打一个 war 包.
在这里插入图片描述
还可以在 pom.xml 中再新增一个 build 标签, 内置一个 finalName 标签, 实现重命名打出来的这个war包,表示打出的 war 包的名字是 hello
在这里插入图片描述

完整的 pom.xml 代码:

<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.example</groupId>
    <artifactId>servelet_project</artifactId>
    <version>1.0-SNAPSHOT</version>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>

    <dependencies>
        <!-- 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>

    </dependencies>

    <packaging>war</packaging>
    <build>
        <finalName>hello</finalName>
    </build>

</project>

重新使用 maven 打包, 可以看到生成的新的 war 包的结果 :
在这里插入图片描述

3.6 部署程序

把 war 包拷贝到 Tomcat 的 webapps 目录下.
启动 Tomcat , Tomcat 就会自动把 war 包解压缩.
在这里插入图片描述
看到这个日志说明 Tomcat 已经正确识别了 hello102 这个 webapp.
在这里插入图片描述

3.7 验证程序

此时通过浏览器访问 http://127.0.0.1:8080/hello102/hello :就可以看到结果了
在这里插入图片描述

注意: URL 中的 PATH 分成两个部分, 其中 hello102 为 Context Path, hello 为 Servlet Path

4. 使用idea smart Tomcat 插件进行部署(更方便的部署方式)

手动拷贝 war 包到 Tomcat 的过程比较麻烦. 我们还有更方便的办法.
此处我们使用 IDEA 中的 Smart Tomcat 插件完成这个工作.

4.1 安装 Smart Tomcat 插件

菜单 -> 文件 -> Settings
在这里插入图片描述
选择 Plugins, 选择 Marketplace, 搜索 “tomcat”, 点击 “Install”.
在这里插入图片描述

4.2 配置 Smart Tomcat 插件

点击右上角的 “Add Configuration”
在这里插入图片描述
选择左侧的 “Smart Tomcat”
在这里插入图片描述
在 Name 这一栏填写一个名字(可以随便写)
在 Tomcat Server 这一栏选择 Tomcat 所在的目录. 其他的选项不必做出修改. (使用默认)
在这里插入图片描述
点击 OK 之后, 右上角变成了
在这里插入图片描述
点击绿色的三角号, IDEA 就会自动进行编译, 部署, 启动 Tomcat 的过程.
在这里插入图片描述
(此时 Tomcat 日志就会输出在 IDEA 的控制台中, 可以看到现在就不再乱码了. )

访问页面:
在浏览器中使用 http://127.0.0.1:8080/hello102/hello 访问页面.(这次在代码中加上了显示当前时间戳的功能,以验证动态页面的实现)
在这里插入图片描述

注意路径的对应关系.
在这里插入图片描述
使用 Smart Tomcat 部署的时候, 我们发现 Tomcat 的 webapps 内部并没有被拷贝一个 war 包, 也没有看到解压缩的内容.
Smart Tomcat 相当于是在 Tomcat 启动的时候直接引用了项目中的 webapp 和 target 目录.

在这里插入图片描述

  • over ~ ✨
  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值