2010-03-27 20 views
11

Al usar seguridad de primavera, específicamente con @notación; ¿Cuál es la forma correcta de acceder al director en un controlador? Digamos que la siguiente es mi controlador, pero me gustaría tener acceso a la principal en el método seguro() en algún lugar ...Spring security accessing principal

@Controller 
public class LoginController { 

    @RequestMapping(value = "/login", method = RequestMethod.GET) 
    public String login(ModelMap map, @RequestParam(value="fail" , required=false) String fail){ 
     map.addAttribute("title", "Login: AD Credentials"); 
     if(fail != null){ 
      map.addAttribute("error", "Invalid credentials"); 
     } 
     return("login"); 
    } 

    @RequestMapping("/secure") 
    @PreAuthorize("isAuthenticated()") 
    public String secure(ModelMap map, String principal){ 
     System.out.println(principal); 
     return("secure"); 
    } 


} 

Respuesta

15

Lo más fácil es SecurityContextHolder.getContext().getAuthentication().getPrincipal(). Funciona a través de un patrón local de subprocesos.

Cuestiones relacionadas