From 195d2ee06edddf27ee281fee2b32ae84f77ddb42 Mon Sep 17 00:00:00 2001 From: thinkgem Date: Thu, 9 Oct 2025 22:52:08 +0800 Subject: [PATCH] =?UTF-8?q?SpringUtils=20=E5=A2=9E=E5=8A=A0=20getBeanIfAva?= =?UTF-8?q?ilable=20=E6=96=B9=E6=B3=95=EF=BC=8C=E5=A6=82=E6=9E=9C=E5=8F=AF?= =?UTF-8?q?=E7=94=A8=E5=88=99=E8=BF=94=E5=9B=9EBean=EF=BC=8C=E4=B8=8D?= =?UTF-8?q?=E6=8A=9B=E5=87=BA=E5=BC=82=E5=B8=B8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../common/shiro/realm/CasAuthorizingRealm.java | 15 ++++++--------- 1 file changed, 6 insertions(+), 9 deletions(-) diff --git a/modules/core/src/main/java/com/jeesite/common/shiro/realm/CasAuthorizingRealm.java b/modules/core/src/main/java/com/jeesite/common/shiro/realm/CasAuthorizingRealm.java index 35c49268..b42887f5 100644 --- a/modules/core/src/main/java/com/jeesite/common/shiro/realm/CasAuthorizingRealm.java +++ b/modules/core/src/main/java/com/jeesite/common/shiro/realm/CasAuthorizingRealm.java @@ -28,7 +28,6 @@ import org.jasig.cas.client.validation.Assertion; import org.jasig.cas.client.validation.Cas20ServiceTicketValidator; import org.jasig.cas.client.validation.TicketValidationException; import org.jasig.cas.client.validation.TicketValidator; -import org.springframework.beans.factory.NoSuchBeanDefinitionException; import javax.servlet.http.HttpServletRequest; import javax.validation.ValidationException; @@ -154,15 +153,13 @@ public class CasAuthorizingRealm extends BaseAuthorizingRealm { // 其它类型,根据项目需要自行创建 else{ - try{ - CasCreateUser casCreateUser = SpringUtils.getBean(CasCreateUser.class); - if(casCreateUser != null){ - casCreateUser.createUser(user, attrs); - } - }catch(NoSuchBeanDefinitionException e){ + User finalUser = user; + SpringUtils.getBeanIfAvailable(CasCreateUser.class, (casCreateUser) -> { + casCreateUser.createUser(finalUser, attrs); + }, (e -> { throw new AuthenticationException("msg:用户 “" + token.getUsername() - + "”, 类型 “" + user.getUserType() + "” 在本系统中不存在, 请联系管理员."); - } + + "”, 类型 “" + finalUser.getUserType() + "” 在本系统中不存在, 请联系管理员."); + })); } }else{ throw new AuthenticationException("msg:用户 “" + token.getUsername() + "” 在本系统中不存在, 请联系管理员.");