I'm using Spring Security 3.2 with CSRF. My configuration includes this:
<csrf />
<form-login default-target-url="/defaultPage"/>
When the user does a POST form submit (with a CSRF token) that requires authentication, he is redirected to the log in page. Afterwards, instead of submitting the request, the user is redirected to the defaultPage
by Spring Security.
I suspect the issue is that the CSRF token gets reset during log in.
How can I get such a POST redirect after log in working?
Update: I tried to create a custom SavedRequestAwareAuthenticationSuccessHandler
to redirect to the original POST request. However, I saw that the original request wasn't even being saved in the requestCache
.
It seems that when CSRF protection is enabled, Spring Security only puts your original request in the requestCache
if the request used the GET
method. In order to have it cache POST
requests as well, I created a custom requestCache
.
I'm not 100% convinced that doing so doesn't weaken the CSRF protection somehow, but it seems safe in my mind.
Add request cache bean to the XML configuration:
<bean id="requestCache" class="a.b.c.AlwaysSaveRequestCache" />
<http>
<csrf />
<request-cache ref="requestCache" />
</http>
Implement the custom request cache, by extending and borrowing code from HttpSessionRequestCache
:
public class AlwaysSaveRequestCache extends HttpSessionRequestCache
{
@Override
public void saveRequest(HttpServletRequest request, HttpServletResponse response)
{
final String SAVED_REQUEST = "SPRING_SECURITY_SAVED_REQUEST";
DefaultSavedRequest savedRequest = new DefaultSavedRequest(request, new PortResolverImpl());
request.getSession().setAttribute(SAVED_REQUEST, savedRequest);
logger.debug("DefaultSavedRequest added to Session: " + savedRequest);
}
}
Your POST
requests should now be cached and re-sent after being interrupted by the login form.
It is quite simple.Don't pass CSRF token in the form of hidden it wont work pass the CSRF token
directly as query params
to the URL
like below
<c:url value="/jobseeker/resume/uploadJobSeekerResume1?${_csrf.parameterName}=${_csrf.token}" var="uploadResumeURL"/>
<form:form action="${uploadResumeURL}" method="post" enctype="multipart/form-data">
<input id="file" name="file" type="file" />
<div class="modal-footer">
<button type="submit" class="btn btn-success" >
<span class="glyphicon glyphicon-ok-sign"></span> Save
</button>
</div>
</form:form>
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With