若依的RBAC权限控制框架

若依权限管理框架

在这里插入图片描述

Spring Security介绍

  • Spring Security是spring的权限控制框架,主分为 认证授权
  • 认证:是否能进入登录
  • 授权:是否有权限访问对应的资源controller能否访问

在这里插入图片描述
在这里插入图片描述

Spring Security 配置

在这里插入图片描述
在这里插入图片描述

配置类上有一个非常重要的注解
@EnableGlobalMethodSecurity(prePostEnabled = true, securedEnabled = true)

在这里插入图片描述

  • 我们自己的配置类是继承了Spring Security原本框架提供的基类,此基类中 有很多 默认 的 配置方法,极大地简化了我们配置操作
  • 如果说 想要 自定义某些配置,你就需要 重写 对应的方法

认证方法的重写

  • 但是这个方法解决的无法依赖注入的问题

在这里插入图片描述

在这里插入图片描述

重写配置相关的方法

在这里插入图片描述

加入可以匿名访问的资源

在这里插入图片描述
在这里插入图片描述

  • 找带有Anonymous注解的

在这里插入图片描述

这个类一般是加在 Controller方法上

在这里插入图片描述

配置哪些是可以放行的,哪些需要拦截的

  • 禁用响应的标头
  • 认证失败的处理
  • 基于token,不使用session
  • 放行静态资源
  • 拦截其他请求
  • 防止页面被IFrame嵌套使用
httpSecurity
         // CSRF禁用,因为不使用session
         .csrf().disable()
         // 禁用HTTP响应标头
         .headers().cacheControl().disable().and()
         // 认证失败处理类 unauthorizedHandler通过IOC容器注入
         .exceptionHandling().authenticationEntryPoint(unauthorizedHandler).and()
         // 基于token,所以不需要session STATELESS 代表任何请求都不需要session
         .sessionManagement().sessionCreationPolicy(SessionCreationPolicy.STATELESS).and()
         // 上面的配置都是全局配置,是基于HttpSecurity 进行链式编程的
         // 过滤请求
         .authorizeRequests()
         // 下面的配置是针对认证请求的配置,是基于ExpressionInterceptUrlRegistry进行链式编程的
         // 对于登录login 注册register 验证码captchaImage 允许匿名访问
         .antMatchers("/login", "/register", "/captchaImage").permitAll()
         // 静态资源,可匿名访问
         .antMatchers(HttpMethod.GET, "/", "/*.html", "/**/*.html", "/**/*.css", "/**/*.js", "/profile/**").permitAll()
         .antMatchers("/swagger-ui.html", "/swagger-resources/**", "/webjars/**", "/*/api-docs", "/druid/**").permitAll()
         // 除上面外的所有请求全部需要鉴权认证
         .anyRequest().authenticated()
         .and()
         //禁用 HTTP 响应头中的 `X-Frame-Options`。`X-Frame-Options` 是一个 HTTP 响应头,用于防止网页被嵌入到 `iframe` 中,从而防止点击劫持攻击。
         .headers().frameOptions().disable();

其他配置

// 添加Logout filter logoutSuccessHandler是通过IOC容器依赖注入的
httpSecurity.logout().logoutUrl("/logout").logoutSuccessHandler(logoutSuccessHandler);
// 添加JWT filter authenticationTokenFilter是通过IOC容器依赖注入的  UsernamePasswordAuthenticationFilter是SpringSecurity默认的登录验证过滤器
// 会将用户的认证对象放入SecurityContextHolder中
httpSecurity.addFilterBefore(authenticationTokenFilter, UsernamePasswordAuthenticationFilter.class);
// 添加CORS filter
// 在认证过滤器之前添加CORS filter  处理跨域请求
httpSecurity.addFilterBefore(corsFilter, JwtAuthenticationTokenFilter.class);
// 在退出过滤器之前添加CORS filter 处理跨域请求
httpSecurity.addFilterBefore(corsFilter, LogoutFilter.class);

用户认证的详细逻辑

密码加密之后传递给详细的接口,进行认证

/**
 * 身份认证接口
 */
// 这个configure方法是用来配置用户信息服务的,即配置用户的登录信息  和上面的configure方法不是同一个方法
@Override
protected void configure(AuthenticationManagerBuilder auth) throws Exception
{
    // 通过userDetailsService方法注入自定义的用户认证逻辑
    auth.userDetailsService(userDetailsService).passwordEncoder(bCryptPasswordEncoder());
}

全局就这么一个实现类

在这里插入图片描述
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Scala_【1】概述

第一章 语言特点环境搭建(Windows)idea编写scalaHelloWorld注意事项 Scala是一门以Java虚拟机(JVM)为运行环境并将面向对象和函数式编程的最佳特性结合在一起的静态类型编程语言 语言特点 Scala是一门多范式的编程语言,Scala支持面向对象和函…

sqoop抽数报错Every derived table must have its own alias

sqoop抽数报错Every derived table must have its own alias 报错如下: ERROR manager.SqlManager: Error executing statement: java.sql.SQLSyntaxErrorException: Every derived table must have its own alias 修改前脚本: –query "select * …

大小鼠智能热板仪 智能冷板仪~根据实验需求和方向选择“冷”or“热”

冷板仪的工作原理 SS-I5IO56IO48O 冷板仪主要通过提供一个可调节温度的冷板(通常为金属地板),其温度设定在低温范围内(如5℃),用于模拟冷刺激引起的疼痛反应。实验时,动物被放置在冷板上&…

VMware vCenter保姆级安装部署(VMware VCenter Nanny Level Installation and Deployment)

VMware vCenter保姆级安装部署教程 VMware vCenter‌是由VMware开发的一款虚拟化管理平台,主要用于管理和监控虚拟化环境中的虚拟机、主机和存储资源。它提供了一个集中控制的平台,简化了虚拟化基础设施的管理工作,提高了资源利用率和灵活性…

WebGIS实战开源项目:智慧机场三维可视化(学习笔记)

From:新中地 1.简介 智慧机场解决方案,基于数字化大平台,融合AI、大数据、IoT、视频云、云计算等技术,围绕机场“运控、安防、服务”三大业务领域,构建“出行一张脸”及“运行一张图”两大场景化解决方案。 https://…

玩转OCR | 探索腾讯云智能结构化识别新境界

📝个人主页🌹:Eternity._ 🌹🌹期待您的关注 🌹🌹 ❀ 玩转OCR 腾讯云智能结构化识别产品介绍服务应用产品特征行业案例总结 腾讯云智能结构化识别 腾讯云智能结构化OCR产品分为基础版与高级版&am…

【论文阅读笔记】Scalable, Detailed and Mask-Free Universal Photometric Stereo

【论文阅读笔记】Scalable, Detailed and Mask-Free Universal Photometric Stereo 前言摘要引言Task 相关工作方法SDM-UniPS预处理尺度不变的空间光特征编码器像素采样变压器的非局部交互 PS-Mix数据集 实验结果训练细节评估和时间: 消融实验定向照明下的评估没有对…

自动控制系统综合与LabVIEW实现

自动控制系统综合是为了优化系统性能,确保其可靠性、稳定性和灵活性。常用方法包括动态性能优化、稳态误差分析、鲁棒性设计等。结合LabVIEW,可以通过图形化编程、高效数据采集与处理来实现系统综合。本文将阐述具体方法,并结合硬件选型提供实…

VUE 3.0 如何新建项目 详细教程 附环境搭建 推荐

本人新入手一台电脑,需要安装各种环境配置,顺便把过程记录一下,方便自己以后查看,也欢迎大家参考交流。 目录 一、环境搭建: 1.Node.js安装 2.国内淘宝镜像设置 3.安装vue 环境 二、新建vue项目 1.vue脚手架新建…

牛客网刷题 ——C语言初阶——BC114 小乐乐排电梯

1.牛客网 :BC114 小乐乐排电梯 题目描述: 小乐乐学校教学楼的电梯前排了很多人,他的前面有n个人在等电梯。电梯每次可以乘坐12人,每次上下需要的时间为4分钟(上需要2分钟,下需要2分钟)。请帮助…

UE5 渲染管线 学习笔记

兰伯特 SSS为散射的意思 带Bias的可以根据距离自动切换mip的卷积值 而带Level的值mipmaps的定值 #define A8_SAMPLE_MASK .a 这样应该就很好理解了 这个只采样a通道 带Level的参考上面的 朝左上和右下进行模糊 带Bias参考上面 随机数 4D 3D 2D 1D

‘vite‘ 不是内部或外部命令,也不是可运行的程序

报错:执行 npm run dev时,提示’vite’ 不是内部或外部命令,也不是可运行的程序 解决:执行 npm install -g vite 报错:导入vite后再次执行npm run dev,报错failed to load config from E:\eclipseWP\test1…

gitlab克隆仓库报错fatal: unable to access ‘仓库地址xxxxxxxx‘

首次克隆仓库,失效了,上网查方法,都说是网络代理的问题,各种清理网络代理后都无效,去问同事: 先前都是直接复制的网页url当做远端url,或者点击按钮‘使用http克隆’ 这次对于我来说有效的远端u…

apisix docker 安装

git clone https://github.com/apache/apisix-docker.git cd apisix-docker/example nano docker-compose 主要修改这里ETCD_ADVERTISE_CLIENT_URLS: "http://192.168.31.160:2379" docker compose -p docker-apisix up -d#安装apisix-dashboard docker pull apache/…

相机雷达外参标定综述“Automatic targetless LiDAR–camera calibration: a survey“

相机雷达外参标定综述--Automatic targetless LiDAR–camera calibration: a survey 前言1 Introduction2 Background3 Automatic targetless LiDAR–camera calibration3.1 Information theory based method(信息论方法)3.1.1 Pairs of point cloud and image attributes(属性…

第13篇 冒泡排序__ARM C语言<二>

Q:如何设计ARM C语言程序对数组进行降序排列? A:基本原理也和Nois II C语言程序一样:通过不断的比较和交换数组中的数据元素,最终使得最大的数据“冒泡”排到到数组最末,并逐步缩小待排序的范围直到所有数…

Pytorch | 利用AI-FGTM针对CIFAR10上的ResNet分类器进行对抗攻击

Pytorch | 利用AI-FGTM针对CIFAR10上的ResNet分类器进行对抗攻击 CIFAR数据集AI-FGTM介绍算法流程初始化迭代更新( t 0 t 0 t0 到 T − 1 T - 1 T−1)迭代完成 AI-FGTM代码实现AI-FGTM算法实现攻击效果 代码汇总aifgtm.pytrain.pyadvtest.py 之前已经…

C++程序启动报错和启动失败的常见原因分析与排查经验总结

目录 1、概述 2、程序启动报错的原因分析与排查方法 2.1、程序启动时报找不到依赖的dll库 2.1.1、找不到C/C运行时库 2.1.2、找不到依赖的业务库 2.2、程序启动时报在依赖的dll库中找不到接口 2.3、程序启动时报0xC000007B错误码 3、程序启动不了(启动失败&…

《通义千问AI落地—中》:前端实现

一、前言 本文源自微博客且已获授权,请尊重版权. 书接上文,上文中,我们介绍了通义千问AI落地的后端接口。那么,接下来我们将继续介绍前端如何调用接口以及最后的效果;首先看效果: 上述就是落地到本微博客以后的页面效果…

Python OCR 文字识别

一.引言 文字识别,也称为光学字符识别(Optical Character Recognition, OCR),是一种将不同形式的文档(如扫描的纸质文档、PDF文件或数字相机拍摄的图片)中的文字转换成可编辑和可搜索的数据的技术。随着技…