关于SpringSecurity出现Failed to evaluate expression ‘ps.hasAuthority(‘role‘)‘

1. 问题描述

在使用SpringSecurity对接口进行权限校验时,报错java.lang.IllegalArgumentException: Failed to evaluate expression 'ps.hasAuthority('role')'

2. 解决方案

2.1 查看是否添加注解

对于SpringSecurity对配置类,我们需要添加注解@EnableGlobalMethodSecurity(prePostEnabled = true)

java 复制代码
@EnableGlobalMethodSecurity(prePostEnabled = true)
@Configuration	
public class AdminSecurityConfig extends WebSecurityConfigurerAdapter {
	//...
}

2.2 校验接口实现类的名称

  • 对于直接使用@Service注解标识的接口实现类,其注入Spring容器后,对应bean名称的首字母会变为小写。例如注入的实现类为PermissionServiceImpl,其bean名称为permissionServiceImpl
  • 对于使用@Service(value = "xxx"),其对应bean的名称就为xxx,直接使用即可。

2.3 校验是否添加@符号进行标识。

对应接口上添加了@PreAuthorize注解后,参数正确格式为@beanName.methodName(roleName)。例如:

java 复制代码
@PreAuthorize("@permissionServiceImpl.hasPermission('role')")
相关推荐
Lyyaoo.9 分钟前
【JAVA基础面经】进程间的通信方式
java·开发语言·python
小坏讲微服务16 分钟前
Claude Code 终极实战指南:从终端 Agent 到 AI+Java 开发
java·开发语言·人工智能
ch.ju17 分钟前
Java程序设计(第3版)第二章——类型转换(2)
java
斌味代码18 分钟前
NestJS 高并发实战:从异步到集群的完整方案
java·spring boot·spring
jarvisuni19 分钟前
JCode添加批量测试,一键同步运行6个Claude Code!
java·服务器·前端
组合缺一20 分钟前
Snack JSONPath 项目架构分析
java·架构·json·jsonpath·rfc 9535
人道领域23 分钟前
2026年Java后端热点科普:Java 26新特性+Java 21落地实战,解锁后端开发新范式
java·开发语言
这辈子谁会真的心疼你23 分钟前
如何修改照片的拍摄信息?三个实用方案分享
java·python·数码相机
周末也要写八哥25 分钟前
Java面试时,线程为什么不安全?
java·开发语言·面试
Albert Edison29 分钟前
【RabbitMQ】七种工作模式
java·开发语言·分布式·rabbitmq