2010-03-27 17 views
11

Quando si utilizza la sicurezza a molla, in particolare con @notation; qual è il modo corretto per accedere al principal in un controller? Diciamo che il seguente è il mio controller, ma vorrei accedere al principale nel metodo sicuro() da qualche parte ...Principio di accesso di sicurezza a molla

@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"); 
    } 


} 

risposta

15

Il metodo più semplice è SecurityContextHolder.getContext().getAuthentication().getPrincipal(). Funziona tramite pattern thread-local.

Problemi correlati