Servlet是什么?怎么使用?

简介: 服务器里面资源分为动态资源和静态资源动态资源:Servlet、Jsp静态资源:HTML、CSS、JS

服务器里面资源分为动态资源和静态资源


动态资源:Servlet、Jsp


静态资源:HTML、CSS、JS


一、概念


1.什么是servlet?


本质上是一个接口,提供了规范。是java提供的一门动态的web资源开发技术。


2.servlet体系结构


Servlet(体系根接口)👉GenericServlet(抽象实现类)👉HttpServlet(对Http协议封装的实现类,后期开发基本用这个)


3.servlet生命周期


servlet运行在Servlet容器(web服务器)中, 生命周期由容器来管理,分为四个阶段


1.加载实例化:默认情况下,当Servlet第一次被访问时,由容器创建servlet对象


2.初始化:当Servlet实例化后,容器将调用servlet的init方法去初始化这个对象,完成一些加载配置文件、创建连接等初始化的工作,该方法只调用一次。


3. 请求处理:每次请求处理时,servlet将调用service方法去处理这些请求


4.服务终止:当需要释放内存或者容器关闭时,容器就会调用destroy方法完成资源的释放。然后该实例就会被java的垃圾回收器回收。


二、完整访问过程


1.http(敲门和递名片)


敲门


浏览器去访问网页就是敲服务器家的门,有两种常见的敲门方法


(1)get方式:超链接访问和form提交,不指定method都默认为get方式


(2)post方式:form提交,指定method=post


两种请求方式的区别:


get向服务器获取信息post是提交信息(更安全)


get请求通过URL提交数据,数据可以在URL看到post请求放在请求体中


get请求提交的数据受限制(1kb左右)post请求不受限制


递名片


那敲门请求的时候,要提交名片,让服务器认识你是谁啊。这里就有三种名片


(1)请求行:包含http请求方式、请求资源名称、请求版本

(2)请求头:包含主机请求地址、客户端环境信息、键值对形式传递

(3)请求体:以键值对的post形式传递参数给服务器,服务器收到参数后再进行解析


2.servlet(管家)


作用 接收用户发来的请求---->调用其他程序来处理------->将处理结果返回到服务器里面


情景理解:


服务器收到请求名片后。服务器的管家是servlet。servlet管家给用户开门的。(接收用户发来的请求)


servlet管家问你要干什么啊?


用户:要来这里参观参观


好嘞。于是管家先让儿子init(初始化的方法)去把房子打扫一遍


然后管家又对用户说,你来这里想要吃什么或者干什么,直接叫我儿子service(servletRequest---请求,servletResponse---响应(文章超链接))去处理就好了


等到用户走后,管家又让儿子destroy(关闭的方法)去关门


servlet的5个儿子(方法)


1.init(初始化服务器配置)


2.getServletConfig(获取servlet本身信息的,了解就好)


3.service(逻辑操作)


4.getServletInfo(返回一个字符串信息,了解就好)


5.destroy(释放资源)


总结:servlet全程参与你的访问请求需求过程,但是有什么事情它直接叫儿子(方法)去干就好了。      


三、升级版管家httpservlet(后续开发都用这个)


解释:就是封装http协议并实现了servlet这个接口,根据接收过来的请求类型判断是get还是post,然后去使用对应的get或者post方法去完成对方的请求。后面使用这个servlet管家主要就是使用继承这个httpservlet,去重写实现他的两个儿子方法,分别是doget和dopost。


至于原来的servlet五个儿子方法都已经被封装到里面了,我们看不见而已,但是还是存在的


四、怎么调用自己写的类?


注意点:这两个调用方式只能用一个,不能同时用,要不然会报错的。强烈推荐注解!!!,方便又简洁


被测试的类

package kk;
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("/one")//利用注解的方式调用
public class HttpServletTest extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        System.out.println("doGet");
    }
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        System.out.println("doPost");
    }
}

(1)注解:在调用该类的开头写上注解@WebServlet("/任意自定义名字")


格式为:

@WebServlet("/任意自定义名字")


 如图所示:



浏览器访问方式:https:localhost:8080/maven_java_war/one


(2)在webapp-->WEB-INF---->web.xm这里面配置


格式为:

<servlet>
    <servlet-name>HttpServletTest</servlet-name>
    <servlet-class>kk.HttpServletTest</servlet-class>
</servlet>
<servlet-mapping>
    <servlet-name>HttpServletTest</servlet-name>
    <url-pattern>/one</url-pattern>
</servlet-mapping>

如图所示:



 浏览器访问方式:https:localhost:8080/maven_java_war/one

目录
相关文章
|
SQL Java 关系型数据库
springboot搭建后台框架 (一)整合tkMapper
springboot搭建后台框架 (一)整合tkMapper
121 0
|
Kubernetes Linux Shell
CentOS7下快速搭建K8s集群实践
CentOS7下快速搭建K8s集群实践
818 1
CentOS7下快速搭建K8s集群实践
|
弹性计算 算法 应用服务中间件
nginx配置访问密码,实现用户输入用户名密码才能访
如果我们在 nginx 下搭建了一些站点,但是由于站点内容或者流量的关系,我们并不想让所有人都能正常访问,那么我们可以设置访问认证。只有让用户输入正确的用户名和密码才能正常访问。效果如下:
3329 0
|
8月前
|
监控 前端开发 Java
SpringBoot集成Tomcat、DispatcherServlet
通过这些配置,您可以充分利用 Spring Boot 内置的功能,快速构建和优化您的 Web 应用。
526 21
|
9月前
|
SQL NoSQL 关系型数据库
RDS PostgreSQL版发布 rds_duckdb 插件!
RDS PostgreSQL版内置DuckDB,结合列存储与向量化执行的优势,在RDS PG内实现复杂SQL查询加速和ETL功能,复杂查询效率提升30X,想了解更多rds_duckdb信息和讨论交流,欢迎加入RDS PG插件用户专项服务群(103525002795)
|
10月前
|
设计模式 前端开发 数据安全/隐私保护
前端必须掌握的设计模式——代理模式
代理模式(Proxy Pattern)是一种结构型设计模式,通过引入“替身”对象来间接访问真实对象,从而解耦并提升性能和安全性。例如,知名艺人复出后,经纪人作为代理筛选商单,确保只处理符合团队利益的请求。代码实现中,定义接口`IService`,艺人和经纪人都实现该接口,经纪人在访问时进行过滤和转发。代理模式常用于权限控制、性能优化等场景,如前端中的Tree-shaking和ES6的Proxy构造方法。
前端必须掌握的设计模式——代理模式
|
SQL 存储 关系型数据库
深入OceanBase内部机制:系统架构与组件精讲
深入OceanBase内部机制:系统架构与组件精讲
深入OceanBase内部机制:系统架构与组件精讲
|
测试技术 开发者
单元测试问题之在Mockito中静态方法的调用,如何模拟
单元测试问题之在Mockito中静态方法的调用,如何模拟
|
SQL 监控 安全
架构设计第五讲:数据巡检系统的设计与应用
架构设计第五讲:数据巡检系统的设计与应用
782 0