当前位置: 首页 > news >正文

济南公司网站建设价格ui设计培训晚班

济南公司网站建设价格,ui设计培训晚班,做一家视频网站,wordpress 繁体转简目录 1. 基本知识2. 使用方式2.1 配置类2.2 直接使用 1. 基本知识 在Java中#xff0c;PreAuthorize 是Spring Security框架中的一个注解#xff0c;用于在方法调用之前对用户的权限进行验证。 允许在方法级别定义访问控制规则#xff0c;确保只有满足指定条件的用户才能调… 目录 1. 基本知识2. 使用方式2.1 配置类2.2 直接使用 1. 基本知识 在Java中PreAuthorize 是Spring Security框架中的一个注解用于在方法调用之前对用户的权限进行验证。 允许在方法级别定义访问控制规则确保只有满足指定条件的用户才能调用该方法 这个注解通常与Spring的AOP面向切面编程结合使用推荐阅读 Spring框架从入门到学精全java框架 零基础从入门到精通的学习路线 附开源项目面经等超全 本身的作用主要如下 权限控制: 主要用于实现基于方法调用的权限控制确保只有经过验证的用户才能访问受保护的方法条件判断: 允许在注解中定义条件表达式这些表达式决定是否允许方法调用 使用方式: PreAuthorize 注解的参数是一个 SpELSpring Expression Language表达式用于定义权限规则SpEL支持在表达式中使用各种功能包括方法调用、条件判断等 表达式的结果应该是布尔值如果为 true则允许方法调用否则抛出权限异常。 示例PreAuthorize(hasRole(ROLE_ADMIN)) 表示只有具有 ROLE_ADMIN 角色的用户可以调用该方法。 除了在方法级别使用 PreAuthorize还可以在全局配置中定义方法安全性 通过配置类指定应用于整个应用程序的全局安全性规则。 2. 使用方式 要么以配置类要么直接使用 2.1 配置类 如果通过配置类的方式 一般通过继承 WebSecurityConfigurerAdapter 类通过这个类配置应用程序的安全性 大致的Demo如下 import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder; import org.springframework.security.config.annotation.web.builders.HttpSecurity; import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity; import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;Configuration EnableWebSecurity public class SecurityConfig extends WebSecurityConfigurerAdapter {// 配置内存中的用户Overrideprotected void configure(AuthenticationManagerBuilder auth) throws Exception {auth.inMemoryAuthentication().withUser(user).password({noop}password).roles(USER).and().withUser(admin).password({noop}admin).roles(ADMIN);}// 配置访问控制规则Overrideprotected void configure(HttpSecurity http) throws Exception {http.authorizeRequests().antMatchers(/admin/**).hasRole(ADMIN).antMatchers(/user/**).hasRole(USER).anyRequest().authenticated().and().formLogin().loginPage(/login).permitAll().and().logout().permitAll();} }一个是普通用户一个是管理员。 访问控制规则指定了 /admin/** 路径需要具有 “ADMIN” 角色的用户才能访问 /user/** 路径需要具有 “USER” 角色的用户才能访问 其他请求需要身份验证。登录页面配置为 /login注销行为允许所有用户。 整体对于配置类来说 定义认证规则: 指定用户认证的规则、设置用户的身份验证方式例如基于内存、数据库、LDAP 等方式并定义用户的角色和权限 配置访问控制规则:哪些路径需要身份验证哪些路径允许匿名访问哪些路径需要特定的角色或权限 定制登录和注销行为: 自定义登录页面、处理登录请求的 URL、注销行为等 启用或禁用特定的安全性功能: 启用或禁用各种安全性功能例如 CSRF 保护、Session 管理等 2.2 直接使用 内部内置的方法都在这个类上 PreAuthorize 注解内置了一些方便的方法可以直接在表达式中使用例如 hasRole(ROLE_NAME) 检查用户是否具有指定角色。hasAnyRole(ROLE1, ROLE2) 检查用户是否具有给定角色中的任意一个。hasAuthority(AUTHORITY_NAME) 检查用户是否具有指定权限。hasAnyAuthority(AUTHORITY1, AUTHORITY2) 检查用户是否具有给定权限中的任意一个。hasPermission(targetObject, permission): 检查用户是否具有特定对象的特定权限。 如图所示 对于上述方法的基本细节操作如下 方法参数传递: 在表达式中可以引用方法的参数例如 PreAuthorize(hasPermission(#entity, read)) 表示检查用户是否有对给定实体的读权限。 逻辑运算: 表达式支持逻辑运算符如 and, or, not允许构建更复杂的权限规则 PreAuthorize(hasRole(ADMIN) and hasPermission(#entity, write))大致Demo如下 import org.springframework.security.access.prepost.PreAuthorize;public class MyService {// 示例1: 仅允许具有ROLE_ADMIN角色的用户调用PreAuthorize(hasRole(ROLE_ADMIN))public void adminOperation() {// 实现管理员操作的代码}// 示例2: 允许具有READ权限并且是特定用户的调用PreAuthorize(hasPermission(#username, READ))public void userOperation(String username) {// 实现用户操作的代码} }PreAuthorize 注解用于控制方法的访问权限。 只有具有ROLE_ADMIN角色的用户才能调用adminOperation方法只有具有READ权限并且传入的用户名符合条件的用户才能调用userOperation方法
http://www.zqtcl.cn/news/734205/

相关文章:

  • 谁能给个网站谢谢wordpress 主题 后门
  • 学校网站建设目的seo教学免费课程霸屏
  • 会计公司网站模板微信网站如何制作软件
  • 烟台做网站多少钱.net网站做增删改
  • 什么网站专门做软件的深圳电商网站制作
  • 局域网做网站家装公司哪家比较好
  • 免费的行情软件网站在线使用wordpress视频分享
  • 内容平台策划书网站优化公司推荐
  • 怎么在阿里巴巴网站做公司wordpress伪静态404
  • 配置 tomcat 做网站网站建设用什么语言
  • 大型的营销型网站建设怎么选择网站建设公司
  • 怎么用网站源码建站友情链接交换方式有哪些
  • 国外免费网站服务器链接幼教网站建设分析
  • 做药品网站有哪些陕西专业网站建设价格
  • 网络公司做网站网站 服务器选择
  • 湖南省重点建设项目办公室网站河南省住建局官网
  • 建设网站企业网上银行登录入口官方论坛系统
  • 嘉定建设机械网站合肥制作网页设计
  • 外链网站有哪些空港经济区内的建设工程网站
  • 企业网站开发价阿里云快速备份网站
  • 大型电子商务网站建设成本ai网页生成
  • 网页播放视频 网站开发常用网站搜索引擎
  • 制作一个购物网站要多少钱做创意小视频的网站
  • 淇县网站建设软件定制流程
  • 17网站一起做网店代发流程wordpress悬浮 联系
  • 如何查网站外链快速开发平台 免费开源
  • 做网站有哪些流程怎么做网站电影
  • 做街机棋牌上什么网站发广告网站策划和运营
  • 建网站是什么专业类别阳江网红人物
  • 网站建设工作描述株洲市建设质监站网站