我在login.jsp页面的隐藏字段中设置'cat = 1',并期望它在default-target-url上可用。 spring-security.xml中的条目是,
<form-login login-page="/login.html" default-target-url="/index.html"
authentication-failure-url="/loginfailed.html" />
并在控制器中,
@RequestMapping(value="/index", method = RequestMethod.GET)
public String index(HttpServletRequest request) {
String cat = request.getParameter("cat");
if (cat != null && cat.equalsIgnoreCase("1")) {
return "add";
}
return "redirect:/index.jsp";
}
但是无法获取请求参数值(cat为null)所以我认为这是因为'default-target-url'重定向请求(并且不转发它?)。是这样的吗?
如果是,那么我有什么方法可以将参数传递给'default-target-url'?
答案 0 :(得分:3)
我已经改变了一点实现方法。详情见下文,
<强>弹簧security.xml文件强>
<form-login login-page="/login.html" authentication-success-handler-ref="feedSuccessHandler"
authentication-failure-url="/loginfailed.html" />
<logout logout-success-url="/loggedout.html"/>
<beans:bean id="feedSuccessHandler"
class="main.java.com.sp.utilities.FeedSuccessHandler">
</beans:bean>
<强> FeedSuccessHandler.java 强>
public class FeedSuccessHandler implements AuthenticationSuccessHandler {
public void onAuthenticationSuccess(HttpServletRequest request,
HttpServletResponse response, Authentication authentication)
throws IOException, ServletException {
String cat = request.getParameter("cat");
if (cat != null && cat.equalsIgnoreCase("1")) {
response.sendRedirect(request.getContextPath()+"/add.html");
}else{
SavedRequest savedRequest = new HttpSessionRequestCache().getRequest(request, response);
if(savedRequest != null) {
response.sendRedirect(savedRequest.getRedirectUrl());
}else{
response.sendRedirect(request.getContextPath()+"/");
}
}
}
}
如果我想根据角色自定义重定向,应用程序也将按需运行,我可以使用相同的类。
答案 1 :(得分:1)
它通过defult 重定向,但您可以使用一些配置选项来更改此行为。它们都是在AbstractAuthenticationTargetUrlRequestHandler
上定义的,SavedRequestAwareAuthenticationSuccessHandler
是两个现有身份验证成功处理程序实现的父类(默认情况下targetUrlParameter
由命名空间配置使用)。
设置其redirectStrategy
属性,以便检查HTTP请求是否具有该名称的参数。如果是这样,它将重定向到该请求参数中给出的URL。
或设置自定义response.sendRedirect()
。默认实现调用{{1}},但您可以在自定义实现中更改它。
但是你会遇到一些困难,因为这些配置点都没有通过命名空间配置公开,所以你需要更深层次,并手动编写bean定义。
答案 2 :(得分:0)
重定向由redirectStrategy
SimpleUrlAuthenticationSuccessHandler
属性中定义的重定向策略控制。
redirectStrategy
的默认值是DefaultRedirectStrategy
的实例。
您需要做的是实现自己的redirectStrategy
(实现RedirectStrategy
)。
然后配置它:
...
<bean id="usernamePasswordAuthenticationFilter">
...
<property name="authenticationSuccessHandler">
<bean
class="org.springframework.security.web.authentication.SavedRequestAwareAuthenticationSuccessHandler">
<property name="redirectStrategy">
<bean class="yourRedirectStrategy"/>
<property>
</bean>
</property>
</bean>