3

現在、次を使用してユーザーをアプリケーションにログインさせています。ただし、角度関数を使用して実際にログインを実行したいと思います。これを行うには、認証する残りの Web サービスを作成したいと思いますが、SO で表示されるすべての例では、減価償却されたと思われる User を使用しています。また、サービスがユーザーに関する情報を返すことも望んでいます。

私が求めているのは、MyUserDetailsS​​ervice をログイン用の安らかなサービスとして使用するように変更する方法、またはログイン後にユーザー オブジェクトを返すログインに使用できるサービスを作成する方法です。

<form class="navbar-form" action="/j_spring_security_check" method="post">
   <input class="span2" name="j_username"  type="text" placeholder="Email">
   <input class="span2" name="j_password" type="password" placeholder="Password">
   <input type="submit" class="btn btn-primary" value="Log in"/>
</form>

これは私のauthenticationManagerです

<authentication-manager>
    <authentication-provider user-service-ref="MyUserDetailsService">
        <password-encoder ref="passwordEncoder"/>
    </authentication-provider>
</authentication-manager>

これは、現在ログインに使用しているユーザー詳細サービスです。

@Service("MyUserDetailsService")
public class MyUserDetailsService implements UserDetailsService {
    private static final Logger logger = LoggerFactory.getLogger(MyUserDetailsService.class);

    private UserManager userManager;

    @Autowired
    public MyUserDetailsService(UserManager userManager) {
        this.userManager = userManager;
    }
    @Override
    @Transactional
    public UserDetails loadUserByUsername(String email) throws UsernameNotFoundException, DataAccessException {
        if ((email == null) || email.trim().isEmpty()) {
            throw new UsernameNotFoundException("Email is null or empty");
        }
        logger.debug("Checking users with email: " + email);

        Users users = userManager.findByEmail(email);

        if (users == null) {
            String errorMsg = "User with email: " + email + " could not be found";
            logger.debug(errorMsg);
            throw new UsernameNotFoundException(errorMsg);
        }

        Collection<GrantedAuthority> grantedAuthorities = toGrantedAuthorities(users.getRoleNames());
        String password = users.getPassword();
        boolean enabled = users.isEnabled();
        boolean userNonExpired = true;
        boolean credentialsNonExpired = true;
        boolean userNonLocked = true;

        return new User(email, password, enabled, userNonExpired, userNonLocked, credentialsNonExpired, grantedAuthorities);
    }

    public static Collection<GrantedAuthority> toGrantedAuthorities(List<String> roles) {
        List<GrantedAuthority> result = newArrayList();

        for (String role : roles) {
            result.add(new SimpleGrantedAuthority(role));
        }

        return result;
    }
}
4

1 に答える 1

3

ビューでいくつかのことを行うために使用できるSpring Security 用の JSTL タグがいくつかあります。何らかの理由で JSTL がオプションでない場合は、次のようにすることができます。

${pageContext.request.userPrincipal.principal.yourCustomProperty}

また、コントローラーでプリンシパルを取得し、モデルに設定することもできます。

于 2013-03-08T20:51:28.330 に答える