一、Servlet的配置
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-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-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()接口
-
getServeltConfig()接口
-
getServletInfo()接口
四、Servlet的生命周期
五、总结
-
从本质上来说JSP就是一个Servlet,因为JSP文件最终会被编译成class文件,而这个Class文件实际上就是一个特殊的Servlet; -
Spring MVC框架是基于Servlet技术实现的; -
代码审计中我们可以选择Servlet入手,也可以选择从漏洞点反推出Http请求的入口地址; -
了解Servlet知识对后续的框架审计有一定的帮助。
精彩推荐



原文始发于微信公众号(FreeBuf):Java安全基础(二)Servlet核心技术
免责声明:文章中涉及的程序(方法)可能带有攻击性,仅供安全研究与教学之用,读者将其信息做其他用途,由读者承担全部法律及连带责任,本站不承担任何法律及连带责任;如有问题可邮件联系(建议使用企业邮箱或有效邮箱,避免邮件被拦截,联系方式见首页),望知悉。
- 左青龙
- 微信扫一扫
-
- 右白虎
- 微信扫一扫
-
评论