SpringUtils 增加 getBeanIfAvailable 方法,如果可用则返回Bean,不抛出异常

This commit is contained in:
thinkgem
2025-10-09 22:52:08 +08:00
parent 839511b48c
commit 195d2ee06e

View File

@@ -28,7 +28,6 @@ import org.jasig.cas.client.validation.Assertion;
import org.jasig.cas.client.validation.Cas20ServiceTicketValidator; import org.jasig.cas.client.validation.Cas20ServiceTicketValidator;
import org.jasig.cas.client.validation.TicketValidationException; import org.jasig.cas.client.validation.TicketValidationException;
import org.jasig.cas.client.validation.TicketValidator; import org.jasig.cas.client.validation.TicketValidator;
import org.springframework.beans.factory.NoSuchBeanDefinitionException;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
import javax.validation.ValidationException; import javax.validation.ValidationException;
@@ -154,15 +153,13 @@ public class CasAuthorizingRealm extends BaseAuthorizingRealm {
// 其它类型,根据项目需要自行创建 // 其它类型,根据项目需要自行创建
else{ else{
try{ User finalUser = user;
CasCreateUser casCreateUser = SpringUtils.getBean(CasCreateUser.class); SpringUtils.getBeanIfAvailable(CasCreateUser.class, (casCreateUser) -> {
if(casCreateUser != null){ casCreateUser.createUser(finalUser, attrs);
casCreateUser.createUser(user, attrs); }, (e -> {
}
}catch(NoSuchBeanDefinitionException e){
throw new AuthenticationException("msg:用户 “" + token.getUsername() throw new AuthenticationException("msg:用户 “" + token.getUsername()
+ "”, 类型 “" + user.getUserType() + "” 在本系统中不存在, 请联系管理员."); + "”, 类型 “" + finalUser.getUserType() + "” 在本系统中不存在, 请联系管理员.");
} }));
} }
}else{ }else{
throw new AuthenticationException("msg:用户 “" + token.getUsername() + "” 在本系统中不存在, 请联系管理员."); throw new AuthenticationException("msg:用户 “" + token.getUsername() + "” 在本系统中不存在, 请联系管理员.");