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中Switch Case多个条件处理方法举例

《Java中SwitchCase多个条件处理方法举例》Java中switch语句用于根据变量值执行不同代码块,适用于多个条件的处理,:本文主要介绍Java中SwitchCase多个条件处理的相... 目录前言基本语法处理多个条件示例1:合并相同代码的多个case示例2:通过字符串合并多个case进阶用法使用

Java中的Lambda表达式及其应用小结

《Java中的Lambda表达式及其应用小结》Java中的Lambda表达式是一项极具创新性的特性,它使得Java代码更加简洁和高效,尤其是在集合操作和并行处理方面,:本文主要介绍Java中的La... 目录前言1. 什么是Lambda表达式?2. Lambda表达式的基本语法例子1:最简单的Lambda表

Java中Scanner的用法示例小结

《Java中Scanner的用法示例小结》有时候我们在编写代码的时候可能会使用输入和输出,那Java也有自己的输入和输出,今天我们来探究一下,对JavaScanner用法相关知识感兴趣的朋友一起看看吧... 目录前言一 输出二 输入Scanner的使用多组输入三 综合练习:猜数字游戏猜数字前言有时候我们在

Spring Security+JWT如何实现前后端分离权限控制

《SpringSecurity+JWT如何实现前后端分离权限控制》本篇将手把手教你用SpringSecurity+JWT搭建一套完整的登录认证与权限控制体系,具有很好的参考价值,希望对大家... 目录Spring Security+JWT实现前后端分离权限控制实战一、为什么要用 JWT?二、JWT 基本结构

java解析jwt中的payload的用法

《java解析jwt中的payload的用法》:本文主要介绍java解析jwt中的payload的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java解析jwt中的payload1. 使用 jjwt 库步骤 1:添加依赖步骤 2:解析 JWT2. 使用 N

springboot项目如何开启https服务

《springboot项目如何开启https服务》:本文主要介绍springboot项目如何开启https服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录springboot项目开启https服务1. 生成SSL证书密钥库使用keytool生成自签名证书将

Java实现优雅日期处理的方案详解

《Java实现优雅日期处理的方案详解》在我们的日常工作中,需要经常处理各种格式,各种类似的的日期或者时间,下面我们就来看看如何使用java处理这样的日期问题吧,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言一、日期的坑1.1 日期格式化陷阱1.2 时区转换二、优雅方案的进阶之路2.1 线程安全重构2

Java中的JSONObject详解

《Java中的JSONObject详解》:本文主要介绍Java中的JSONObject详解,需要的朋友可以参考下... Java中的jsONObject详解一、引言在Java开发中,处理JSON数据是一种常见的需求。JSONObject是处理JSON对象的一个非常有用的类,它提供了一系列的API来操作J

SpringBoot多数据源配置完整指南

《SpringBoot多数据源配置完整指南》在复杂的企业应用中,经常需要连接多个数据库,SpringBoot提供了灵活的多数据源配置方式,以下是详细的实现方案,需要的朋友可以参考下... 目录一、基础多数据源配置1. 添加依赖2. 配置多个数据源3. 配置数据源Bean二、JPA多数据源配置1. 配置主数据

将Java程序打包成EXE文件的实现方式

《将Java程序打包成EXE文件的实现方式》:本文主要介绍将Java程序打包成EXE文件的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录如何将Java程序编程打包成EXE文件1.准备Java程序2.生成JAR包3.选择并安装打包工具4.配置Launch4