Recentemente ho iniziato a conoscere Spring Security e oggi ho posto questa domanda fondamentale (credo): Perché non posso accedere al Principal corrente all'interno di un filtro Servlet come dimostrato nella classe di seguito:Spring Security: accesso all'attuale utente autenticato all'interno di un servlet Filtro
package com.acme.test;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import org.springframework.security.core.Authentication;
import org.springframework.security.core.context.SecurityContext;
import org.springframework.security.core.context.SecurityContextHolder;
import org.springframework.stereotype.Component;
@Component
public class TestFilter implements Filter {
/*
* (non-Javadoc)
*
* @see javax.servlet.Filter#init(javax.servlet.FilterConfig)
*/
@Override
public void init(FilterConfig filterConfig) throws ServletException {
// TODO Auto-generated method stub
}
/*
* (non-Javadoc)
*
* @see javax.servlet.Filter#doFilter(javax.servlet.ServletRequest,
* javax.servlet.ServletResponse, javax.servlet.FilterChain)
*/
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
SecurityContext securityContext = SecurityContextHolder.getContext();
Authentication auth = securityContext.getAuthentication();
// auth is null here
chain.doFilter(request, response);
}
/*
* (non-Javadoc)
*
* @see javax.servlet.Filter#destroy()
*/
@Override
public void destroy() {
// TODO Auto-generated method stub
}
}
scopo autenticazione recuperato con autenticazione auth = securityContext.getAuthentication(); è nullo. Mentre si utilizza lo snippet sopra riportato in un MVC @Controller funziona bene (come previsto).
Perché sta succedendo?
vorrei guardare catena di filtri di sicurezza a molla, per ignorare la configurazione di default della molla e inserire il filtro nella posizione giusta. L'Autenticazione potrebbe essere disponibile solo in una determinata posizione http://docs.spring.io/spring-security/site/docs/3.1.x/reference/security-filter-chain.html – jpprade
@jpprade grazie. Sono principalmente interessato ai filtri generici, quindi preferirei non sovrascrivere un filtro di sicurezza.Sembra (dalle risposte in basso) che la configurazione dell'ordine del Filtro funzioni. – dimi