12-1 Springboot过滤拦截和日志处理

Springboot的日志

默认日志框架:logback

1.日志以文件的形式的保存 使用logback框架 ->(运行日志,开发中用于调式的,在开发中作为系统运行日志记录故障,从而追究问题根源)

2.日志相关的表 记录用户相关操作信息 -> 需要我们去处理  -> 作为系统功能存在

日志配置:

SpringBoot默认日志输出目的地: console(控制台)

在生产环境,日志肯定不是在控制台

设置日志输出目的地:文件
 

问题:
这个项目所有的日志保存在一个文件,系统运行越久,日志文件中内容越多,打开越慢,找特定日期的日志文件困难

解决方案:

每一天产生一个日志文件,根据每个日志文件级别单独再创建一个文件

想实现解决方案效果,默认配置无法实现

logback框架允许我们编写配置文件:推荐使用xml

logback运行流程:
1. logback会在类路径下寻找名为logback-test.xml的文件
2。如果没有找到,logback会继续寻找名为logback.groovy的文件

3.如果没有找到,logback会继续寻找名为logback.xml的文件

4.如果没有找到,将会在类路径下寻找文件META-INFO/services/ch.qos.logback.classic.spi.Configurator,该文件的内容为实现了Configurator接口的实现类的全限定类名
5.如果以上都没有成功,logback会通过BasicConfigurator为自己进行配置,并且日志将会全部在控制台打印出来

SpringBoot加载logback的配置文件默认默认会加载classpath:logback-spring.xml或者classpath:logback-spring.groovy或者:classpath:logback.xml或者: classpath: logback-test.xml

如果logback的配置文件:不是logback-spring.xml,logback-test.xmL,logback.xml可以在SpringBoot全局配置文件: application.yml指定配置文件

注意:
logback配置文件名: logback-logback.xml不能使用

SpringBoot中过滤器和拦截器的应用

过滤器

过滤器的实现:
1. javaWeb实现:实现javax.servlet.Filter接口  如果设置拦截方式为forward,默认面定向拦截
2. Spring对Filter接口进行再次封装:OncePerRequestFilter抽象类,Spring框架推荐使用

OncePreRequestFilter :  只对该请求进行一次过滤

AFilter拦截方式:重定向方式拦截,转发拦截

localhost:8080/hello    可以访问   不会拦截此时  因为拦截会打印AFilter......

过滤器的配置方式:
1.使用@WebFilter注解(javaWeb的注解),配置过滤器,使用@ServletComponentScan扫描web注解

.

.

.

.

.注释AFilter

AFilter再转发中拦截了两次  BFilter是另一种方式,是继承了OncePerRequestFiter这种方式

.继承OncePreRequestFilter,一-次请求只拦截一次

.

.

改变过滤器1拦截顺序:

1.使用@WebFilter配置,指定过滤器执行顺序,修改类名,根据类名顺序

2.使用Springboot提供的配置类方式配置: FilterRegistrationBean类,专门用于注册过滤器

方法二:(解决之前JavaWeb中所没有的指定过滤方法的缺陷)

提供setOrder()指定过滤器执行顺序,数字越小,越先执行

JavaWeb的配置类

@Bean

public  FilterRegisterationBean<AFilter>  aFilterRegisterationBean(){

        new 

}

拦截器

使用配置类进行配置

WebMvcConfigurer接口是SPringboot提供给开发者对SpringMvc的配置扩展

登录成功->得到token

带回服务器  防止伪造token -> 

token

拦截处理判断

登录的重定向解决

ajax发送的请求!!!!!

跳转由前端来处理  下面这种方式是不对的

token从session里拿

Q1主界面 详情界面不是可以直接访问的,需要登录  直接访问会因为没有携带token导致允许都无法访问

Q2拦截ajax请求 没有token response重定向跳转到login.html 前端需要数据 前端实现跳转

解决方案:不让用户直接通过url访问主界面和详情界面

我可以提供一个处理器controller来让用户进行访问

HtmlController.java

@RequestMapping("test")

public String toindex(){return "forward:/index.html"}

Q2:

拿到请求头里的东向来进行区分

ajax没有token下的失败   过滤器会拦截  根据header里的状态判断是否拦截

手动响应json

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/191523.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

<Linux>(极简关键、省时省力)《Linux操作系统原理分析之linux存储管理(2)》(18)

《Linux操作系统原理分析之linux存储管理&#xff08;1&#xff09;》&#xff08;17&#xff09; 6 Linux存储管理6.2 选段符与段描述符6.2.1 选段符6.2.2 段描述符6.2.3 分段机制的存储保护 6.3 80x86 的分页机制6.3.180x86 的分页机制6.3.2 分页机制的地址转换6.3.3 页表目录…

PTA预编译中的宏定义:求平行四边形面积

已知平行四边形面积函数的原型如下&#xff1a; 函数原型 double ParaArea(double base, double height); 说明&#xff1a;参数 base 和 height 分别为平行四边形的底和高&#xff0c;函数值为平行四边形的面积。 请在空白处填写适当内容&#xff0c;用带参数的宏替换命令…

FWFT-FIFO的同步和异步verilog代码

//----------------------------------------------------------------------------- // File Name : fifo_sync.v //----------------------------------------------------------------------------- //参数化同步FIFO。DEPTH可以是任何大于0的整数值。实际使用的内存深度是…

嵌入式WIFI芯片通过lwip获取心知天气实时天气信息(包含完整代码)

一、天气API 1. 心知天气的产品简介 HyperData 是心知天气的高精度气象数据产品&#xff0c;通过标准的 Restful API 接口&#xff0c;提供标准化的数据访问。无论是 APP、智能硬件还是企业级系统都可以轻松接入心知的精细化天气数据。 HyperData API V4版是当前的最新…

运筹学-使用python建模基本操作

运筹学中的python基本操作 运筹学库的基本介绍MIP 库的使用networkx 库的使用运筹学 所谓运筹学(Operation Research) 就是用数学方法研究各种系统最优化问题的学科,为决策者提供科学决策的依据,求解系统最优化问题,制定合理运用人力,物力,财力的方案。 库的基本介绍 对…

Go函数和方法之间有什么区别

基础知识 在了解两者不同之前&#xff0c;还是简单的回顾一下基础语法知识。下面的实例&#xff0c;定义一个函数和方法&#xff0c;然后调用函数和方法。 package mainimport "fmt"// 函数和方法 func function1() {fmt.Println("我是一个名字叫做function1的…

要致富 先撸树——判断循环语句(六)

引子 什么&#xff1f;万年丕更的作者更新了&#xff1f; 没错&#xff01;而且我们不当标题党&#xff0c;我决定把《我的世界》串进文章里。 什么&#xff1f;你不玩《我的世界》&#xff1f; 木有关系 本专栏文章主要在讲c语言的语法点和知识&#xff0c;保证让不玩《我…

Azure Machine Learning - 在 Azure 门户中创建AI搜索技能组

你将了解 Azure AI 搜索中的技能组如何通过添加光学字符识别 (OCR)、图像分析、语言检测、文本翻译和实体识别&#xff0c;在搜索索引中创建可搜索文本的内容。 关注TechLead&#xff0c;分享AI全维度知识。作者拥有10年互联网服务架构、AI产品研发经验、团队管理经验&#xff…

Python程序员入门指南:就业前景

文章目录 标题Python程序员入门指南&#xff1a;就业前景Python 就业数据Python的就业前景SWOT分析法Python 就业分析 标题 Python程序员入门指南&#xff1a;就业前景 Python是一种流行的编程语言&#xff0c;它具有简洁、易读和灵活的特点。Python可以用于多种领域&#xff…

ganache部署智能合约报错VM Exception while processing transaction: invalid opcode

这是因为编译的字节码不正确&#xff0c;ganache和remix编译时需要选择相同的evm version 如下图所示&#xff1a; remix: ganache: 确保两者都选择london或者其他evm&#xff0c;只要确保EVM一致就可以正确编译并部署&#xff0c; 不会再出现VM Exception while processing…

分享一个国内可用的免费GPT4-AI提问AI绘画网站工具

一、前言 ChatGPT GPT4.0&#xff0c;Midjourney绘画&#xff0c;相信对大家应该不感到陌生吧&#xff1f;简单来说&#xff0c;GPT-4技术比之前的GPT-3.5相对来说更加智能&#xff0c;会根据用户的要求生成多种内容甚至也可以和用户进行创作交流。 然而&#xff0c;GPT-4对普…

LangChain 18 LangSmith监控评估Agent并创建对应的数据库

LangChain系列文章 LangChain 实现给动物取名字&#xff0c;LangChain 2模块化prompt template并用streamlit生成网站 实现给动物取名字LangChain 3使用Agent访问Wikipedia和llm-math计算狗的平均年龄LangChain 4用向量数据库Faiss存储&#xff0c;读取YouTube的视频文本搜索I…

Nacos源码解读03——管理元数据

监听元数据事件 NamingMetadataManager Overridepublic void onEvent(Event event) {//实例元数据if (event instanceof MetadataEvent.InstanceMetadataEvent) {handleInstanceMetadataEvent((MetadataEvent.InstanceMetadataEvent) event);//服务元数据 } else if (event …

SSM框架(五):Maven进阶

文章目录 一、分模块开发1.1 分模块开发的意义1.2 步骤 二、依赖管理2.1 依赖传递2.2 可选依赖和排除依赖 三、继承与聚合3.1 聚合3.2 继承3.3 聚合和继承区别 四、属性4.1 pom文件的依赖使用属性4.2 资源文件使用属性 五、多环境开发六、跳过测试七、私服7.1 下载与使用7.2 私…

文件操作-IO

文件操作-IO 1.认识文件1.什么是文件2.文件路径 2.java中操作文件2.1 File类的用法 3.InputStream和OutputStream的用法 1.认识文件 1.什么是文件 文件是计算机系统中用来存储数据的基本单位。它是一种用于持久性存储数据的命名、有序的数据集合.计算机系统通过文件系统来组织…

gitlab高级功能之容器镜像仓库

今天给大家介绍一个gitlab的高级功能 - Container Registry&#xff0c;该功能可以实现docker镜像的仓库功能&#xff0c;将gitlab上的代码仓的代码通过docker构建后并推入到容器仓库中&#xff0c;好处就是无需再额外部署一套docker仓库。 文章目录 1. 参考文档2. Container R…

【动手学深度学习】(九)Kaggle房价预测

文章目录 一、代码1.下载和缓存数据集 【相关总结】1.os.makedirs()2.os.path.join()3.os.path.exits()4.os.path.dirname() 一、代码 题目链接 1.下载和缓存数据集 建立字典DATA_HUB&#xff0c;将数据集名称的字符串映射到数据集相关的二元组上&#xff0c;这个二元组包含…

Linux 进程(三)

Linux进程状态的查看&#xff1a; 这是Linux内核源代码对于进程状态的定义&#xff1a; R运行状态&#xff08;running&#xff09;: 并不意味着进程一定在运行中&#xff0c;它表明进程要么是在运行中要么在运行队列里。 S睡眠状态&#xff08;sleeping): 意味着进程在…

openGauss学习笔记-138 openGauss 数据库运维-例行维护-检查时间一致性

文章目录 openGauss学习笔记-138 openGauss 数据库运维-例行维护-检查时间一致性138.1 操作步骤 openGauss学习笔记-138 openGauss 数据库运维-例行维护-检查时间一致性 数据库事务一致性通过逻辑时钟保证&#xff0c;与操作系统时间无关&#xff0c;但是系统时间不一致会导致…

[传智杯 #3 决赛] 商店

disangan333 想给 disangan233 买一个礼物&#xff0c;于是他和你一起逛商店。 超详细&#xff0c;超详细&#xff0c;超详细&#xff0c;超详细 题目描述 有 n 名同学去逛商店&#xff0c;店里有 m 个物品&#xff0c;第 i 人有 wi​ 块钱&#xff0c;第 i 个物品价格 ci​…