Java基础入门day55

2024-05-25 03:44
文章标签 java 基础 入门 day55

本文主要是介绍Java基础入门day55,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

day55

过滤器

简介

过滤器filter,是处于客户端与服务器端目标资源之间的一道过滤技术技术

作用

执行地位在servlet之前,客户发送请求时,会先经过Filter,再到达目标Servlet中。

相应时,会根据执行流程再次反向执行Filter

可以解决多个Servlet共性代码的冗余问题

编写

新增一个类,实现Filter接口

编写其生命周期方法

再doFilter当中实现过滤方法

package com.saas.day55;
​
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import java.io.IOException;
​
@WebFilter(filterName = "characterFilter", urlPatterns = "/*")
public class CharacterFilter implements Filter {public void init(FilterConfig filterConfig) throws ServletException {System.out.println("this is init method.");}@Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain filterChain) throws IOException, ServletException {
​request.setCharacterEncoding("UTF-8");response.setCharacterEncoding("UTF-8");response.setContentType("text/html;charset=UTF-8");
​System.out.println("this is doFilter method.");
​//  让请求资源放行filterChain.doFilter(request, response);}
​public void destroy() {System.out.println("this is destroy method.");}
}

filter的配置方式有两种:

  • 注解:

注解方式配置:
@WebFilter(filterName = "characterFilter", urlPatterns = "/*")
​
  • xml方式

    <filter><filter-name>characterFilter</filter-name><filter-class>com.saas.day55.CharacterFilter</filter-class></filter>
​<filter-mapping><filter-name>characterFilter</filter-name><url-pattern>/*</url-pattern></filter-mapping>

注意请求的通配

/abc        代表的是具体的请求abc
/*          代表的是任意请求
*.action    代表的是以action结尾的任何请求
*.jsp       任何的jsp页面

过滤器链和优先级

过滤器链

客户端对于服务器请求之后,服务器调用servlet之前会执行一组过滤器,那么这组过滤器就成为一个过滤器链

每个过滤器实现某个特定功能,当第一个过滤器的doFilter方法执行时,web服务器会创建一个代表FilterChain对象传递给该方法,在doFilter方法中,开发人员如果调用了FilterChain中的doFilter方法,则web服务器会检查FilterChain对象中是否还有其他filter,如果有,则执行第二个第三个...过滤器,否则,调用目标资源

优先级

在一个web容器中,可以开发多个过滤器,这种过滤器组合起来称之为一个Filter链

优先级:

如果为注解的话,是按照类全名称的字符串自然顺序决定

如果是web.xml配置方式,按照Filter-mapping的注册顺序,从上往下

web.xml配置方式高于注解方式

如果注解和xml同时配置,会创建多个过滤器对象,造成过滤多次

cookie

什么是cookie

  • cookie是在浏览器访问web服务器的某个资源是,由web服务器在HTTP响应头中附带的传送给浏览器的一小段数据

  • 一旦web浏览器保存了某个cookie,那么它在以后访问该web服务器时,都应在HTTP请求头中将这个cookie回传给web服务器

  • 一个cookie主要是由标识该信息的名称(name)和值(value)组成

创建cookie

代码实现
package com.saas.day55;
​
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
​
@WebServlet("/addCookie")
public class CookieServlet extends HttpServlet {
​@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {doPost(req, resp);}
​@Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {//  新建一个cookie对象,里面存放cookie的名值对Cookie ck = new Cookie("myCode", "8888");
​//  设置cookie的有效期,单位为秒ck.setMaxAge(30);
​//  使用HttpServletResponse对象将cookie对象发送给客户端resp.addCookie(ck);}
}
​

通过response对象的addCookie方法将cookie的名值对存入cookie中

cookie是作用于客户端浏览器之上,即使服务器重启,也还是存在的,除非cookie失效

package com.saas.day55;
​
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
​
@WebServlet("/getCookie")
public class GetCookie extends HttpServlet {
​@Override-protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {doPost(req, resp);}
​@Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {//  通过HttpServletRequest对象获取cookie,得到cookie数组Cookie[] cookies = req.getCookies();
​//  遍历cookie数组,动态获取我们需要的cookie那么对于的valuefor (Cookie c : cookies) {if (c.getName().equals("code")){System.out.println("code" + c.getValue());resp.getWriter().write("code" + c.getValue());}if(c.getName().equals("myCode")){System.out.println("myCode" + c.getValue());resp.getWriter().write("myCode" + c.getValue());}}}
}

通过HttpServletRequest对象获取cookie数组

循环cookie数组,动态获取我们需要的name进行进一步的处理

这篇关于Java基础入门day55的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1000385

相关文章

java如何解压zip压缩包

《java如何解压zip压缩包》:本文主要介绍java如何解压zip压缩包问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java解压zip压缩包实例代码结果如下总结java解压zip压缩包坐在旁边的小伙伴问我怎么用 java 将服务器上的压缩文件解压出来,

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Spring WebFlux 与 WebClient 使用指南及最佳实践

《SpringWebFlux与WebClient使用指南及最佳实践》WebClient是SpringWebFlux模块提供的非阻塞、响应式HTTP客户端,基于ProjectReactor实现,... 目录Spring WebFlux 与 WebClient 使用指南1. WebClient 概述2. 核心依

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分