文章目录
- Servlet
- 什么是Servlet?
- Servlet的生命周期
- ServletConfig对象
- ServletContext对象
- Servlet请求转发和重定向
- Servlet请求转发(forward和include)
- Servlet重定向(redirect)
- 重定向和转发的区别?
- 读取文件、下载文件
- 会话管理
- Cookie
- 什么是Cookie?
- Cookie的特点:
- Cookie具体使用:
- Session
- HttpSession 保存信息过程
- HTTP Session的特点:
- HttpSession的用法:
- Session的销毁方式
- Session生命周期?
- Cookie、Session区别?
- Servlet三个域对象
- Filter
- Listener
Servlet
什么是Servlet?
- Servlet是运行在Web服务起中的小城Java程序,侠义的Servlet是实现了Java语言实现的一个接口,广义的Servlet是任何实现了这个Servlet接口的类,作用是:接受用户的请求,并对请求做出处理,将处理结果响应给客户端。
- Servlet有三种实现方式:实现Servlet接口,继承抽象类GennericServlet,继承HttPServlet。
- Servlet是可以接受HTTP请求并做出相应的一种结束,是Java语言编写的一种动态资源。
- Servlet是前后端衔接的一种技术,不是所有的Java类都可以接受请求和做出相应,但是Servlet可以。
在MVC模式中,Servlet作为Controller层主要技术,用来和浏览器完成数据交互,控制交互逻辑。 - Servlet的工作模式:客户端发送请求至服务器,服务器运行并调用Servlet,Servlet根据客户端请求生成相应内容并将其传给服务器,相应内容动态生成,通常取决于客户端的请求,服务器将相应返回客户端。
- Servlet是Tomcat的一个组件,Servlet的功能需要依赖包servlet-api.jar,由Tomcat提供,Tomcat在初始化Servlert时候首先读取web.xml文件,根据web.xml文件中的参数信息初始化ServletConfig,ServletContext对象,同时帮助我们创建HttpServletRequest和HttpServletResponse对象一并交给Servlet实例,此时Servlet就具有了相关的功能。
Servlet的生命周期
Servlet的生命周期室友容器管理的,Servlet容器会根据下面的规则来调用三个方法:
- 初始化方法init(),只会执行一次(启动Tomcat的时候默认是不执行的,在访问的时候才会执行,但是可以根据web.xml中的配置更改为容器启动并初始化),当Servlet第一次被请求时,Servlet容器会实例化这个Servlet,然后就会调用init()方法来初始化Servlet,然后后续请求时,这个方法就不会再被执行,一般用来完成初始化工作。
- 服务方法service(),每当请求Servlet时,Servlet容器就会调用这个方法,第一次请求时,Servlet就会初始化一个Servlet对象,然后掉用service()方法来完成工作,后续请求就直接调用service()方法。
- 销毁方法destory(),当要销毁Servlet时候,Servlet容器就会调用这个方法,卸载应用程序或者关闭Servlet容器时候,就会执行这个方法,一般用来写一些清楚工作代码。
ServletConfig对象
每个Servlet都有一个ServletConfig对象,ServletConfig对象对应web.xml中的节点,Servlet初始化后就会Servlet的配置信息封装到ServletConfig中,例如:
<!--servlet 配置-->
<servlet>
<servlet-name>ServletLifeCycle</servlet-name>
<servlet-class>com.xxliao.servlet.ServletLifeCycle</servlet-class>
<!--初始化等级,1可以跟随容器启动初始化-->
<load-on-startup>1</load-on-startup>
<!--servlet初始化参数,放在ServletConfig对象中-->
<init-param>
<param-name>author</param-name>
<param-value>xxliao</param-value>
</init-param>
</servlet>
ServletConfig获取参数方式,例如:
ServletConfig servletConfig = this.getServletConfig();
System.out.println(servletConfig.getServletName());
System.out.println(servletConfig.getInitParameter("author"));
ServletContext对象
Servlet上下文对象,一个Webapp程序一个ServletContext对象。Web容器启动的时候,它会为每个web程序都创建一个对应的ServletContext对象,这个对象全局唯一,web程序中的所有Servlet共享这个对象,因此也叫全局应用共享对象。具体配置参数使用标签进行配置,例如:
<!-- 参数配置 这个web容器共享,放在Servlet Context中-->
<context-param>
<param-name>author</param-name>
<param-value>xxliao</param-value>
</context-param>
// ServletContext获取参数例子:
ServletContext servletContext = this.getServletContext();
System.out.println(servletContext.getInitParameter("author-context"));
ServletContext的生命周期:Servlet容器启动时候,就会创建ServletContext对象,然后一直缓存这个对象,直到容器关闭后该对象生命周期结束。
Servlet请求转发和重定向
Servlet请求转发(forward和include)
请求转发是在服务器中进行的转发,由一个Servlet转发到另一个Servlet,然后返回客户端的请求方式,浏览器端的地址蓝不会发生改变,只发送了一次请求,两次跳转之间传输的数据不会丢失,可以通过request对象进行传递,根据response是否能够传递,请求转发分为forward转发(不传递)和include转发(传递),具体代码为:
request.getRequestDispatcher(“接quest受请求的Servlet的路径”).forward(request,response)
request.getRequestDispatcher(“接quest受请求的Servlet的路径”).include(request,response)
两种方式的区别:
1.forward在servlet传递间,不能输出响应体,include可以输出相应体
2.forward不能设置响应体,但是可以设置响应头,include响应头和响应体均可以设置。
Servlet重定向(redirect)
Servlet的重定向是,服务器告诉客户端,你需要重新发送一个请求,到一个targer路径,因此浏览器需要发送两次请求,且请求地址会发生改变,具体使用代码为:response.sendRedirect(targetUrl);
重定向和转发的区别?
- 对于客户端来说,转发是一次请求一次响应,重定向是两次请求两次响应。
- 请求转发浏览器地址栏不会发生变化,重定向会变化成功转发后的URL。
- 转发不支持跨域跳转,只能在项目内转发,重定向则不受限制。
- 转发之间可以传递request对象,重定向不能,本质是两次请求。
读取文件、下载文件
//读取文件:
InputStream is = this.getServletContext().getResourceAsStream("/WEBINF/classes/com/kuang/servlet/aa.properties");
//下载文件:
ServletOutputStream out = resp.getOutputStream();
out.write
会话管理
Http协议本身不具备直接记录用户状态的功能,JavaWeb提供了Cookie和Session技术来帮助我们记录用户的状态。
Cookie
什么是Cookie?
Cookie是一种保存少量信息到浏览器端的技术,请求时服务器段可以给浏览器一些Cookie信息保存下来,后续请求可以携带之前的Cookie信息到服务器端。
Cookie的特点:
- Cookie使用字符串保存诗句,使用的是key-value的数据结构存储,单个Cookie的存储大小限制是4097字节。
- ]Cookie存储的数据不支持中文,Servlet4.0中支持,4.0之前保存中文可以采用编码和解码处理方式,具体为:
将内容按照指定的编码方式做URL编码处理:URLEncoder.encode(“content”,“code”)
将内容按照指定的编码方式做URL解码处理:URLDecoder.decode(“content”,“code”) - Cookie分为状态Cookie(保存在内存中)和持久化Cookie(保存在磁盘上)。
- Cookie是与域名绑定,所以Cookie不支持跨一级域名访问。
- 浏览器能保存的Cookie个数是有限的,不同浏览器支持的数量不同。
- 浏览器每次请求时,都会将访问域名相关的Cookie携带到服务端。
- Cookie是基于明文的方式存储的,所以安全性较低。
Cookie具体使用:
- Cookie的创建:
Cookie cookie = new Cookie(“key”,”value“);
resp.addCookie(cookie); //添加到response 对象中 - Cookie获取:
Cookie[] cookies = req.getCookies(); - 设置Cookie的过期时间
cookie.setMaxAge(time);ime是描述,一旦设置后cookie将保存到磁盘中,当失效时间到达后再删除。
Session
HttpSession 保存信息过程
HttpSession是一种保存少量信息到服务器的一种技术,具体保存过程是:
- 第一次请求时,服务器端会拆功能键HttpSession对象,然后将数据保存在该对象后,服务器端会将HttpSession的JSESSIONID以Cookie形式响应给浏览器。
- 第二次请求,浏览器会携带之前JSESSJIONID的Cookie,服务器端根据JSESSIONID对象获取对对应的HttpSession对象,然后从HttpSession对象中获取缓存的数据,
HTTP Session的特点:
1.HttpSession保存到服务器端,也是使用key-value的存储结构存储数据,其中value可以是任何数据类型。
2.HttpSession保存数据没有大小限制。
HttpSession的用法:
- 创建Session:
HttpSession session = request.getSession();第一次获取则创建该对象,后面根据JSESSIONID获取已经创建的对象。
HttpSession session = request.getSession(false);根据JSESSIONID获取对象, 有则返回,没有不会创建新对象。 - 将数据存储在Session中:
session.setAttribute(“key”,value); - 根据key,从session中获取数据:
Object obj = session.getAttribute(“key”); - 根据key删除Session数据:
session.removeAttribute(“key”);
Session的销毁方式
1.通过web.xml中设置超市时间(最大不活动时间)
<!--设置session超时时间-->
<session-config>
<session-timeout>60</session-timeout>
</session-config>
- session.invalidate(),销毁当前HTTP Session对象
Session生命周期?
Session的生命周期没有固定的创建和销毁时间,合适创建取决于合适调用getSession()方法,HttpSession的销毁时间取决于设置的最大不活动时间或者调用invalidate()方法,如果均没有,那么HttpSession会一直存储,默认超时时间为30分钟。
Cookie、Session区别?
- Cookie保存到客户端,Session保存到服务端,
- Cookie不安全,HttpSession安全
- Cookie保存数据有限制(单个容量4K,浏览器个数闲置)
Servlet三个域对象
- request:一次请求有效,请求转发可以进行数据传递,生命周期和request对象周期相同。
- session:单词会话有效,可以跨多个请求。
- application:当前web服务内,跨请求,跨会话。
// 1.设置数据
域对象.setAttribute("key",value)
// 2.获取数据
域对象.getAttribute("key")
Filter
1. implements Filter接口,然后重写init、doFilter、destroy方法
public class DemoFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
System.out.println("DemoFilter的init...");
}
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
System.out.println("DemoFilter的doFilter...");
// 通过filter
filterChain.doFilter(servletRequest,servletResponse);
}
@Override
public void destroy() {
System.out.println("DemoFilter的destroy...");
}
}
2. web.xml配置
<!--filter配置-->
<filter>
<filter-name>DemoFilter</filter-name>
<filter-class>com.xxliao.filter.DemoFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>DemoFilter</filter-name>
<url-pattern>/servlet/*</url-pattern>
</filter-mapping>
Listener
- JavaWeb8大监听器:
- ServletContextListener
- ServletContextAttributeListener
- HttpSessionListener
- HttpSessionAttributeListener
- ServletRequestListener
- ServletRequestAttributeListener
- HttpSessionBindingListener
- HttpSessionActivationListener
- web.xml配置
<!--listener-->
<listener>
<listener-class>com.xxliao.listener.DemoListener</listener-class>
</listener>