`

cas自定义登录异常

    博客分类:
  • cas
阅读更多

cas版本4.0 

定义异常类com.xxx.MyLoginException

在认证时根据实际情况抛出MyLoginException:

public class MyDatabaseAuthenticationHandler extends AbstractJdbcUsernamePasswordAuthenticationHandler {
    /** {@inheritDoc} */
    @Override
    protected final HandlerResult authenticateUsernamePasswordInternal(final UsernamePasswordCredential credential) throws GeneralSecurityException, PreventedException {
        final String username = credential.getUsername();        
        try {
        	//do sth
        	if (...){
        	    throw new MyLoginException("...");
                }

        } catch (final Exception e) {
            throw new PreventedException("exception", e);
        }
        
        return createHandlerResult(credential, new SimplePrincipal(username), null);
    }

  替换默认的认证异常处理handler:

public class MyAuthenticationExceptionHandler extends AuthenticationExceptionHandler {
	
    private List<Class<? extends Exception>> errs= new ArrayList<Class<? extends Exception>>();	

	public void init() {
		errs.addAll(getErrors());
		errs.add(com.xxx.MyLoginException.class);
		setErrors(errs);
	}
}
 cas-servlet.xml修改 
  <!-- <bean id="authenticationExceptionHandler" class="org.jasig.cas.web.flow.AuthenticationExceptionHandler" /> -->
  <bean id="authenticationExceptionHandler" class="com.xxx.MyAuthenticationExceptionHandler" init-method="init" />
 messages_*.properties加入异常类对应的消息

authenticationFailure.MyLoginException=登录失败异常...

 

login-webflow.xml加入异常转向的页面处理

 

  <action-state id="handleAuthenticationFailure">
......
    <transition on="MyLoginException" to="generateLoginTicket"/>
......
  </action-state>

 

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics