Servlet

什么是servlet?

• 概念:Java Servlet 是运行在 Web 服务器或应用服务器上的程序,它是作为来自 Web 浏览器或其他 HTTP 客户端的请求和 HTTP 服务器上的数据库或应用程序之间的中间层。
• 定位:Java Servlet用Java编写的服务器端程序(web application)。
• 作用:其主要功能在于交互式地浏览和修改数据,生成动态Web内容。
• 理解:狭义的Servlet是指Java语言实现的一个接口,广义的Servlet是指任何实现了这个Servlet接口的类,一般情况下,我们将Servlet理解为后者。

Servlet生命周期

Servlet 生命周期可被定义为从创建直到毁灭的整个过程。以下是 Servlet 遵循的过程:
• Servlet 通过调用 init () 方法进行初始化。
• Servlet 调用 service() 方法来处理客户端的请求。
• Servlet 通过调用 destroy() 方法终止(结束)。
• Servlet 是由 JVM 的垃圾回收器进行垃圾回收的。
注意事项:
1)Servlet 通过调用 init () 方法进行初始化,init 方法被设计成只调用一次。
• 它在第一次创建 Servlet 时被调用,在后续每次用户请求时不再调用。因此,它是用于一次性初始化。
• Servlet 创建于用户第一次调用对应于该 Servlet 的 URL 时,但是也可以指定 Servlet 在服务器第一次启动时被加载。
• 当用户调用一个 Servlet 时,就会创建一个 Servlet 实例,每一个用户请求都会产生一个新的线程,适当的时候移交给 doGet 或 doPost 方法。init() 方法简单地创建或加载一些数据,这些数据将被用于 Servlet 的整个生命周期。
2)Servlet 调用 service() 方法来处理客户端的请求,service() 方法是执行实际任务的主要方法。
• Servlet 容器(即 Web 服务器)调用 service() 方法来处理来自客户端(浏览器)的请求,并把格式化的响应写回给客户端。
• 每次服务器接收到一个 Servlet 请求时,服务器会产生一个新的线程并调用服务。service() 方法检查 HTTP 请求类型(GET、POST、PUT、DELETE 等),并在适当的时候调用 doGet、doPost、doPut,doDelete 等方法。
3)Servlet 通过调用 destroy() 方法终止,destroy() 方法只会被调用一次,在 Servlet 生命周期结束时被调用。
• destroy() 方法可以让您的 Servlet 关闭数据库连接、停止后台线程、把 Cookie 列表或点击计数器写入到磁盘,并执行其他类似的清理活动。
4)Servlet 是由 JVM 的垃圾回收器进行垃圾回收的。

HttpServlet处理Http请求

• Servlet的service()方法是请求的入口方法,HttpServlet实现service()方法在这个入口方法中根据不同的Http请求方法(如GET、POST请求)调用不同的方法。
• 大多数应用程序都是要于HTTP结合起来使用。这意味着可以利用HTTP提供的特性。javax.servlet.http包是Servlet API中的第二个包,其中包含了用于编写Servlet应用程序的类和接口,并且许多类型都覆写了javax.servlet 中的类型。
• HttpServlet类覆盖了 javax.servlet.GenericServlet 类。使用HttpServlet时,需要使用代表Servlet请求和Servlet响应的 HttpServletRequest 和 HttpServletResponse 对象。

Servlet的方法

HttpServlet中的Service方法会检验用来发送请求的HTTP方法(通过调用request.getMethod() ), 并调用以下方法之一:

doGet

doPost

doHead

doPut

doTrace

doOptions

doDelete

每一种方法都表示一个HTTP方法, doGet 和 doPost 是最常用的。
为什么不覆盖Servlet方法
service方法在内部已经对收到的http请求的方法做了分类,从而让请求可以路由到不同的具体方法(如:doGet),所以在编写servlet程序的时候,不需要覆盖Service方法,只要覆盖doGet或者doPost即可。

Servlet请求处理过程图

Javaservlet设置HTMLaction标签 javaweb中servlet_服务器

Servlet Cookies

定义: Cookies 是存储在客户端计算机上的文本文件,并保留了用户的各种跟踪信息
作用: 会话保持,如完成用户的登录与状态保持
工作原理:
• 客户端向服务区发起登录请求
• 服务器脚本向浏览器发送一组 Cookies。例如:姓名、年龄或识别号码等。
• 浏览器将这些信息存储在本地计算机上,以备将来使用。
• 当下一次浏览器向 Web 服务器发送任何请求时,浏览器会把这些 Cookies 信息发送到服务器,服务器将使用这些信息来识别用户。
构成:
Cookies 通常设置在 HTTP 头信息中。设置 Cookie 的http请求,会向 Servlet 会发送头信息:
• Set-Cookie 头包含了一个名称值对、一个 GMT 日期、一个路径和一个域。名称和值会被 URL 编码。
• expires 字段是一个指令,告诉浏览器在给定的时间和日期之后过期该 Cookie。
• 如果浏览器被配置为存储 Cookies,它将会保留此信息直到到期日期。

如果用户的浏览器指向任何匹配该 Cookie 的路径和域的页面,它会重新发送 Cookie 到服务器。Servlet 就能够通过请求方法 request.getCookies() 访问 Cookie,该方法将返回一个 Cookie 对象的数组。

Servlet Session

定义: session 是存储在服务器上的文本文件,并保留了用户的各种跟踪信息。
作用: 会话保持,如完成用户的登录与状态保持,因为在服务器端,所以相对安全一些。

Cookie和Session区别

1)cookie数据存放在客户的浏览器上,session数据放在服务器上。
2)设置cookie时间可以使cookie过期。但使用session-destory(),将会销毁会话。
3)单个cookie保存的数据<=4KB,一个站点最多保存20个Cookie。session并没有上限,但session会在一定时间内保存在服务器上。当访问增多,会比较占用你服务器。
4)cookie中只能保管ASCII字符串,并需要通过编码方式存储为Unicode字符或者二进制数据。session中能够存储任何类型的数据,包括且不限于string,integer,list,map等。
5)开发可以通过设置cookie的属性,达到使cookie长期有效的效果。关闭窗口该session就会失效,session不能达到长期有效的效果。