早上好。
我已经成功配置了CAS SSO服务器和客户端。但是,我想更改CAS的配置以使用自定义登录页面。我按照本教程进行了这样的配置,它的工作原理很吸引人。但是,问题在于,当我输入无效的凭据(错误的用户名或密码)时,它将尝试重定向到CAS的默认登录页面。但是,它应该重定向到自定义外部登录页面。如果您能帮助我找出输入错误凭据后如何使CAS重定向到其他页面,我将不胜感激。
这是我的casLoginView.jsp
<%@ page contentType="text/html; charset=UTF-8" %>
<html>
<head>
<script type="text/javascript">
function doAutoLogin() {
document.forms[0].submit();
}
</script>
</head>
<body onload="doAutoLogin();">
<form id="credentials" method="POST" action="https://externalsite.com/cas-server-webapp-4.0.0/login?service=<%= request.getParameter("service") %>">
<input type="hidden" name="lt" value="${loginTicket}" />
<input type="hidden" name="execution" value="${flowExecutionKey}" />
<input type="hidden" name="_eventId" value="submit" />
<input type="hidden" name="username" value="<%= request.getParameter("username") %>" />
<input type="hidden" name="password" value="<%= request.getParameter("password") %>" />
<% if ("true".equals(request.getParameter("rememberMe"))) {%>
<input type="hidden" name="rememberMe" value="true" />
<% } %>
<input type="submit" value="Submit" style="visibility: hidden;" />
</form>
</body>
这是我的外部自定义登录页面:
<form method="GET" action="https://externalsite.com/cas-server-webapp-4.0.0/">
<p>Username : <input type="text" name="username" /></p>
<p>Password : <input type="password" name="password" /></p>
<p>Remember me : <input type="checkbox" name="rememberMe" value="true" /></p>
<p><input type="submit" value="Login !" /></p>
<input type="hidden" name="auto" value="true" />
<input type="hidden" name="service" value="<%= request.getParameter("service") %>" />
</form>
基本上,我的外部登录页面将凭据发送到CAS登录页面,而CAS登录页面是自动提交的。但是,当凭据错误时,CAS会重定向到默认登录页面,而不是我的外部登录页面。
问候。
我通过更改login-webflow.xml文件上的转换解决了我的问题。我所做的是创建一个新的动作状态:
<action-state id="customFailedLogin">
<evaluate expression="generateLoginTicketAction.generate(flowRequestContext)" />
<transition on="generated" to="externalRedirection" />
</action-state>
而这个调用了一个视图状态,该状态将用户重定向到我的外部登录页面
<view-state id="externalRedirection" view="externalRedirect:#{requestParameters.callingUrl}&error=true"/>
(callingUrl是我使用服务网址创建并发送的变量)。最后,我只是更改了handleAuthenticationFailure中的过渡
<transition on="AccountNotFoundException" to="customFailedLogin"/>
<transition on="FailedLoginException" to="customFailedLogin"/>
希望它对其他人有帮助。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句