JavaWeb-Servlet服务连接器(一)

这篇具有很好参考价值的文章主要介绍了JavaWeb-Servlet服务连接器(一)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

JavaWeb-Servlet服务连接器(一),javaweb,servlet

目录

 1.Servlet生命周期

2.Servlet的配置

3.Servlet的常用方法

4.Servlet体系结构

5.HTTP请求报文

6.HTTP响应报文


 1.Servlet生命周期

Servlet(Server Applet)是Java Servlet的简称。其主要的功能是交互式地浏览和修改数据,生成一些动态的Web内容。

 Servlet的生命周期 可以简述为以下几个步骤:

  1. Servlet容器接收到第一个HTTP请求,将其委派给对应的Servlet。
  2. Servlet初始化阶段,容器会调用Servlet的init()方法,用于执行一些初始化操作,比如加载资源、建立数据库连接等。
  3. 在接收到客户端请求时,Servlet容器会调用Servlet的service()方法来处理请求,并根据请求方法(如GET、POST等)决定调用具体的doGet()、doPost()等方法。在这些方法中,开发者可以编写处理请求和生成响应的业务逻辑。
  4. 当Servlet容器关闭或重新加载时,会调用Servlet的destroy()方法用于清理资源、释放连接等操作。
  5. 最后,当没有活跃的请求或超过一定时间限制时,Servlet容器会通过JVM的垃圾回收机制对Servlet进行回收。

2.Servlet的配置

1.通过xml配置

JavaWeb-Servlet服务连接器(一),javaweb,servlet

<!--    servlet声明-->
    <servlet>
        <servlet-name> Servlet名字(自己定义的) </servlet-name>
        <servlet-class> 此处写完整的类名 </servlet-class>
    </servlet>
<!--    servlet访问方式的声明-->
    <servlet-mapping>
        <servlet-name>Servlet名字(自己定义的)</servlet-name>
        <url-pattern>访问路径</url-pattern>
    </servlet-mapping>

2.通过注解配置

可以看到如果增加一个servlet类就需要多进行配置一次非常麻烦,所以官方引入了注解配置(无需再使用web.xml),但是注意注解配置只能在Web Application3.0以上版本才可用

@WebServlet("/" +" 路径名(可以自行设置名称)")

@WebServlet({"/" +" 路径名(可以自行设置名称)","/" +" 路径名(可以自行设置名称)"...})

案例:

JavaWeb-Servlet服务连接器(一),javaweb,servlet


3.Servlet的常用方法

       在实现了Servlet的接口后会出现以下几个方法:(核心在于init(),service();destory()三个生命周期方法)

package com.company;

import javax.servlet.*;
import java.io.IOException;

public class Main  implements Servlet {
//    创建一个ServletConfig对象可以用来接收init传递的servletConfig
    private ServletConfig servletConfig;

//    初始化,在Servlet创建时候自动执行,特点是只会执行一次
    @Override
    public void init(ServletConfig servletConfig) throws ServletException {
//        通过数据范围上升一级实现能够获取ServletConfig信息
        this.servletConfig = servletConfig;
    }
//    获取Servlet类的相关配置数据
    @Override
    public ServletConfig getServletConfig() {
        return servletConfig;
    }
//    提供服务方法,特点是在每一次用户访问时候都能调用方法
    @Override
    public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {
        System.out.println("执行服务方法");
    }
//    获取消息
    @Override
    public String getServletInfo() {
        return null;
    }
//    结束生命周期,在服务器关闭时候执行destroy方法
    @Override
    public void destroy() {

    }
}

案例:

创建一个类叫ServletDemo源码如下:通过实行按Servlet接口并覆写相关方法。找到service方法,在其下输出Hello Servlet和Test

package com.company;


import javax.servlet.*;
import java.io.IOException;

public class ServletDemo implements Servlet {

    @Override
    public void init(ServletConfig servletConfig) throws ServletException {

    }
    @Override
    public ServletConfig getServletConfig() {
        return null;
    }
    //  使用service服务的方法,其他暂时不用管
    @Override
    public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {
        System.out.println("Hello Servlet");
        System.out.println("Test");
    }
    @Override
    public String getServletInfo() {
        return null;
    }
    @Override
    public void destroy() {

    }
}

web.xml配置如下(也可以通过注解配置):

<?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">
<!--配置-->
    <display-name>HelloServlet</display-name>
<!--    servlet声明-->
    <servlet>
<!--        随便创建想要的Servlet名字-->
        <servlet-name> ServletDemo </servlet-name>
<!--        找到servlet对应的类,输入 包.具体类名-->
        <servlet-class> com.company.ServletDemo </servlet-class>
    </servlet>
<!--    servlet访问方式的声明-->
    <servlet-mapping>
<!--        映射Servlet名-->
        <servlet-name>ServletDemo</servlet-name>
<!--        映射路径配置一般就用 "/"+映射类名-->
        <url-pattern>/ServletDemo</url-pattern>
    </servlet-mapping>

</web-app>

 通过输入url并加上对应的路径

JavaWeb-Servlet服务连接器(一),javaweb,servlet

再回到idea中的控制台可以看到能够正常访问

JavaWeb-Servlet服务连接器(一),javaweb,servlet


4.Servlet体系结构

问题引出:通过案例可以发现 我们一般使用资源请求,只会调用到service方法。其他init方法,destroy方法等等我们都不太需要,但是由于Servlet是接口所以需要覆写所有的方法,所以引入了其他类

 Servlet体系结构:

JavaWeb-Servlet服务连接器(一),javaweb,servlet

其中GennericServlet抽象类将除了service的方法默认进行空处理如下所示:

package com.company;

import javax.servlet.GenericServlet;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import java.io.IOException;

public class GenServlet extends GenericServlet {
//    除了service方法其他都不需要覆写
    @Override
    public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {
        System.out.println("我是service方法");
//        判断请求方式
        String method = servletRequest.getMethod();
        if (method.equals("GET")){
            
        }else if (method.equals("POST")){
            
        }
    }
}

 问题引出:可以看到虽然继承了GennericServlet类,但是处理请求数据时候,由于请求方式的不同(请求方式有Get和POST)所以要单独对其进行操作,并且每多一个继承GennericServlet的类就需要再写一边判断请求方式代码,为此又细化分了一个HttpServlet抽象类

HttpServlet自动帮助写完了判断方法,并且带来了方法doGet(),doPOST()

案例代码:

package com.company;

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

//多路径设置
@WebServlet({"/Hello","/Dome","/kimi"})
public class HttpServlet extends javax.servlet.http.HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        System.out.println("GET!!!!!!!!!");
    }
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        System.out.println("POST!!!!!!!!!!!!");
    }
}

在index.jsp中设置一个表单并且可以通过method修改发送方法

JavaWeb-Servlet服务连接器(一),javaweb,servlet

Get方法获取到信息

JavaWeb-Servlet服务连接器(一),javaweb,servlet

 Post方法获取到信息

JavaWeb-Servlet服务连接器(一),javaweb,servlet


5.HTTP请求报文

1.请求报文格式

HTTP 请求报文的格式可分为三个部分:起始行(请求行)、请求头部(Header)和请求体(Body)。

JavaWeb-Servlet服务连接器(一),javaweb,servlet

示例:

GET /index.html HTTP/1.1
Host: www.example.com
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36
Accept-Language: en-US,en;q=0.9
  • 请求行(Request Line):

    • 包含三个要素:HTTP 方法、请求目标(URI/URL)和 HTTP 版本。
    • 示例:GET /index.html HTTP/1.1
  • 请求头部(Headers):

    • 由多个键值对组成,每行一个键值对,用冒号分隔键和值。
    • 可包含多个不同的请求头,如 Host、User-Agent、Content-Type 等。
  • 请求体(Body):

    • 仅在某些请求中存在,用于承载客户端向服务器发送的数据(如 POST、PUT 请求)。
    • 根据不同的应用场景,请求体可以是纯文本、JSON、XML、二进制数据等格式。

 2.请求头部

由关键字和值组成,每行一队,关键字和值之间用“:”隔开

请求头部字段 说明 示例
Host 请求的目标主机的域名或IP地址 Host:www.example.comwww.example.comwww.example.com
User-Agent 发起请求的用户代理信息 User-Agent: Mozilla/5.0
Accept 客户端可接受的响应内容类型 Accept: text/html, application/json
Content-Type 请求中包含的实体的媒体类型 Content-Type: application/json
Authorization 认证信息,用于身份验证 Authorization: Bearer token123
Cookie 之前由服务器通过Set-Cookie设置的cookie Cookie: sessionId=abc123
Referer 表示客户端是从哪个URL跳转过来的 Referer: Example DomainExample DomainExample Domain
Content-Length 请求中的消息体长度 Content-Length: 1024
If-None-Match 用于缓存验证,与资源的ETag进行比较 If-None-Match: "abc123"
If-Modified-Since 用于缓存验证,与资源的最后修改时间进行比较 If-Modified-Since: Tue, 01 Aug 2023 12:00:00 GMT

6.HTTP响应报文

1.响应报文格式

    HTTP 响应报文的格式可分为三个部分:起始行(状态行)、响应头部(Header)和响应体(Body)。

示例:

HTTP/1.1 200 OK
Content-Type: text/html
Content-Length: 1234
Cache-Control: max-age=3600

<!DOCTYPE html>
<html>
<head>
  <title>Welcome</title>
</head>
<body>
  <h1>Hello, World!</h1>
  <p>This is a sample HTML page.</p>
</body>
</html>
  • 状态行(Status Line):

    • 包含三个要素:HTTP 版本、状态码和状态消息。
    • 示例:HTTP/1.1 200 OK
  • 响应头部(Headers):

    • 由多个键值对组成,每行一个键值对,用冒号分隔键和值。
    • 可包含多个不同的响应头,如 Content-Type、Content-Length、Cache-Control 等。
  • 响应体(Body):

    • 用于承载服务器返回给客户端的实际数据内容。
    • 根据不同的应用场景,响应体可以是纯文本、HTML、JSON、XML、二进制数据等格式。

2.常用的状态码

状态码 含义
200 OK - 请求成功完成
301 Moved Permanently - 资源永久重定向到新URL
302 Found - 资源临时重定向到新URL
304 Not Modified - 资源未修改,可以使用缓存的版本
400 Bad Request - 请求无效或非法
403 Forbidden - 拒绝访问,权限不足或被禁止
404 Not Found - 请求的资源不存在
500 Internal Server Error - 服务器内部错误

 3.常用的响应头

响应头部字段 说明 示例
Content-Type 响应中实体的媒体类型 Content-Type: text/html; charset=UTF-8
Content-Length 响应中实体的长度(字节) Content-Length: 1024
Server 服务器软件名称和版本号 Server: Apache/2.4.29 (Unix)
Set-Cookie 服务器设置的cookie信息 Set-Cookie: sessionId=abc123
Last-Modified 资源的最后修改时间 Last-Modified: Tue, 01 Aug 2023 12:00:00 GMT
ETag 资源的实体标识符 ETag: "abc123"
Location 重定向的目标URL Location: Example Domain
Cache-Control 指定响应的缓存机制 Cache-Control: max-age=3600
Content-Encoding 响应实体的压缩编码方式 Content-Encoding: gzip
Access-Control-Allow-Origin 指定允许跨域请求的域名或通配符 Access-Control-Allow-Origin: *

下一篇JavaWeb-Servlet服务连接器(二)_Alphamilk的博客-CSDN博客文章来源地址https://www.toymoban.com/news/detail-641512.html

到了这里,关于JavaWeb-Servlet服务连接器(一)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • JavaWeb-Servlet的应用

    1. HTTP协议 2. HttpServlet 什么是HTTP协议 HTTP 协议一般指 HTTP(超文本传输协议)。超文本传输协议(英语:HyperText Transfer Protocol,缩写:HTTP)是一种用于分布式、协作式和超媒体信息系统的应用层协议,是因特网上应用最为广泛的一种网络传输协议,所有的 WWW 文件都必须遵守

    2024年02月08日
    浏览(32)
  • JavaWeb-Servlet【内含思维导图】

    目录 Servlet思维导图​编辑 1.什么是Servlet 2.Servelt概述 3.Servlet-Quickstart Your Project 3.1创建一个Web项目,导入Servlet依赖 3.1.1 选择Servlet导入依赖       3.1.2 导入Servlet依赖 3.2 在Web项目,定义类,实现Servlet接口,并重写其方法  3.2.1 Servlet 方法介绍 4. Servlet 执行流程  5. Servlet 生命

    2024年02月02日
    浏览(69)
  • Flink 之 Kafka连接器

    Flink附带了一个通用的Kafka连接器,它试图跟踪Kafka客户端的最新版本。Kafka的客户端版本会在Flink不同版本间发生变化。现代Kafka客户端向后兼容broker 0.10.0版本及以后的版本。 用法 Kafka Source 提供了一个构造器类来构建KafkaSource的实例。下面代码展示如何构建一个KafkaSource来消

    2023年04月08日
    浏览(34)
  • 汽车连接器接线端子和多芯线束连接界面

    冷压接的开式压接和闭式压接以及热压接的超声波焊接对汽车连接器接线端子和多芯线束连接界面 连接器接线端子和多芯线束的连接是电子线束行业,特别是汽车行业常用的导线连接方式。汽车整车线束又由许多分支线束组成,而分支线束必须通过连接器实现连接,连接核心

    2024年01月19日
    浏览(41)
  • 【flink sql】kafka连接器

    Kafka 连接器提供从 Kafka topic 中消费和写入数据的能力。 前面已经介绍了flink sql创建表的语法及说明:【flink sql】创建表 这篇博客聊聊怎么通过flink sql连接kafka 以下的连接器元数据可以在表定义中通过元数据列的形式获取。 R/W 列定义了一个元数据是可读的(R)还是可写的(

    2024年02月08日
    浏览(36)
  • 【腾讯云】腾讯云HiFlow场景连接器

    iFlow场景连接器是腾讯云推出的一个免费的应用连接自动化工具。提供助力办公流程自动化的场景连接工具,可以零代码的连接你的多个应用,鼠标轻点即可轻松设置自动化的工作流程数据流程,轻松实现日常办公任务的自动化操作。 通过场景连接器,你可以轻松快速实现如

    2024年02月16日
    浏览(35)
  • 罗技鼠标m590 连接器无法工作

    买了M590,手感不错,一开始可以连接两台设备。但是后来我重置了蓝牙,调换了两台设备的连接方法,,就发现蓝牙可以,连接器不行。 我比较奇怪,按道理一般连接器要比蓝牙方便,但这次为什么蓝牙可以,连接器不行了。然后我又把两个连接方式调换了一下,发现还是

    2024年02月11日
    浏览(78)
  • Semantic Kernel 入门系列:?Connector连接器

    当我们使用Native Function的时候,除了处理一些基本的逻辑操作之外,更多的还是需要进行外部数据源和服务的对接,要么是获取相关的数据,要么是保存输出结果。这一过程在Semantic Kernel中可以被归类为Connector。 Connector更像是一种设计模式,并不像Function和Memory 一样有强制和

    2023年04月15日
    浏览(31)
  • Flink系列之:JDBC SQL 连接器

    Scan Source: Bounded Lookup Source: Sync Mode Sink: Batch Sink: Streaming Append Upsert Mode JDBC 连接器允许使用 JDBC 驱动向任意类型的关系型数据库读取或者写入数据。本文档描述了针对关系型数据库如何通过建立 JDBC 连接器来执行 SQL 查询。 如果在 DDL 中定义了主键,JDBC sink 将以 upsert 模式与外

    2024年02月02日
    浏览(33)
  • Flink系列之:Elasticsearch SQL 连接器

    Sink: Batch Sink: Streaming Append Upsert Mode Elasticsearch 连接器允许将数据写入到 Elasticsearch 引擎的索引中。本文档描述运行 SQL 查询时如何设置 Elasticsearch 连接器。 连接器可以工作在 upsert 模式,使用 DDL 中定义的主键与外部系统交换 UPDATE/DELETE 消息。 如果 DDL 中没有定义主键,那么

    2024年02月04日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包