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

<!--    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({"/" +" 路径名(可以自行设置名称)","/" +" 路径名(可以自行设置名称)"...})

案例:


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并加上对应的路径

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


4.Servlet体系结构

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

 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修改发送方法

Get方法获取到信息

 Post方法获取到信息


5.HTTP请求报文

1.请求报文格式

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

示例:

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设置的cookieCookie: 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.常用的状态码

状态码含义
200OK - 请求成功完成
301Moved Permanently - 资源永久重定向到新URL
302Found - 资源临时重定向到新URL
304Not Modified - 资源未修改,可以使用缓存的版本
400Bad Request - 请求无效或非法
403Forbidden - 拒绝访问,权限不足或被禁止
404Not Found - 请求的资源不存在
500Internal 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重定向的目标URLLocation: Example Domain
Cache-Control指定响应的缓存机制Cache-Control: max-age=3600
Content-Encoding响应实体的压缩编码方式Content-Encoding: gzip
Access-Control-Allow-Origin指定允许跨域请求的域名或通配符Access-Control-Allow-Origin: *

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

python爬虫——爬虫伪装和反“反爬”

前言 爬虫伪装和反“反爬”是在爬虫领域中非常重要的话题。伪装可以让你的爬虫看起来更像普通的浏览器或者应用程序&#xff0c;从而减少被服务器封禁的风险&#xff1b;反“反爬”则是应对服务器加强的反爬虫机制。下面将详细介绍一些常见的伪装和反反爬技巧&#xff0c;并提…

92. 反转链表 II

92. 反转链表 II 题目-中等难度示例1. 获取头 反转中间 获取尾 -> 拼接2. 链表转换列表 -> 计算 -> 转换回链表 题目-中等难度 给你单链表的头指针 head 和两个整数 left 和 right &#xff0c;其中 left < right 。请你反转从位置 left 到位置 right 的链表节点…

【Hilog】鸿蒙系统日志源码分析

【Hilog】鸿蒙系统日志源码分析 Hilog采用C/S结构&#xff0c;Hilogd作为服务端提供日志功能。Client端通过API调用&#xff08;最终通过socket通讯&#xff09;与HiLogd打交道。简易Block图如下。 这里主要分析一下。Hilog的读、写、压缩落盘&#xff0c;以及higlog与android…

图像处理技巧形态学滤波之腐蚀操作

1. 引言 欢迎回来&#xff0c;我的图像处理爱好者们&#xff01;今天&#xff0c;让我们深入研究图像处理领域中的形态学计算。这些非线性的图像处理技术允许我们操纵图像中对象的形状和结构。在本系列中&#xff0c;我们将依次介绍四种基本的形态学操作&#xff1a;腐蚀、膨胀…

PHP最简单自定义自己的框架view使用引入smarty(8)--自定义的框架完成

1、实现效果。引入smarty&#xff0c; 实现assign和 display 2、下载smarty&#xff0c;创建缓存目录cache和扩展extend 点击下面查看具体下载使用&#xff0c;下载改名后放到extend PHP之Smarty使用以及框架display和assign原理_PHP隔壁老王邻居的博客-CSDN博客 3、当前控…

PE启动盘和U启动盘(第三十六课)

PE启动盘和U启动盘(第三十六课) 一 WindowsPE工具盘 1. 制作WinPE镜像光盘 双击WePE64_V2.2-是-点击右下角光盘图标-选择ISO的输出位置-立即生成ISO 2. 通过光盘启动WinPE

Hybrid App 可以从哪些技术路径实现性能优化

说到 Hybrid App&#xff08;混合应用&#xff09;大家都不陌生&#xff0c;因为这种开发模式大行其道发展的这些年取代了很多原生和 Web 应用&#xff0c;为什么大家对这种「Native HTML5」的开发模式额外偏爱呢&#xff1f; 因为一方面在一定程度上兼顾了原生应用的优质体验…

第十九章 重要HL7操作场景

文章目录 第十九章 重要HL7操作场景HL7确认(ACK)模式HL7双确认序列 第十九章 重要HL7操作场景 本章描述了一些影响选择配置设置的关键HL7场景。 HL7确认(ACK)模式 HL7确认(ACK)消息确认目的地已收到HL7消息。负ACK (NACK)消息承认目的地知道传输&#xff0c;但没有捕获该消息…

文盘 Rust -- tokio 绑定 cpu 实践

tokio 是 rust 生态中流行的异步运行时框架。在实际生产中我们如果希望 tokio 应用程序与特定的 cpu core 绑定该怎么处理呢&#xff1f;这次我们来聊聊这个话题。 首先我们先写一段简单的多任务程序。 use tokio::runtime; pub fn main() {let rt runtime::Builder::new_mu…

Webstorm + Egg.js 进行断点调试

Webstorm Egg.js 进行断点调试 1、在工具栏找到编辑配置&#xff0c;创建已运行Node.js 应用程序的调试配置 2、debug调试配置 3、调试 4、查看断点是否起效

win10配置rocketmq

下载地址&#xff1a;下载 | RocketMQ ,版本根据自己情况定&#xff0c;我选用的是4.7.* 1、下载后解压。D:\rocketmq-all-4.7.0-bin-release 2、需要注意一下jdk安装目录的目录名不能有空格&#xff0c;否则会报错找不到JAVA 3、环境变量新增ROCKEMQ_THOMED:\rocketmq-all-4…

将达梦DM8数据库JDBC驱动注册到本地Maven仓库安装

这里写目录标题 1下载DmJdbcDriver18.jar2,以管理员身份运行CMD窗口&#xff0c;然后执行如下安装命令&#xff1a;3.pom文件添加引用 1下载DmJdbcDriver18.jar 我本地放在d:\DmJdbcDriver.jar 2,以管理员身份运行CMD窗口&#xff0c;然后执行如下安装命令&#xff1a; mvn …

iptables端口转发,wireshark抓包分析

app发送请求&#xff0c;到安全交互平台访问服务&#xff0c;app发送请求的ip地址是基站随机分配的&#xff0c;ip地址被拉黑了怎么访问&#xff1f;解决办法&#xff1f; 一开始考虑使用nginx作为代理服务器转发请求&#xff0c;后来在服务器用端口转发解决。 修改nginx配置文…

绽放趋势:Python折线图数据可视化艺术

文章目录 一 json数据格式1.1 json数据格式认识1.2 Python数据和Json数据的相互转换 二 pyecharts模块2.1 pyecharts概述2.2 pyecharts模块安装 三 pyecharts快速入门3.1 基础折线图3.2 pyecharts配置选项3.2.1 全局配置选项 3.4 折线图相关配置3.4.1 .add_yaxis相关配置选项3.…

Netty宝典

文章目录 一.NIO1.简介2.缓冲区(Buffer)3.通道(Channel)4.选择器(Selector)5.原理6.SelectionKey7.ServerSocketChannel 和 SocketChannel8.Socket 二.线程模型1.传统阻塞 I/O 服务模型2.Reactor 模式3.单 Reactor 单线程4.单Reactor多线程5.主从 Reactor 多线程6.为什么用Nett…

P450进阶款无人机室内定位功能研测

在以往的Prometheus 450&#xff08;P450&#xff09;无人机上&#xff0c;我们搭载的是Intel Realsense T265定位模块&#xff0c;使用USB连接方式挂载到机载计算机allspark上&#xff0c;通过机载上SDK驱动T265运行并输出SLAM信息&#xff0c;以此来实现室内定位功能。 为进…

【雕爷学编程】Arduino动手做(24)---水位传感器模块2

37款传感器与模块的提法&#xff0c;在网络上广泛流传&#xff0c;其实Arduino能够兼容的传感器模块肯定是不止37种的。鉴于本人手头积累了一些传感器和执行器模块&#xff0c;依照实践出真知&#xff08;一定要动手做&#xff09;的理念&#xff0c;以学习和交流为目的&#x…

Git (2)

文章目录 1. 删除文件2. 分支管理2.1 理解分支2.2 分支创建 &#xff0c; 分支切换2.3 分支合并2.4 删除分支2.5 合并冲突2.6 合并模式2.7 分支策略2.8 bug 分支2.9 强制删除分支 3. 远程操作3.1 创建远程仓库3.2 克隆远程仓库3.3 推送3.4 拉取3.5 gitignore 文件3.6 配置别名 …

2023-08-11 LeetCode每日一题(矩阵对角线元素的和)

2023-08-11每日一题 一、题目编号 1572. 矩阵对角线元素的和二、题目链接 点击跳转到题目位置 三、题目描述 给你一个正方形矩阵 mat&#xff0c;请你返回矩阵对角线元素的和。 请你返回在矩阵主对角线上的元素和副对角线上且不在主对角线上元素的和。 示例 1&#xff1…
最新文章