Java Web基础知识(Servlet、Cookie、Session、Filter、Listener)
Starry-Leo 2024-06-27 14:03:02 阅读 100
文章目录
Servlet什么是Servlet?Servlet的生命周期ServletConfig对象ServletContext对象Servlet请求转发和重定向Servlet请求转发(forward和include)Servlet重定向(redirect)重定向和转发的区别?
读取文件、下载文件
会话管理Cookie什么是Cookie?Cookie的特点:Cookie具体使用:
SessionHttpSession 保存信息过程HTTP Session的特点:HttpSession的用法:Session的销毁方式Session生命周期?
Cookie、Session区别?
Servlet三个域对象FilterListener
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的重定向是,服务器告诉客户端,你需要重新发送一个请求,到一个target路径,因此浏览器需要发送两次请求,且请求地址会发生改变,具体使用代码为:response.sendRedirect(targetUrl);
重定向和转发的区别?
对于客户端来说,转发是一次请求一次响应,重定向是两次请求两次响应。请求转发浏览器地址栏不会发生变化,重定向会变化成功转发后的URL。转发不支持跨域跳转,只能在项目内转发,重定向则不受限制。转发之间可以传递request对象,重定向不能,本质是两次请求。
读取文件、下载文件
//读取文件:
InputStream is = this.getServletContext().getResourceAsStream("/WEBINF/classes/com/xxliao/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大监听器:
ServletContextListenerServletContextAttributeListenerHttpSessionListenerHttpSessionAttributeListenerServletRequestListenerServletRequestAttributeListenerHttpSessionBindingListenerHttpSessionActivationListener
需要监听什么内容就实现上面的监听器,然后将监听器配置到web.xml文件中
2. 测试监听器
package com.xxliao.listener;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;
/**
* @author xxliao
* @description: 演示Listener
* @date 2023/11/19$ 12:25$
*/
public class DemoListener implements HttpSessionListener {
@Override
public void sessionCreated(HttpSessionEvent httpSessionEvent) {
}
@Override
public void sessionDestroyed(HttpSessionEvent httpSessionEvent) {
}
}
web.xml配置
<!--listener-->
<listener>
<listener-class>com.xxliao.listener.DemoListener</listener-class>
</listener>
上一篇: Stable Diffusion Webui源码剖析
下一篇: 解决CitSpace分析新版本web of science文献报错“the timing slicing setting is outside the range of your data”
本文标签
声明
本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。