Java安全基础(二)Servlet核心技术

news2025/1/18 9:10:09

因为在实习中,文章更新速度可能有点慢,初学JAVA安全,内容如有不恰当的地方,欢迎各位大佬指正。

今天写一下Servlet的一些核心技术,后面更新完Filter之后我会对这两个进行一个总结。

了解Servlet知识对后续的框架审计有一定的帮助。代码审计中我们可以选择Servlet入手,也可以选择从漏洞点反推出Http请求的入口地址。

一、Servlet的配置

不同的版本的Servlet配置不同,Servlet3.0之前的版本都是在web.xml中配置的,而Servlet3.0之后的版本则使用更为便捷的注解方式来配置。此外,不同版本的Servlet所需的Java/JDK版本也不相同。

1.1、Servlet的配置-基于web.xml

<servlet>—— 声明servlet配置入口
<description>—— 声明servlet描述信息
<display-name>——— 定义WEB
<servlet-name>—— 声明Servlet名称以便在后面的映射时使用
<servlet-class>—— 指定当前servlet对应的类的路径
<servlet-mapping>—— 注册组件访问配置的路径入口
<servlet-name>—— 指定上文配置的Servlet的名称
<url-pattern>—— 指定配置这个组件的访问路径  

二、Servlet的访问流程

我们以如下的配置文件举例

首先在浏览器地址栏中输入user,即访问url-pattern标签中的值,然后浏览器发起请求,服务器通过servlet-
mapping标签中找到文件名为user的url-pattern,通过其对应的servlet-name寻找servlet标签中servlet-
name相同的servlet,再通过servlet标签中servlet-name,获取servlet-
class参数,最终得到具体的class文件路径,继而执行servlet-class标签中class文件的逻辑。

从上述过程中可以看出,servlet和servlet-mapping中都含有</servlet-
name>标签,其主要原因是通过servlet-name作为纽带,将servlet-class和url-
pattern构成联系,从而使url映射到servlet-class所指定的类中执行相应逻辑。

首先在浏览器地址栏中输入user,即访问url-pattern标签中的值,然后浏览器发起请求,服务器通过servlet-
mapping标签中找到文件名为user的url-pattern,通过其对应的servlet-name寻找servlet标签中servlet-
name相同的servlet,再通过servlet标签中servlet-name,获取servlet-
class参数,最终得到具体的class文件路径,继而执行servlet-class标签中class文件的逻辑。

从上述过程中可以看出,servlet和servlet-mapping中都含有</servlet-
name>标签,其主要原因是通过servlet-name作为纽带,将servlet-class和url-
pattern构成联系,从而使url映射到servlet-class所指定的类中执行相应逻辑。

三、Servlet的接口方法

HTTP有8中请求方式,分别为,GET、POST、HEAD、OPTIONS、PUT、DELETE、TRACE以及CONNECT方法.与此类似,Servlet接口中也对于着响应的请求接口:GET、POST、HEAD、PUT、DELETE、OPTIONS以及TRACE,这些接口对应着请求类型,service()方法会检查HTTP请求类型,然后在适当的时候调用doGet、doPost、doPost、doPut、doDelete等方法。

3.1、Servlet的接口方法 - init()接口

在Servlet实例化后,Servlet容器会巧用init()方法来初始化该对象,主要是为例使Servlet对象在处理客户请求钱可以完成一些初始化工作,例如建立数据库的连接,获取配置信息等。init()方法在第一次创建servlet时被调用,在后续每次用户请求时不在被调用。

在init()方法中有一个ServletConfig参数,ServletConfig代表的是配置信息,即在web.xml中配置的信息。

3.2、Servlet的接口方法 - service()接口

service()方法是执行实际任务的主要方法,Servlet容器(即web服务器)调用service()方法来处理来自客户端(浏览器)的请求,并将格式化的响应写回给客户端,每次服务器接收到一个servlet请求时,服务器会产生一个新的线程并调用服务。要注意的是,在service()方法被Servlet容器调用之前,必须确保init()方法正确完成。

一般来说service方法是不需要重写的,因为在HttpServlet中已经有了很好的实现,它会根据请求的方法名(GET,POST),调用doGet,doPos以及其他的doXXX方法,也就是说service是用来转向的,所以我们一般写一个servlet,只需要重写doGet或者doPost就可以了。

3.3、Servlet的接口方法 - doGet() && doPost()接口

doGet()等方法根据HTTP的不同请求调用不同的方法,如果HTTP得到一个来自URL的GET请求,就会调用doGet()方法;如果得到的是一个POST请求,就会调用doPost()方法。

在servlet中默认情况下,无论你是get还是post提交过来都会经过service()方法来处理,然后转向到doGet或者是doPost方法。

下面是自动生成的doGet()和doPost方法

3.4、Servlet的接口方法 - 其他接口

  • destory()接口

当Servlet容器检测到一个Servlet对象应该从服务中被移除时,就会调用该对象的destroy()方法,以便Servlet对象释放它所使用的资源,保存数据到持久存储设备中,例如将内存中的数据保存到数据库中、关闭数据库连接、停止后台线程、把Cookie列表或点击计数器写到磁盘,并执行其他类似的清理活动。destory()方法与init()方法相同,只会被调用一次。

  • getServeltConfig()接口

getServletConfig()方法返回Servlet容器调用init()方法时传递给Servlet对象的ServletConfig对象,ServletConfig对象包含Servlet的初始化参数。开发者可以在Servlet的配置文件web.xml中,使用标签为servlet配置一些初始化参数。

  • getServletInfo()接口

getServletInfo()方法会返回一个String类型的字符串,包括关于Servlet的信息,如作者、版本及版权等。

四、Servlet的生命周期

我们常说的Servlet生命周期指的是servlet从创建直到销毁的整个过程,在一个生命周期中,Servlet经历了被加载、初始化、接收请求、响应请求以及提供服务的过程

当用户第一次向服务器发起请求时,服务器会解析用户的请求,此时容器会加载Servlet,然后创建Servlet实例,再初始化servlet调用init()方法,紧接着调用服务的service()方法去处理用户GET、POST或者其他类型的请求。当执行完Servlet中对应class文件的逻辑后,将结果返回给服务器,服务器再响应用户请求,当服务器不再需要Servlet实例或重新载入servlet实例或重新载入servlet时会调用destory()方法,借助该方法,Servlet可以释放掉所以在init()方法中申请的资源。

五、总结

  • 从本质上来说JSP就是一个Servlet,因为JSP文件最终会被编译成class文件,而这个Class文件实际上就是一个特殊的Servlet

  • Spring MVC框架是基于Servlet技术实现的

  • 代码审计中我们可以选择Servlet入手,也可以选择从漏洞点反推出Http请求的入口地址

  • 了解Servlet知识对后续的框架审计有一定的帮助

  • Spring MVC框架是基于Servlet技术实现的

  • 代码审计中我们可以选择Servlet入手,也可以选择从漏洞点反推出Http请求的入口地址

  • 了解Servlet知识对后续的框架审计有一定的帮助

网络安全工程师企业级学习路线

这时候你当然需要一份系统性的学习路线

如图片过大被平台压缩导致看不清的话,可以在文末下载(无偿的),大家也可以一起学习交流一下。

一些我收集的网络安全自学入门书籍

一些我白嫖到的不错的视频教程:

上述资料【扫下方二维码】就可以领取了,无偿分享

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

自媒体人绝对要知道的6款软件工具!免费文案、配音不在话下

NO.1丨喵盐配音&#xff08;小程序&#xff09; 喵盐配音&#xff0c;它是我近期使用次数较多的配音小程序。这是一款专注于文字转语音的智能语音合成小程序&#xff0c;不需要下载&#xff0c;v小橙序搜索在线使用。其拥有200多个抖音热门发音人&#xff0c;支持普通话、英语、…

更安全的ftp服务器Pure-FTP搭建(4)

实验简介 实验所属系列&#xff1a;Linux服务器搭建 实验对象&#xff1a; 本科/专科信息安全专业 相关课程及专业&#xff1a;计算机基础&#xff0c;计算机网络 实验时数&#xff08;学分&#xff09;&#xff1a;2学时 实验类别&#xff1a;实践类预备知识 本实验要求实验者…

【JVM】Java类加载机制详解

【JVM】Java类加载机制详解 文章目录【JVM】Java类加载机制详解一&#xff1a;类加载子系统1&#xff1a;类加载器子系统的作用2&#xff1a;加载器 ClassLoader 的角色二&#xff1a;类的加载过程1&#xff1a;加载阶段2&#xff1a;验证阶段&#xff1a;确保被加载的类的正确…

[leetcode 215] 数组中的第K个最大元素

题目 题目&#xff1a;https://leetcode.cn/problems/kth-largest-element-in-an-array/description/ 解法 这道题目目前快排可以直接过&#xff0c;但是时间复杂度是 O(nlogn)O(nlogn)O(nlogn)。 想要 O(n)O(n)O(n)&#xff0c;这就涉及到408考研知识点了&#x1f602;&…

Java高手速成 | 使用TCP进行手机文件传输

由于TCP是面向流的&#xff0c;这意味着接收端有可能会在一次接收动作中接收两个或者多个数据包&#xff0c;那么当发送方需要把一个大文件分批连续发送时&#xff0c;如何保证接收方能够正确地接收并重修组会成一个完整的文件显得十分重要&#xff0c;本节通过一个端到端的手机…

每天10个前端小知识 【Day 4】

前端面试基础知识题 1. js中如何判断一个值是否是数组类型&#xff1f; instanceof const arr []; arr instanceof Array; // true Array.isArray const arr []; Array.isArray(arr) // true const obj {}; Array.isArray(obj) // false Object.prototype.isPrototype…

拉伯证券|A股延续强势格局 北向资金开年以来净买入超1500亿元

周四&#xff0c;A股商场整体延续强势格局&#xff0c;沪指贴合5日均线震动向上。科技板块仍是干流热点&#xff0c;半导体板块大面积飘红&#xff0c;创新药、CRO等生长赛道均涨势杰出。 到收盘&#xff0c;上证综指报3285.67点&#xff0c;涨0.02%&#xff1b;深证成指报1213…

初识SpringSecurity

初识SpringSecurity spring-security在spring的官网即可找到 spring-security spring-security官方文档的地址 https://docs.spring.io/spring-security/site/docs/ spring-security是Spring系列的关于安全的框架&#xff0c;还有一套安全的框架是Shiro 环境的搭建 项目使…

Android 播放base64音频

需求描述&#xff1a; 做一个Android扫码验证入场的程序&#xff1a; 如果验证通过&#xff0c;则播放一段“验证通过&#xff0c;请放行”的语音&#xff0c; 如果验证不通过&#xff0c;则播放其他的语音提示。 实现步骤&#xff1a; 1.要播放语音提示&#xff0c;先要有…

8个你可能不知道答案的常见JavaScript面试问题

不管你喜不喜欢&#xff0c;棘手的问题仍然会被野外的面试官问到。 原因是&#xff0c;这些问题可以告诉你很多关于你对语言的核心理解&#xff0c;因此你是否适合这份工作。 这些问题中涉及的常见概念包括&#xff1a; Hoisting关闭范围值与引用类型原型继承 今天我们要一石…

AC自动机详解

更好的阅读体验\color{red}{更好的阅读体验}更好的阅读体验 文章目录前置知识字典树 Trie支持操作建字典树实现思想代码实现例题Trie字符串统计最大异或对AC自动机基础概念实现思想代码实现例题搜索关键词单词前置知识 字典树 Trie Trie 是一种能够快速插入和查询字符串的多叉树…

成功解决yum安装的php版本过低的问题

文章目录前言一. 问题复现二. 问题分析三. 问题解决&#xff1a;四. 重要补充1. yum-config-manager介绍2. yum-uitls介绍3. remi资源库总结前言 大家好&#xff0c;我是沐风晓月&#xff0c;日常学习过程经常会遇到一些奇奇怪怪的问题&#xff0c;而解决问题就成了常态&#…

鸿蒙开发学习|HarmonyOS工程介绍

系列文章目录 第一章 HarmonyOS是什么 第二章 基础环境和开发工具 文章目录系列文章目录前言一、HarmonyOS工程介绍二、工程目录结构三、工程目录介绍1.entry2.Ability3.库文件4.资源文件5.配置文件6.pack.info7.HAR总结前言 本文将会给大家梳理 HarmonyOS 源码目录结构&…

关于《利用LexYacc进行词法分析和语法分析并生成语法树》

利用Lex&Yacc进行词法分析和语法分析 写在前面 利用Lex进行词法分析的流程在前面已经讲过&#xff0c;接下来是利用Lex&Yacc进行语法分析&#xff0c;最后可视化生成语法树。具体的操作视频&#xff1a;https://www.bilibili.com/video/BV1wY411q7aH/ 语法分析流程 …

【MySQL】MySQL 8.0 新特性之 - 窗口函数(Window Functions)

窗口函数 - Window Functions1. 定义1.1 窗口函数1.2 语法格式2. 分类2.1 序号函数2.1.1 row_number()2.1.2 rank()2.1.3 dense_rank()2.2.4 示例2.2 分布函数2.2.1 percent_rank()2.2.2 cume_dist()2.3 前后函数2.3.1 lag(expr, n, default)2.3.2 lead(expr, n, default)2.3.3…

致跟我一样苦恼的你们

2023年2月1日&#xff0c;我决定结束实习&#xff0c;回去准备春招和毕设。我把这个决定跟家人和朋友说时&#xff0c;他们似乎是有点不太赞同&#xff0c;他们觉得&#xff1a; “现在工作不好找&#xff0c;你可以先找好下一家公司后再选择离职” “毕设得事情&#xff0c;…

VBA提高篇_17 区域合纵连横,单元格精准定位

文章目录Application.Union方法:Application.Intersect方法:Range.CurrentRegion属性:Range.Resize(3,2)Range.Offset 单元格偏移属性Application.Union方法: 把多个Range联合在一起,作为一个新的Range对象返回 Sub RangeUnionDemo()Dim a&, r1 As Range, r2 As Range, r3 …

魔兽世界服务端AzerothCore+Centos系统+docker编译教程

魔兽世界服务端AzerothCoreCentos系统docker编译教程1.1 准备工作1.1.1 准备1.1.2 安装软件1.1.3 下载源码1.1.4 地图文件1.2 修改配置文件1.2.1 修改环境变量文件1.2.2 修改文件执行权限1.2.3 修改配置文件1.3 编译及启动1.3.1 编译项目1.3.2 启动容器1.3.3 无法启动1. 网络问…

【Java多线程】线程的安全问题

根据上篇文章买票问题举例&#xff0c;还可能出现的问题&#xff1a; 代码如下&#xff1a; class Window1 implements Runnable{private static int ticket 100;Overridepublic void run() {while (true){if (ticket > 0){try {Thread.sleep(100);} catch (InterruptedExc…

网站优化与seo的方法(seo的优化基础)

SEO优化的常规思路&#xff0c;别全以转化为目标 SEO优化作为现在公司推广营销的基础&#xff0c;几乎每个公司都在做这件事。这种优化既可以提升品牌知名度&#xff0c;又能直接给公司带来流量&#xff0c;确实让不少公司感觉很有用。但是在持续的过程中&#xff0c;又会觉得…