第一个servlet的程序

news2025/1/21 4:56:32

文章目录

  • 一.Hello World的程序
    • 1.创建项目
    • 2.引入依赖
    • 3.创建目录
    • 4.编写代码
    • 5.打包程序
    • 6.部署程序
    • 7.验证程序
  • 二.简化部署方式
    • 1.下载插件
    • 2.配置smart Tomcat插件
    • 3.测试插件
  • 三.常见的servelt问题
    • 出现 404
    • 出现 405
    • 出现 500
    • 出现 "空白页面"
    • 出现 "无法访问此网站"
  • 四.总结


一.Hello World的程序

我们即将进行最复杂的helloworld的程序建立

1.创建项目

在这里插入图片描述
创建成功之后,会出现下面的目录
在这里插入图片描述

2.引入依赖

为什么我们下载了Tomcat还要引入依赖,有以下几个原因

  1. 版本控制
    Tomcat有不同的版本,如9.x,8.x,7.x等。如果我们直接使用Tomcat提供的jar包,很难管理不同项目使用的Tomcat版本,容易导致版本混乱。
    而在Maven中通过声明Tomcat依赖后,Maven会自动操控依赖的版本,下载正确版本的jar包。我们只需要在dependencyManagement中声明使用的Tomcat版本号,就可以轻松控制所有项目的Tomcat版本。
  2. 依赖传递
    Tomcat依赖其他的jar包,如servlet-api、jsp-api等。如果我们手动添加Tomcat的jar包,需要一一添加这些相关依赖,比较繁琐。
    而在Maven中,我们只需要引入spring-boot-starter-tomcat这样的启动器依赖,Maven就会自动解析并引入所有相关依赖,简化了我们的配置过程。
  3. 可移植性
    如果我们的项目直接依赖Tomcat的jar包,那么项目只能运行在Tomcat下。
    而通过Maven引入Tomcat依赖后,我们的代码实际上是依赖Maven抽象出的Servlet API和JSP API,那么该项目可以运行在任何实现了这些API的服务器下,如Tomcat、Jetty、WebLogic等,具有更好的可移植性。
  4. 方便管理
    有了Maven,我们可以一处管理所有项目的Tomcat版本,一键升级Tomcat版本,而不用一个个项目去更换jar包,更简单易用。
    总之,使用Maven管理Tomcat依赖相比手动引入jar包有许多优势。它可以最大限度减少我们的配置工作,简化依赖管理,提高项目的可移植性,是一个现代Java项目开发的理想状态。

接着我们现在解释了为什么之后,我们只需要在pom.xml里面增加下面的依赖即可.

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

至于这个依赖是怎么来的
参考我下面的步骤
1.进入maven网站
maven网站链接
在这里插入图片描述

2.搜索
在这里插入图片描述
点击选择3.1.0版本
在这里插入图片描述

3.复制
复制到下面的,到pom.xml中
在这里插入图片描述
4.点击刷新
在这里插入图片描述

3.创建目录

分为三个步骤

1.创建webapp目录
2.创建WEB-INF
3.创建一个web.xml
最终目录效果如下:
在这里插入图片描述
4.在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>

web.xml 是给 tomcat 看的:tomcat 从 webapps 目录中加载 webapp,就是以 web.xml 为依据的

4.编写代码

1.创建一个HelloServlet类继承 HttpServlet ,并且重写doGet方法

public class HelloServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    super.doGet(req, resp);


    }
}

当然在编写代码的之前,我要对上述代码展开解析,解释完之后,大家再进入下一个阶段.
具体的解释环节如下:
在这里插入图片描述

先来解释这段代码究竟对于Tomcat究竟做了哪些工作.

  1. 创建req和resp对象
    当有请求访问Servlet时,Tomcat会创建req和resp对象,以代表该次请求和响应。
  2. 封装请求信息到req对象
    Tomcat会解析HTTP请求,获取诸如请求URL、请求参数、Cookie、Session等信息,并封装到req对象中。
  3. 传入req和resp对象给Servlet
    Tomcat会调用Servlet的服务方法,如doGet或doPost,并传入req和resp对象作为参数。
  4. 获取resp对象的响应
    Servlet通过resp对象设置响应 status、header、内容等,Tomcat获取这些响应信息。
  5. 构造HTTP响应并返回客户端
    Tomcat会构造一个HTTP响应,设置Servlet通过resp对象设置的响应状态、头信息和正文内容,并返回给客户端。
  6. 请求响应结束,关闭req和resp
    当整个请求响应流程结束后,Tomcat会关闭req和resp对象。

下面再来看看,这里的Tomcat就是充当服务器的角色.

对Tomcat来说:

  1. 当Tomcat启动时,它会加载所有的Servlet类。所以Tomcat启动时会加载HelloServlet这个类。
  2. 当有HTTP GET请求访问该Servlet时,Tomcat会调用HelloServlet类中的doGet方法进行处理。
  3. 由于HelloServlet类重写了doGet方法,并在方法中调用了父类的doGet方法。所以实际上Tomcat调用doGet方法时,会先执行子类的doGet方法,在该方法中调用父类的doGet方法。
  4. 如果doGet方法内有其他逻辑,那么Tomcat会执行完父类doGet方法后,再执行该逻辑。
  5. 请求处理完成后,Tomcat会继续监听其他请求。

2.编写代码

public class HelloServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//        super.doGet(req, resp);
//这是在服务器的控制台中,打印孕将串(服务器看的到,客户端看不到)
        System.out.println("hello world");
//这是是给 resp 的 body写入hello world字符串.这个内容就会被 HTTP响应返回给浏览器,显示到浏览器页面上

        resp.getWriter().write("hello world");

    }
}

3.增加注解

@WebServlet("/hello")
public class HelloServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//        super.doGet(req, resp);
//这是在服务器的控制台中,打印孕将串(服务器看的到,客户端看不到)
        System.out.println("hello world");
//这是是给 resp 的 body写入hello world字符串.这个内容就会被 HTTP响应返回给浏览器,显示到浏览器页面上

        resp.getWriter().write("hello world");

    }
}

这里加上注释之后,我们到时候就可以运行了.

5.打包程序

至于我们为什么打包程序?
不能直接独立运行,而是必须放到Tomcat上运行.(部署)

使用 maven 进行打包. 打开 maven 窗口 (一般在 IDEA 右侧就可以看到 Maven 窗口, 如果看不到的话,
可以通过 菜单 -> View -> Tool Window -> Maven 打开)
然后展开 Lifecycle , 双击 package 即可进行打包.
在这里插入图片描述
这里要注意一下,我们打成的包是War包,所以我们还要在pom.xml当中加入这样一行代码

  <packaging>war</packaging>
    <build>
        <finalName>hello_servlet</finalName>
    </build>

这里打好的war包如下:
在这里插入图片描述

至于为什么要打war包,原因如下:

  1. 部署方便
    war包是一个压缩文件,包含了项目的所有资源,可以直接部署到Tomcat等servlet容器中。不需要将项目的各个部分(类文件、配置文件、静态资源等)分别部署,简化了部署过程,方便运维人员。
  2. 版本控制
    通过war包可以方便地对项目进行版本控制,部署时只需要替换新的war包即可。
  3. 项目封装
    war包将项目所有的构成部分(源码、配置、静态资源等)都封装在一个文件中,对项目的结构和资源进行了封装,便于项目迁移和分发。
  4. 隔离环境
    在开发环境和生产环境使用不同的war包,可以隔离两个环境,避免直接修改生产环境所造成的影响。
  5. Servlet规范
    根据Servlet规范,Servlet容器会搜索名为“ROOT”的目录及其子目录下的“*.war”后缀的文件,将其作为Web应用进行部署。所以,打成war包符合Servlet标准的Web项目布局。

6.部署程序

部署的操作也非常简单,分几个步骤
1.把打好的war包,复制到tomcat的webapps目录中.
在这里插入图片描述

2.重新打开tomcat,它会自动解压.
在这里插入图片描述

7.验证程序

在浏览器输入,http://127.0.0.1:8080/hello_servelt/hello
这里要对这段url进行说明一下
在这里插入图片描述

最后启动访问的效果如下:
在这里插入图片描述
在这里插入图片描述


二.简化部署方式

看到了上面的操作之后.这些程序你是不是感觉太过于复杂,其实我们在写一个servelt的程序的时候,上面的七个步骤是必须的,但是其中有俩个步骤是可以简化的.
就是打包和部署操作.
这里给出具体的方案:

1.下载插件

在这里插入图片描述
在这里插入图片描述

2.配置smart Tomcat插件

在这里插入图片描述
在这里插入图片描述

3.测试插件

点击运行
在这里插入图片描述
成功后控制台:
在这里插入图片描述

访问:
在这里插入图片描述
smart tomcat的运行方式和之前拷贝到webapps 中,是存在本质区别的.
smart tomcat其实是使用了Tomcat另外一种运行方式.
在运行Tomcat的时候,通过特定的参数,来指定Tomcat加载某个特定目录中的webapp

三.常见的servelt问题

出现 404

  • 资源路径错误,导致Tomcat无法找到资源
  • 资源被删除或重命名了,资源名与路径映射不符

在这里插入图片描述

出现 405

  • 只有doGet()方法,发起POST请求导致405
  • 非法的请求方法,如PUT等

在这里插入图片描述
这里是因为我方法里面写的put请求,但我发起的是get请求
在这里插入图片描述

出现 500

  • Servlet抛出异常未捕获,导致500响应
  • 代码逻辑错误或NullPointException等异常
    在这里插入图片描述
    这里是因为我代码加了一句,所以报了这个错误
String s1=null;
System.out.println(s1.length());

出现 “空白页面”

  • 缺少网页标签闭合或语法错误
  • 没有设置响应内容类型 resp.setContentType()
  • 都输出流关闭太早 resp.getWriter().close()

出现 “无法访问此网站”

  • 服务器停机或维护中
  • 网络连接错误
  • 域名解析错误或不存在
  • 防火墙或安全规则禁止访问
  • 在这里插入图片描述

四.总结

总之,这篇文章对Servlet开发中最基本的几个方面:HelloWorld程序、部署方式和常见问题,进行了较为详细的介绍和总结。掌握这些内容后可以比较顺利地编写一个简单的Servlet Web应用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/573676.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

图像风格迁移

一、简介 图像风格迁移是指&#xff0c;将一副内容图的内容&#xff0c;和一幅或多幅风格图的风格融合在一起&#xff0c;从而生成一些有意思的图片。 我们使用 TensorFlow 和 Keras 分别来实现图像风格迁移&#xff0c;主要用到深度学习中的卷积神经网络&#xff0c;即CNN。…

Transformer应用之构建聊天机器人(二)

四、模型训练解析 在PyTorch提供的“Chatbot Tutorial”中&#xff0c;关于训练提到了2个小技巧&#xff1a; 使用”teacher forcing”模式&#xff0c;通过设置参数“teacher_forcing_ratio”来决定是否需要使用当前标签词汇来作为decoder的下一个输入&#xff0c;而不是把d…

Linux:查看进程。

Linux&#xff1a;查看进程。 windows linux TTY如果是&#xff1f;说明是不是终端(控制台)启动的&#xff0c;而是系统内部自己启动的。 TIME是启动Linux后&#xff0c;这个进程一共占用了cpu多少时间00…

《Spring Guides系列学习》guide46 - guide50

要想全面快速学习Spring的内容&#xff0c;最好的方法肯定是先去Spring官网去查阅文档&#xff0c;在Spring官网中找到了适合新手了解的官网Guides&#xff0c;一共68篇&#xff0c;打算全部过一遍&#xff0c;能尽量全面的了解Spring框架的每个特性和功能。 接着上篇看过的gui…

《Python安全攻防:渗透测试实战指南》极致经典,学完即可包吃包住

前言 网络江湖&#xff0c;风起云涌&#xff0c;攻防博弈&#xff0c;从未间断&#xff0c;且愈演愈烈。从架构安全到被动纵深防御&#xff0c;再到主动防御、安全智能&#xff0c;直至进攻反制&#xff0c;皆直指安全的本质——攻防。未知攻&#xff0c;焉知防! 每一位网络安…

【Python】循环语句 ② ( while 嵌套循环 | 代码示例 - while 嵌套循环 )

文章目录 一、while 嵌套循环1、while 嵌套循环语法2、代码示例 - while 嵌套循环 一、while 嵌套循环 1、while 嵌套循环语法 while 嵌套循环 就是 在 外层循环 中 , 嵌套 内层循环 ; while 嵌套循环 语法格式 : while 外层循环条件:外层循环操作1外层循环操作2while 内存循…

VuePress + GitHub Actions 自动部署

文章目录 前言背景GitHub Actions简介基本概念引用 Actionworkflow 文件 自动部署创建 Action权限问题 小结参考文献 前言 我的第二本开源书籍《后台开发命令 365》上线啦。 为了方便阅读&#xff0c;使用 VuePress 将之前记录的后台常用 Linux 命令博文整理成一个系统的开源…

路径规划算法:基于阴阳对优化的路径规划算法- 附代码

路径规划算法&#xff1a;基于阴阳对优化的路径规划算法- 附代码 文章目录 路径规划算法&#xff1a;基于阴阳对优化的路径规划算法- 附代码1.算法原理1.1 环境设定1.2 约束条件1.3 适应度函数 2.算法结果3.MATLAB代码4.参考文献 摘要&#xff1a;本文主要介绍利用智能优化算法…

Compose 没有 inputType 怎么过滤(限制)输入内容?这题我会!

前言 闲话 在我之前的文章 《Compose For Desktop 实践&#xff1a;使用 Compose-jb 做一个时间水印助手》 中&#xff0c;我埋了一个坑&#xff0c;关于在 Compose 中如何过滤 TextField 的输入内容。时隔好几个月了&#xff0c;今天这篇文章就是来填这个坑的。 为什么需要…

Doris

Aggregate 模型 是相同key的数据进行自动聚合的表模型。表中的列按照是否设置了 AggregationType&#xff0c;分为 Key&#xff08;维度列&#xff09;和 Value&#xff08;指标列&#xff09;&#xff0c;没有设置 AggregationType 的称为 Key&#xff0c;设置了 Aggregation…

散列表(哈希表)

目录 散列表 散列函数 散列表常用函数 1. 直接定址法 2. 除留余数法 2.1. exmple 3. 数字分析法 4. 平方取中法 5. 折叠法 处理冲突的方法 1. 开放定址法---线性探测 2. 二次探测法 3. 再Hash法 4. 拉链法(链地址法) 散列表&#xff08;Hash table&#xff0c;也…

Redis缓存击穿及解决问题

缓存击穿的意思是对于设置了过期时间的key,缓存在某个时间点过期的时候&#xff0c;恰好这时间点对这个 Key有大量的并发请求过来&#xff0c;这些请求发现缓存过期- -般都会从后端DB加载数据并回设到缓存&#xff0c;这个时候大并发的请求可能会瞬间把DB压垮。 解决方案有两种…

第五十四天学习记录:C语言进阶:动态内存管理Ⅱ

常见的动态内存错误 1、对NULL指针的解引用操作 int* p(int*)malloc(4); //p进行相关的判断 *p10;//malloc开辟空间失败&#xff0c;有可能对NULL指针解引用 free(p); pNULL;2、对动态开辟的内存的越界访问 int* p(int*)malloc(40);//10个int if(p!NULL) {int i0;//越界for(…

微服务项目租房网

文章目录 一、租房网项目的介绍1、使用的技术介绍2、使用的组件和开发工具的版本以及作用3、项目模块结构4、项目总体架构 二、环境搭建1、启动前端服务2、CentOS7各个组件的安装2.1 安装Docker2.2 安装JDK2.3 安装Redis(6390)2.4 安装FastDFS(8888)2.5 安装MongoDB(27017)2.6 …

Niagara—— 概述

目录 一&#xff0c;核心组件 Systems Emitters Modules Parameters 二&#xff0c;创建系统或发射器向导 System向导 Emetter向导 三&#xff0c;Niagara VFX工作流程 创建系统 创建或添加发射器 创建或添加模块 Niagara是最新一代VFX系统&#xff0c;无需程序员…

Junit测试框架详解

目录 Junit框架 导入Junit到项目 Junit注解 Test Disabled BeforeAll / AfterAll BeforeEach / AfterEach 参数化 单参数 多参数 CSV获取参数 方法获取参数 断言 assertEquals / assertNotEquals assertNull / assertNotNull 用例执行顺序 测试套件Suite 指定…

使用IIS创建WEB服务

文章目录 前言一、Web服务是什么&#xff1f;1.Web服务概述2.如何获取网页资源3.常见Web服务端软件4.什么是IIS 二、安装IIS1.安装Web服务器角色2.准备网页文件3.配置Web站点4.客户端浏览例&#xff1a;配置IIS站点 三、虚拟主机概述1.虚拟Web主机2.虚拟主机的几种类型3.基于端…

软考信管高级——进度管理

进度管理内容 缩短活动工期方法 赶工&#xff0c;投入更多资源或增加工作时间&#xff0c;以缩短关键活动的工期快速跟进&#xff0c;并行施工&#xff0c;以缩短关键路径长度使用高素质的资源或经验更丰富的人员减小活动范围或降低活动要求改进方法或技术&#xff0c;以提高…

活动回顾|解锁 AIGC 密码,探寻企业发展新商机

5月24日&#xff0c;Google Cloud 与 Cloud Ace 联合主办的线下活动顺利落下帷幕。 本次活动&#xff0c;有近 40 位企业精英到场支持。三位 Google Cloud 演讲嘉宾就本次活动主题&#xff0c;为大家带来了比较深度的演讲内容&#xff0c;干货满满。 &#xff08;*以下的嘉宾演…

期末复习总结【MySQL】聚合查询 + 多表联合查询(重点)

文章目录 前言一、聚合查询1, 聚合函数2, 聚合函数使用示例3, GROUP BY 子句4, HAVING 子句 二、联合查询(重点)1, 笛卡尔积2, 内连接2.1, 示例12.2, 示例22.3, 示例3 3, 外连接4, 自连接 总结 前言 各位读者好, 我是小陈, 这是我的个人主页, 希望我的专栏能够帮助到你: &#…