文章目录
- 一.Hello World的程序
- 1.创建项目
- 2.引入依赖
- 3.创建目录
- 4.编写代码
- 5.打包程序
- 6.部署程序
- 7.验证程序
- 二.简化部署方式
- 1.下载插件
- 2.配置smart Tomcat插件
- 3.测试插件
- 三.常见的servelt问题
- 出现 404
- 出现 405
- 出现 500
- 出现 "空白页面"
- 出现 "无法访问此网站"
- 四.总结
一.Hello World的程序
我们即将进行最复杂的helloworld的程序建立
1.创建项目
创建成功之后,会出现下面的目录
2.引入依赖
为什么我们下载了Tomcat还要引入依赖,有以下几个原因
- 版本控制
Tomcat有不同的版本,如9.x,8.x,7.x等。如果我们直接使用Tomcat提供的jar包,很难管理不同项目使用的Tomcat版本,容易导致版本混乱。
而在Maven中通过声明Tomcat依赖后,Maven会自动操控依赖的版本,下载正确版本的jar包。我们只需要在dependencyManagement中声明使用的Tomcat版本号,就可以轻松控制所有项目的Tomcat版本。 - 依赖传递
Tomcat依赖其他的jar包,如servlet-api、jsp-api等。如果我们手动添加Tomcat的jar包,需要一一添加这些相关依赖,比较繁琐。
而在Maven中,我们只需要引入spring-boot-starter-tomcat这样的启动器依赖,Maven就会自动解析并引入所有相关依赖,简化了我们的配置过程。 - 可移植性
如果我们的项目直接依赖Tomcat的jar包,那么项目只能运行在Tomcat下。
而通过Maven引入Tomcat依赖后,我们的代码实际上是依赖Maven抽象出的Servlet API和JSP API,那么该项目可以运行在任何实现了这些API的服务器下,如Tomcat、Jetty、WebLogic等,具有更好的可移植性。 - 方便管理
有了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究竟做了哪些工作.
- 创建req和resp对象
当有请求访问Servlet时,Tomcat会创建req和resp对象,以代表该次请求和响应。 - 封装请求信息到req对象
Tomcat会解析HTTP请求,获取诸如请求URL、请求参数、Cookie、Session等信息,并封装到req对象中。 - 传入req和resp对象给Servlet
Tomcat会调用Servlet的服务方法,如doGet或doPost,并传入req和resp对象作为参数。 - 获取resp对象的响应
Servlet通过resp对象设置响应 status、header、内容等,Tomcat获取这些响应信息。 - 构造HTTP响应并返回客户端
Tomcat会构造一个HTTP响应,设置Servlet通过resp对象设置的响应状态、头信息和正文内容,并返回给客户端。 - 请求响应结束,关闭req和resp
当整个请求响应流程结束后,Tomcat会关闭req和resp对象。
下面再来看看,这里的Tomcat就是充当服务器的角色.
对Tomcat来说:
- 当Tomcat启动时,它会加载所有的Servlet类。所以Tomcat启动时会加载HelloServlet这个类。
- 当有HTTP GET请求访问该Servlet时,Tomcat会调用HelloServlet类中的doGet方法进行处理。
- 由于HelloServlet类重写了doGet方法,并在方法中调用了父类的doGet方法。所以实际上Tomcat调用doGet方法时,会先执行子类的doGet方法,在该方法中调用父类的doGet方法。
- 如果doGet方法内有其他逻辑,那么Tomcat会执行完父类doGet方法后,再执行该逻辑。
- 请求处理完成后,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包,原因如下:
- 部署方便
war包是一个压缩文件,包含了项目的所有资源,可以直接部署到Tomcat等servlet容器中。不需要将项目的各个部分(类文件、配置文件、静态资源等)分别部署,简化了部署过程,方便运维人员。 - 版本控制
通过war包可以方便地对项目进行版本控制,部署时只需要替换新的war包即可。 - 项目封装
war包将项目所有的构成部分(源码、配置、静态资源等)都封装在一个文件中,对项目的结构和资源进行了封装,便于项目迁移和分发。 - 隔离环境
在开发环境和生产环境使用不同的war包,可以隔离两个环境,避免直接修改生产环境所造成的影响。 - 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应用。