Servlet

Servlet

以下是个人在学习Servlet时的笔记及一些个人理解,不是很详细,仍在更新。。。。

Servlet是什么?

Java Servlet是运行在Web服务器或应用服务器上的程序,它是作为来自Web浏览器或其它Http客户端的请求和Http服务器上的数据库或应用程序之间的中间层。

Servlet的优势

·性能明显更好。
·Servlet在Web服务器的地址空间内执行。这样它就没有必要再创建一个单独的进程来处理每个客户端请求。
·Servlet是独立于平台的,因为它们是用Java编写的。
·服务器上的Java安全管理器执行了一系列限制,以保护服务器计算机上的资源,因此,Servlet是可信的。
·Java类库的全部功能对Servlet来说都是可用的。它可以通过sockets(网络编程接口)和RMI(远程方法调用)机制与applets、数据库或其它软件进行交互。

Servlet架构

下图显示了Servlet在Web应用程序中的位置

在这里插入图片描述

servlet 生命周期

Servlet生命周期可被定义为从创建直到毁灭的整个过程,以下是Servlet遵循的过程:
·Servlet通过调用 init() 方法进行初始化。
·Servlet调用 service() 方法来处理客户端的请求。
·Servlet通过调用 destory() 方法终止(结束)。
·最后,Servlet是由JVM的垃圾回收器进行垃圾回收的。
init()方法
init 方法被设计成只调用一次。它在第一次创建Servlet时被调用,在后续每次用户请求时不再调用。
Servlet创建于用户第一次调用对用该Servlet的URL时,但是也可以指定Servlet在服务器第一次启动时被加载。
当用户调用一个Servlet时,就会创建一个Servlet实例,每一个用户请i去都会产生一个新的线程,适当的时候移交给doGet或doPost方法。 init() 方法简单地创建或加载一些数据,这些数据被用于Servlet的整个生命周期。

init方法的定义如下:

public void init() throws ServletException{
	//初始化代码
	}
Service() 方法
service() 方法是执行实际任务的主要方法。
Servlet容器(即Web服务器)调用service() 方法来处理来自客户端的请求,并把格式化的响应写回给客户端。
每次服务器接收到一个Servlet请求时,服务器会产生一个新的线程并调用服务。service()方法检查HTTP请求类型(GET、POST、PUT、DELETE等),并在适当的时候调用doGet、doPost、doPut、doDelete等方法。
public void service (ServletRequest request,ServletResponse response) throws ServletException,IOExption{

}
其中doGet()和doPost()方法时每次服务请求中最常用的方法:
doGet()方法
GET请求来自于一个URL的正常请求,或者来自一个为指定METHOD的HTML表单,它由doGet()方法处理。
public void doGet(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException{
	//Service 代码
	}
doPost()方法
POST请求来自于一个特别指定了METHOD为POST的HTML表单,它由doPost()方法来处理
public void doPost(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException{
	//Service 代码
	}
destroy()方法
destroy()方法只会被调用一次,在Servlet生命周期结束时被调用。 destroy()方法可以让你的Servlet关闭数据库连接、停止后台线程、把Cookie列表或点击计数器写入到磁盘,并执行其它类似的清理活动
在调用destroy()方法之后,servlet对象被标记为垃圾回收。destroy方法定义如下所示:
	public void destroy(){
	//终止化代码
	}
以下为生命周期的一个简单实例:
	/**servlet生命周期,的三个方法,
			1.被创建,执行且只执行一次init方法,
			2.提供服务,执行service方法,执行多次 
			3.被销毁,当Servlet服务器正常关闭时,执行destroy方法,只执行一次。
	*/
	  @Override
     public void init() throws ServletException {
         // TODO Auto-generated method stub
         super.init();
     }
     
     @Override
     protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
         // TODO Auto-generated method stub
         super.service(req, resp);
     }
     
     @Override
     public void destroy() {
         // TODO Auto-generated method stub
         super.destroy();
     }

Servlet 表单数据

很多情况下,需要传递一些信息,从浏览器到Web服务器,最终到后台程序。浏览器使用两种方法可将这些信息传递到Web服务器,分别为GET方法和POST方法。
GET方法
GET方法向页面请求发送已编码的用户信息。
GET方法默认的从浏览器向Web服务器传递信息的方法,它会产生一个很长的字符串,出现在浏览器的地址栏中。如果要向服务器传递的是密码或其它的敏感信息,请不要使用GET方法。GET方法有大小限制:请求字符串中最多只能有1024个字符。
这些信息使用QUERY_STRING头传递,并可以通过QUERY_STRING环境变量访问,Servlet使用doGet()方法处理这种类型的请求。
POST方法
另一个向后台程序传递信息的比较可靠的方法是POST方法。POST方法打包信息的方式与GET方法基本相同,但是POST方法不是把信息作为URL中?字符串后的文本字符串进行发送,而是把这些信息作为一个单独的消息。消息以标准输出的形式传到后台程序,可以解析和使用这些标准输出。Servlet使用doPost()方法处理这种类型的请求。
使用Servlet读取表单数据
Servlet处理表单数据,这些数据会根据不同的情况使用不同的方法自动解析:
	·getParameter():  可以调用requset.getParameter() 方法来获取表单参数的值。
	·getParameterValues(): 如果参数出现一次以上,则调用该方法,并返回多个值,例如复选框。
	·getParameterNames(): 如果你想要得到当前请求的所有参数的完整列表,则调用该方法。

Servlet 编写过滤器

Servlet过滤器是可用于Servlet编程的Java类,有以下目的:
	·在客户端的请求访问后端资源之前,拦截这些请求。
	·在服务器的响应发送会客户端之前,处理这些响应。
根据规范建议的各种类型的过滤器:
	·身份验证过滤器(Authentication Filters)
	·数据压缩过滤器(Data compression Filters)
	·加密过滤器(Encryption Filters)
	·触发资源访问事件过滤器
	·图像转换过滤器(Image Conversion Filters)
	·日志记录和审核过滤器(Logging and Auditing Filters)
	·MIME-TYPE 链过滤器(MIME-TYPE Chain Filters)
	·标记化过滤器(Tokenizing Filters)
	·XSL/T 过滤器(XSL/T Filters),转换 XML 内容
过滤器被部署在部署描述符文件 web.xml 中,然后映射到您的应用程序的部署描述符中的 Servlet 名称或 URL 模式。
当 Web 容器启动 Web 应用程序时,它会为您在部署描述符中声明的每一个过滤器创建一个实例。该过滤器执行的顺序是按它们在部署描述符中声明的顺序。

Servlet 过滤器方法
过滤器是一个实现了 javax.servlet.Filter 接口的 Java 类。javax.servlet.Filter 接口定义了三个方法:
序号方法 & 描述
1public void doFilter (ServletRequest, ServletResponse, FilterChain) 该方法在每次一个请求/响应对因客户端在链的末端请求资源而通过链传递时由容器调用。
2public void init(FilterConfig filterConfig) 该方法由 Web 容器调用,指示一个过滤器被放入服务。
3public void destroy() 该方法由 Web 容器调用,指示一个过滤器被取出服务。

Servlet Cookies处理

Cookies是存储在客户端计算机上的文本文件,并保留了各种跟踪信息。Java Servlet显然支持HTTP Cookies。
识别返回用户包括三个步骤:
	·服务器脚本向浏览器发送一组Cookies。
	·浏览器将这些信息存储在本地计算机上,以备将来使用。
	·当下一次浏览器向Web服务器发送任何请求时,浏览器会把这些Cookies信息发送到服务器,服务器将使用这些信息来识别用户。

Servlet Session跟踪

HTTP是一种"无状态"协议,这意味着每次客户端检索页面时。客户端打开一个单独的连接到Web服务器,服务器会自动不保留之前客户端请求的任何记录。
但是仍然有以下三种方式来维持Web客户端和Web服务器之间的Session会话:
	1、Cookies:
	一个Web服务器可以分配一个唯一的session会话ID作为每个Web客户端的cookie,对于客户端的后续请求可以使用接收到的cookie来识别。
	这可能不是一个有效的方法,因为很多浏览器不支持cookie,所以我们建议不要使用这种方式来维持session会话。

	2、隐藏的表单字段:
	一个Web服务器可以发送一个隐藏的HTML表单字段,以及一个唯一的session会话ID
	<input type="hidden" name="sessionid" value="12345">
当表单被提交时,指定的名称和值会被浏览器自动包含在GET或POST数据中。每次当Web浏览器发送回请求时,session_id值可以用于保持不同的Web浏览器的跟踪。
	3、URl重写
	你可以在每个URL末尾追加一些额外的数据来标识session会话,服务器会把该session会话标识符与已存储的有关session会话的数据相关联。

Servlet 处理日期

使用Servlet的最重要的优势之一是,可以使用java中的大多数可用方法。
Date类支持两个构造函数。
第一个构造函数初始化当前日期和时间的对象。
第二个构造函数接受一个参数,该参数等于1970年1月1日以来经过的毫秒数。
	Date()
	Date(long millisec)

Servlet 页面重定向

当文档移动到新的位置,我们需要向客户端发送这个新的位置时,我们需要用到网页重定向。
当然,也可能是为了负载均衡,或者只是为了简单得随机,这些情况都有可能用到页面重定向。
重定向请求到另一个网页得最简单的方式是使用response对象的sendRedirect() 方法。下面是该方法的定义:将请求重定向到另一页的最简单的方法是,用方法的sendRedircet()的响应对象。以下是这种方法的定义:
public void HttpServletResponse.sendRedirect(String location) throws IOException
该方法把响应连同状态码和新的网页位置发送回浏览器。也可以通过setStatus()和setHeader()方法一起使用来达到同样的效果。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值