Hi,大家好,我是编程小6,很荣幸遇见你,我把这些年在开发过程中遇到的问题或想法写出来,今天说一说tomcat的默认端口号_tomcat的端口号,希望能够帮助你!!!。
web-4-理解Tomcat中的HTTP请求和Servlet响应处理机制
在网站工作流程介绍,我们已经知道了什么是web(不知道的可以自行查看我的文章进行查看)。那么现在我们学习JavaWeb,什么是JavaWeb现在我们开始学习
JavaWeb: 可以理解为
Java技术开发网站(web),网站结构又分为两种
什么是B/S架构?
B/S 架构:Browser/Server,浏览器/服务器 架构模式。
特点:
B/S架构上网过程如下:
例子:
打开浏览器访问百度首页,输入要搜索的内容,点击回车或百度一下,就可以和搜索相关的内容,这就是一个B/S架构过程
思考:搜索的内容并不在我们自己的点上,那么这些内容从何而来?
答案很明显内容从百度服务器返回给我们的
百度小细节:
逢年过节百度的logo会更换不同的图片,服务端发生变化,客户端不需做任务事情就能最新内容
从上面介绍我们可以发现B/S架构有以下好处:
了解B/S架构后,我们后台开发注意服务端的开发和维护工作。在服务端将来会放很多资源,都有哪些资源存放在服务端?
接下来我们具体介绍一下这些资源
静态资源是指不需要经过服务器处理的文件,例如HTML、CSS、JavaScript、图片等。这些文件的内容在请求时不会发生改变,服务器只需要将它们原封不动地发送给客户端即可。静态资源一般存储在服务器的文件系统中,客户端通过URL直接访问它们。
张三
登录以后在网页的右上角看到的是 张三
,而李四
登录以后看到的则是李四
。所以不同的用户访问相同的资源看到的内容大多数是不一样的,要想实现这样的效果,光靠静态资源是无法实现的。
动态资源是需要服务器在请求时进行一定处理后才能返回给客户端的文件,例如JSP、Servlet、
http://
ASP.NET
等。这些文件包含了动态生成内容的代码,服务器在接收到客户端请求后,会执行相应的处理逻辑,然后生成最终的响应结果返回给客户端。
用户名
和密码
,这个时候我们就又需要解决的一个问题是,用户在注册的时候填入的用户名和密码思考:用户名和密码数据都存储在哪里?我们需要的时候又是从哪里来取呢?
数据就是存储在数据库中,当我们需要的时候从数据库中
(1)浏览器发送一个请求到服务端,去请求所需要的相关资源;
(2)资源分为动态资源和静态资源,动态资源可以是使用Java代码按照Servlet和JSP的规范编写的内容;
(3)在Java代码可以进行业务处理(比如登录,注册等逻辑)也可以从数据库中读取数据;
(4)拿到数据后,把数据交给HTML页面进行展示,再结合CSS和JavaScript使展示效果更好;
(5)服务端将静态资源响应给浏览器;
(6)浏览器将这些静态资源进行解析;
(7)解析后将效果展示在浏览器,用户就可以看到最终的结果。
在整个Web的访问过程中,会设计到很多技术,这些技术有已经学习过的,也有还未涉及到的内容,都有哪些还没有涉及到呢?
到这为止,关于JavaWeb中用到的技术栈我们就介绍完了,这里面就只有HTTP协议、Servlet、JSP以及Tomcat这些知识是没有学习过的,所以整个Web核心主要就是来学习这些技术。
HTTP概念
HyperText Transfer Protocol,超文本传输协议,规定了浏览器和服务器之间
数据传输的规则。
F12
打开开发者工具,点击Network
来查看某一次请求的请求数据和响应数据具体的格式内容,如下图所示:注意:在浏览器中如果看不到上述内容,需要清除浏览器的浏览数据。chrome浏览器可以使用ctrl+shift+Del进行清除。
HTTP主要学习以下两方面内容:
在学习这两方面之前,我们先了解一下HTTP协议特点:
加入购物车
和去购物车结算
是两次请求,会话技术(Cookie、Session)
来解决这个问题。具体如何来做,我们后面会详细讲到。
思考:刚才提到HTTP协议是规定了请求和响应数据的格式,那具体的格式是什么呢?
HTTP-请求协议:浏览器将数据以请求格式发送到服务器
请求方式 | 请求说明 |
---|---|
GET | 资源。 向特定的资源发出请求。例:http://www.baidu.com/s?wd=itheima |
POST | 传输实体主体。 向指定资源提交数据进行处理请求(例:上传文件),数据被包含在请求体中。 |
OPTIONS | 返回服务器针对特定资源所支持的HTTP请求方式。 因为并不是所有的服务器都支持规定的方法,为了安全有些服务器可能会禁止掉一些方法,例如:DELETE、PUT等。那么OPTIONS就是用来询问服务器支持的方法。 |
HEAD | 获得报文首部。 HEAD方法类似GET方法,但是不同的是HEAD方法不要求返回数据。通常用于确认URI的有效性及资源更新时间等。 |
PUT | 传输文件。 PUT方法用来传输文件。类似FTP协议,文件内容包含在请求报文的实体中,然后请求保存到URL指定的服务器位置。 |
DELETE | 删除文件。 请求服务器删除Request-URI所标识的资源 |
TRACE | 追踪路径。 回显服务器收到的请求,主要用于测试或诊断 |
CONNECT | 要求用隧道协议连接代理。 HTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器 |
在我们实际应用中常用的也就是 :GET、POST
GET方式的请求协议:。
请求方式
、资源路径
、协议/版本
组成(之间使用空格分隔) &
连接?
连接常见的HTTP请求头有:
Host: 表示请求的主机名
User-Agent: 浏览器版本。 例如:Chrome浏览器的标识类似Mozilla/5.0 ...Chrome/79 ,IE浏览器的标识类似Mozilla/5.0 (Windows NT ...)like Gecko
Accept:表示浏览器能接收的资源类型,如text/*,image/*或者*/*表示所有;
Accept-Language:表示浏览器偏好的语言,服务器可以据此返回不同语言的网页;
Accept-Encoding:表示浏览器可以支持的压缩类型,例如gzip, deflate等。
Content-Type:请求主体的数据类型
Content-Length:数据主体的大小(单位:字节)
举例说明:服务端可以根据请求头中的内容来客户端的相关信息,有了这些信息服务端就可以处理不同的业务需求。
比如:
POST方式的请求协议:
GET请求和POST请求的区别:
区别方式 | GET请求 | POST请求 |
---|---|---|
请求参数 | 请求参数在请求行中。 例:/brand/findAll?name=OPPO&status=1 |
请求参数在请求体中 |
请求参数长度 | 请求参数长度有限制(浏览器不同限制也不同) | 请求参数长度没有限制 |
安全性 | 安全性低。原因:请求参数暴露在浏览器地址栏中。 | 安全性相对高 |
HTTP-响应协议:服务器将数据以响应格式返回给浏览器
协议及版本
、响应状态码
、状态码描述
组成 常见的HTTP响应头有:
Content-Type:表示该响应内容的类型,例如text/html,image/jpeg ;
Content-Length:表示该响应内容的长度(字节数);
Content-Encoding:表示该响应压缩算法,例如gzip ;
Cache-Control:指示客户端应如何缓存,例如max-age=300表示可以最多缓存300秒 ;
Set-Cookie: 告诉浏览器为当前页面所在的域设置cookie ;
状态码分类 | 说明 |
---|---|
1xx | 响应中 --- 临时状态码。表示请求已经接受,告诉客户端应该继续请求或者如果已经完成则忽略 |
2xx | 成功 --- 表示请求已经被成功接收,处理已完成 |
3xx | 重定向 --- 重定向到其它地方,让客户端再发起一个请求以完成整个处理 |
4xx | 客户端错误 --- 处理发生错误,责任在客户端,如:客户端的请求一个不存在的资源,客户端未被授权,禁止访问等 |
5xx | 服务器端错误 --- 处理发生错误,责任在服务端,如:服务端抛出异常,路由出错,HTTP版本不支持等 |
关于响应状态码,我们先主要认识三个状态码,其余的等后期用到了再去掌握:
服务器硬件
服务器,也称伺服器。是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。
服务器的构成包括处理器、硬盘、内存、系统总线等,和通用的计算机架构类似,但是由于需要提供高可靠的服务,因此在处理能力、稳定性、可靠性、安全性、可扩展性、可管理性等方面要求较高。
在网络环境下,根据服务器提供的服务类型不同,可分为:文件服务器,数据库服务器,应用程序服务器,WEB服务器等。
服务器只是一台设备,必须安装服务器软件才能提供相应的服务。
服务器软件
服务器软件:基于ServerSocket编写的程序
Web服务器是一个应用程序(软件),对HTTP协议的操作进行封装,使得程序员不必直接对协议进行操作(不用程序员自己写代码去解析http协议规则),让Web开发更加便捷。主要功能是
提供网上信息浏览服务。
Web服务器是安装在服务器端的一款软件,将来我们把自己写的Web项目部署到Tomcat服务器软件中,当Web服务器软件启动后,部署在Web服务器软件中的页面就可以直接通过浏览器来访问了。
Web服务器软件使用步骤
介绍了Web服务器软件的使用后,思考一个问题。 思考:Web服务器是指将服务器软件安装到服务器上,那么web服务器有哪些?
我们会从以下这些方向去学习Tomcat:
Tomcat服务器软件是一个免费的开源的web应用服务器。是Apache软件基金会的一个核心项目。由Apache,Sun和其他一些公司及个人共同开发而成。
由于Tomcat只支持Servlet/JSP少量JavaEE规范,所以是一个开源免费的轻量级Web服务器。
JavaEE规范: JavaEE => Java Enterprise Edition(Java企业版)
avaEE规范就是指Java企业级开发的技术规范总和。包含13项技术规范:JDBC、JNDI、EJB、RMI、JSP、Servlet、XML、JMS、Java IDL、JTS、JTA、JavaMail、JAF
因为Tomcat支持Servlet/JSP规范,所以Tomcat也被称为Web容器、Servlet容器。JavaWeb程序需要依赖Tomcat才能运行。
Tomcat的官网: https://tomcat.apache.org/
直接从官方网站下载:https://tomcat.apache.org/download-90.cgi
Tomcat软件类型说明:
安装: Tomcat是绿色版,直接解压即安装
在D盘的tomcat目录下,将
apache-tomcat-9.0.78-windows-x64.zip
进行解压缩,会得到一个
apache-tomcat-9.0.78
的目录,Tomcat就已经安装成功。
注意:Tomcat进行解压缩的时候,最好不要包含中文和空格目录,如果存在可能会存在程序部署失败问题 apache-tomcat-9.0.27
目录就能看到如下目录结构如下:
bin:目录下有两类文件:
.bat
结尾的,是Windows系统的可执行文件.sh
结尾的,是Linux系统的可执行文件。webapps:就是以后项目部署的目录
卸载:卸载比较简单,可以直接删除目录即可
启动Tomcat :
方式一:
方式二:
注意: tomcat服务器启动后,黑窗口不会关闭,只要黑窗口不关闭,就证明tomcat服务器正在运行
Tomcat的默认端口为8080,所以在浏览器的地址栏输入:http://127.0.0.1:8080
即可访问tomcat服务器
127.0.0.1 也可以使用localhost代替。如:
http://localhost:8080
能看到以上图片中内容就说明Tomcat已经启动成功
注意 :Tomcat启动的过程中,遇到控制台有中文乱码时,可以通常修改conf/logging.prooperties文件解决
关闭: 关闭有四种方式
1.强制关闭:直接x掉Tomcat窗口(不建议)
2.正常关闭:双击bin\shutdown.bat
3.正常关闭: 使用cmd命令行输入shutdown.bat
4.正常关闭:在Tomcat启动窗口中按下 Ctrl+C
问题1:Tomcat启动时,窗口一闪而过
问题2:端口号冲突
注: HTTP协议默认端口号为80,如果将Tomcat端口号改为80,则将来访问Tomcat时,将不用输入端口号。
方式一:将项目放置到 webapps 目录下, 即部署完成
a.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>a</title>
</head>
<body>
<h1>Hello A Html</h1>
</body>
</html>
index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Index</title>
</head>
<body>
<h1 style="color: #FF3366">Hello Index</h1>
</body>
</html>
http://localhost:8080/hello/a.html
,能看到下面的内容就说明项目已经部署成功。思考:如何访问http://localhost:8080/hello,会看到什么内容?
默认访问的index.html页面
方式二:将项目压缩文件.war放置到 webapps 目录下, 即部署完成
项目中的资源也会越来越多,项目在拷贝的过程中也会越来越费时间,使用项目压缩文件.war解决
步骤:
介绍完Tomcat的基本使用后,我们来学习在IDEA中如何创建Maven Web项目,学习这种方式的原因是以后Tomcat中运行的绝大多数都是Web项目,而使用Maven工具能更加简单快捷的把Web项目给创建出来,所以Maven的Web项目具体如何来构建呢?
在真正创建Maven Web项目之前,我们先要知道Web项目长什么样子,具体的结构是什么?
Web项目的结构分为:开发中的项目和开发完可以部署的Web项目,这两种项目的结构是不一样的,我们一个个来介绍下:
具体的步骤包含:
1.创建Maven项目
2.选择不使用Web项目骨架
3.输入Maven项目坐标创建项目
4.在pom.xml设置打包方式为war
5.补齐Maven Web项目缺失webapp的目录结构
6.补齐Maven Web项目缺失WEB-INF/web.xml的目录结构
思考:如何在IDEA中能快速使用Tomcat呢?
在IDEA中集成使用Tomcat方式:
目标: 将刚才本地安装好的Tomcat9集成到IDEA中,完成项目部署,具体的实现步骤
扩展内容: xxx.war和 xxx.war exploded这两种部署项目模式的区别?
至此,IDEA中集成本地Tomcat进行项目部署的内容我们就介绍完了
介绍完Servlet是什么以后,接下来我们就按照快速入门
->执行流程
->生命周期
->体系结构
->urlPattern配置
->XML配置
的学习步骤,一步步完成对Servlet的知识学习,首选我们来通过一个入门案例来快速把Servlet用起来。
具体的步骤包含:
1.创建 web项目,导入 Servlet依赖坐标
2.创建:定义一个类,实现 Servlet接口,并重写接口中所有方法,并在 service方法中输入一句话
3.配置:在类上使用@WebServlet 注解,配置该 Servlet的访问路径
4.访问:启动 Tomcat,浏览器输入URL 访问该Servlet
<dependencies>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.1</version>
</dependency>
</dependencies>
package com.zbbmeta.servlet;
import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import java.io.IOException;
@WebServlet("/hello")
public class HelloServlet implements Servlet {
@Override
public void init(ServletConfig config) throws ServletException {
}
@Override
public ServletConfig getServletConfig() {
return null;
}
@Override
public void service(ServletRequest req, ServletResponse res) throws ServletException, IOException {
System.out.println("Hello Servlet ...");
}
@Override
public String getServletInfo() {
return null;
}
@Override
public void destroy() {
}
}
http://localhost:8080/tomcat_one_war_exploded/hello
Hello Servlet ...
说明servlet程序已经成功运行。 Servlet程序已经能正常运行,但是我们需要思考个问题: 我们并没有创建HelloServlet
类的对象,也没有调用对象中的service方法,为什么在控制台就打印了- Hello Servlet ...
这句话呢?
要想回答上述问题,我们就需要对Servlet的执行流程进行一个学习。
http://localhost:8080/tomcat_one_war_exploded/hello
请求,从请求中可以解析出三部分内容,分别是localhost:8080
、tomcat_one_war_exploded
、hello
localhost:8080
可以找到要访问的Tomcat Web服务器tomcat_one_war_exploded
可以找到部署在Tomcat服务器上的web-demo项目hello
可以找到要访问的是项目中的哪个Servlet类,根据@WebServlet后面的值进行匹配小结
介绍完Servlet的执行流程,需要大家掌握两个问题:
Servlet由web服务器创建,Servlet方法由web服务器调用
因为我们自定义的Servlet,必须实现Servlet接口并复写其方法,而Servlet接口中有service方法
介绍完Servlet的执行流程后,我们知道Servlet是由Tomcat服务器帮我们创建的。
思考:Tomcat什么时候创建的Servlet对象?
要想回答上述问题,我们就需要对Servlet的生命周期进行一个学习。
/**
* 默认情况,Servlet会在第一次访问被容器创建,但是如果创建Servlet比较耗时的话,
* 那么第一个访问的人等待的时间就比较长,用户的体验就比较差,
* 那么我们能不能把Servlet的创建放到服务器启动的时候来创建,具体如何来配置?
*/
@WebServlet(value = "/hello",loadOnStartup = 1)
loadOnstartup的取值有两类情况
(1)负整数:第一次访问时创建Servlet对象
(2)0或正整数:服务器启动时创建Servlet对象,数字越小优先级越高
init()
方法初始化这个对象,完成一些如加载配置文件、创建连接等初始化的工作。该方法只调用一次package com.zbbmeta.servlet;
import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import java.io.IOException;
/**
* 默认情况,Servlet会在第一次访问被容器创建,但是如果创建Servlet比较耗时的话,
* 那么第一个访问的人等待的时间就比较长,用户的体验就比较差,
* 那么我们能不能把Servlet的创建放到服务器启动的时候来创建,具体如何来配置?
*/
@WebServlet(value = "/hello",loadOnStartup = 1)
public class HelloServlet implements Servlet {
/**
* 初始化方法
*1.调用时机:默认情况下,Servlet被第一次访问时,调用
* * loadOnStartup: 默认为-1,修改为0或者正整数,则会在服务器启动的时候,调用
* 2.调用次数: 1次
* @param config
* @throws ServletException
*/
@Override
public void init(ServletConfig config) throws ServletException {
System.out.println("Hello Servlet init ...");
}
/**
* 销毁方法
* 1.调用时机:内存释放或者服务器关闭的时候,Servlet对象会被销毁,调用
* 2.调用次数: 1次
*/
@Override
public void destroy() {
System.out.println("Hello Servlet destroy ...");
}
/**
* 提供服务
* 1.调用时机:每一次Servlet被访问时,调用
* 2.调用次数: 多次
* @param req
* @param res
* @throws ServletException
* @throws IOException
*/
@Override
public void service(ServletRequest req, ServletResponse res) throws ServletException, IOException {
System.out.println("Hello Servlet ...");
}
@Override
public ServletConfig getServletConfig() {
return null;
}
@Override
public String getServletInfo() {
return null;
}
}
在控制台的结果:
注意:如何才能让Servlet中的destroy方法被执行?
小结
这节中需要掌握的内容是:
默认是第一次访问的时候被创建,可以使用@WebServlet(value = "/hello",loadOnStartup = 1)的loadOnStartup 修改成在服务器启动的时候创建。
涉及到三个方法,分别是 init()、service()、destroy()
init方法在Servlet对象被创建的时候执行,只执行1次
service方法在Servlet被访问的时候调用,每访问1次就调用1次
destroy方法在Servlet对象被销毁的时候调用,只执行1次
Servlet中总共有5个方法,我们已经介绍过其中的三个,剩下的两个方法作用分别是什么?
我们先来回顾下前面讲的三个方法,分别是:
void init(ServletConfig config)
void service(ServletRequest req, ServletResponse res)
void destroy()
剩下的两个方法是:
String getServletInfo()
//该方法用来返回Servlet的相关信息,没有什么太大的用处,一般我们返回一个空字符串即可
public String getServletInfo() {
return "";
}
ServletConfig getServletConfig()
getServletInfo()和getServletConfig()这两个方法使用的不是很多,大家了解下。
通过上面的学习,我们知道要想编写一个Servlet就必须要实现Servlet接口,重写接口中的5个方法,虽然已经能完成要求,但是编写起来还是比较麻烦的,因为我们更的其实只有service方法,那有没有更简单方式来创建Servlet呢?
要想解决上面的问题,我们需要先对Servlet的体系结构进行下了解:
因为我们将来开发B/S架构的web项目,都是针对HTTP协议,所以我们自定义Servlet,会通过继承HttpServlet
具体的编写格式如下:
package com.zbbmeta.servlet;
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("/httptest")
public class HttpTestServlet extends HttpServlet {
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("httptest doPost ...");
}
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("httptest doGet ...");
}
}
http://localhost:8080/tomcat_one_war_exploded/httptest
,就能看到doGet方法被执行了a.html
页面,内容如下:<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>a</title>
</head>
<body>
<h1>Hello A Html</h1>
<form action="httptest" method="post">
<input name="username"/><input type="submit"/>
</form>
</body>
</html>
启动测试,即可看到doPost方法被执行了。
Servlet的简化编写就介绍完了,接着需要思考两个问题:
针对问题一,我们需要回顾之前的知识点前端发送GET和POST请求的时候,参数的位置不一致,GET请求参数在请求行中,POST请求参数在请求体中,为了能处理不同的请求方式,我们得在service方法中进行判断,然后写不同的业务处理,这样能实现,但是每个Servlet类中都将有相似的代码,针对这个问题,有什么可以优化的策略么?
package com.zbbmeta.servlet;
import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
@WebServlet("/demo1")
public class Demo1Servlet implements Servlet {
@Override
public void init(ServletConfig config) throws ServletException {
}
@Override
public ServletConfig getServletConfig() {
return null;
}
@Override
public void service(ServletRequest req, ServletResponse res) throws ServletException, IOException {
//如何调用?
//请求方式,根据不同的请求方式进行不同的业务处理
HttpServletRequest request = (HttpServletRequest)req;
//1. 请求方式
String method = request.getMethod();
//2. 判断
if("GET".equals(method)){
// get方式的处理逻辑
}else if("POST".equals(method)){
// post方式的处理逻辑
}
}
@Override
public String getServletInfo() {
return null;
}
@Override
public void destroy() {
}
}
要解决上述问题,我们可以对Servlet接口进行继承封装,来简化代码开发。
package com.zbbmeta.servlet;
import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
public class MetaHttpServlet implements Servlet {
@Override
public void init(ServletConfig config) throws ServletException {
}
@Override
public ServletConfig getServletConfig() {
return null;
}
@Override
public void service(ServletRequest req, ServletResponse res) throws ServletException, IOException {
HttpServletRequest request = (HttpServletRequest)req;
//1. 请求方式
String method = request.getMethod();
//2. 判断
if("GET".equals(method)){
// get方式的处理逻辑
doGet(req,res);
}else if("POST".equals(method)){
// post方式的处理逻辑
doPost(req,res);
}
}
protected void doPost(ServletRequest req, ServletResponse res) {
}
protected void doGet(ServletRequest req, ServletResponse res) {
}
@Override
public String getServletInfo() {
return null;
}
@Override
public void destroy() {
}
}
有了MetaHttpServlet这个类,以后我们再编写Servlet类的时候,只需要继承MetaHttpServlet,重写父类中的doGet和doPost方法,就可以用来处理GET和POST请求的业务逻辑。接下来,可以创建Demo2Servlet代码
package com.zbbmeta.servlet;
import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
@WebServlet("/demo2")
public class Demo2Servlet extends MetaHttpServlet {
@Override
protected void doGet(ServletRequest req, ServletResponse res) {
System.out.println("demo2 doGet extends MetaHttpServlet");
}
@Override
protected void doPost(ServletRequest req, ServletResponse res) {
System.out.println("demo2 doPost extends MetaHttpServlet");
}
}
将来页面发送的是GET请求,则会进入到doGet方法中进行执行,如果是POST请求,则进入到doPost方法。这样代码在编写的时候就相对来说更加简单快捷。
类似MetaHttpServlet这样的类Servlet中已经为我们提供好了,就是HttpServlet,翻开源码,大家可以搜索service()
方法,你会发现HttpServlet做的事更多,不仅可以处理GET和POST还可以处理其他五种请求方式。
protected void service(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException
{
String method = req.getMethod();
if (method.equals(METHOD_GET)) {
long lastModified = getLastModified(req);
if (lastModified == -1) {
// servlet doesn't support if-modified-since, no reason
// to go through further expensive logic
doGet(req, resp);
} else {
long ifModifiedSince = req.getDateHeader(HEADER_IFMODSINCE);
if (ifModifiedSince < lastModified) {
// If the servlet mod time is later, call doGet()
// Round down to the nearest second for a proper compare
// A ifModifiedSince of -1 will always be less
maybeSetLastModified(resp, lastModified);
doGet(req, resp);
} else {
resp.setStatus(HttpServletResponse.SC_NOT_MODIFIED);
}
}
} else if (method.equals(METHOD_HEAD)) {
long lastModified = getLastModified(req);
maybeSetLastModified(resp, lastModified);
doHead(req, resp);
} else if (method.equals(METHOD_POST)) {
doPost(req, resp);
} else if (method.equals(METHOD_PUT)) {
doPut(req, resp);
} else if (method.equals(METHOD_DELETE)) {
doDelete(req, resp);
} else if (method.equals(METHOD_OPTIONS)) {
doOptions(req,resp);
} else if (method.equals(METHOD_TRACE)) {
doTrace(req,resp);
} else {
//
// Note that this means NO servlet supports whatever
// method was requested, anywhere on this server.
//
String errMsg = lStrings.getString("http.method_not_implemented");
Object[] errArgs = new Object[1];
errArgs[0] = method;
errMsg = MessageFormat.format(errMsg, errArgs);
resp.sendError(HttpServletResponse.SC_NOT_IMPLEMENTED, errMsg);
}
}
小结
继承HttpServlet
重写doGet和doPost方法
请求方式,并根据不同的请求方式,调用不同的doXxx方法
前面对应Servlet的配置,我们都使用的是@WebServlet,这个是Servlet从3.0版本后开始支持注解配置,3.0版本前只支持XML配置文件的配置方法。
对于XML的配置步骤有两步:
package com.zbbmeta.servlet;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
//@WebServlet("/demo3")
public class Demo3Servlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("demo3 doGet ...");
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("demo3 doPost ...");
}
}
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<!--
Servlet 全类名
-->
<servlet>
<!-- servlet的名称,名字任意-->
<servlet-name>demo3</servlet-name>
<!--servlet的类全名-->
<servlet-class>com.zbbmeta.servlet.Demo3Servlet</servlet-class>
</servlet>
<!--
Servlet 访问路径
-->
<servlet-mapping>
<!-- servlet的名称,要和上面的名称一致-->
<servlet-name>demo3</servlet-name>
<!-- servlet的访问路径-->
<url-pattern>/demo3</url-pattern>
</servlet-mapping>
</web-app>
访问流程如下图:
原创不易,转载请注明出处,感谢支持!如果本文对您有用,欢迎转发分享!
今天的分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。