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

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

因为在实习中文章更新速度可能有点慢初学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中已经有了很好的实现它会根据请求的方法名GETPOST,调用doGetdoPos以及其他的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知识对后续的框架审计有一定的帮助

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

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

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

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

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

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

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: Java