java - Autowired 注释在 AuthenticationSuccessHandler 中返回 null

标签 java spring-mvc spring-security

在我的 Spring Security 应用程序中,我尝试在成功登录后返回 cookie 'remember_token'。我的 AuthenticanSuccessHandler 类自动连接 RememberMeService 类以从数据库获取“ token ”值。但 Autowiring 的引用 rememberMeService 返回 null。我确实提到了该类的 @Component 注释,但它并没有改变结果。 Link to complete source code

FormAuthenticationSuccessHandler:

package com.fastcheck.timesheet.common.security;

import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.core.Authentication;
import org.springframework.security.core.userdetails.UserDetails;
import org.springframework.security.web.authentication.AuthenticationSuccessHandler;
import org.springframework.stereotype.Component;

import com.fastcheck.timesheet.common.services.RememberMeService;


@Component
public class FormAuthenticationSuccessHandler implements AuthenticationSuccessHandler
{
    @Autowired
    public RememberMeService rememberMeService;

@Override
public void onAuthenticationSuccess(HttpServletRequest request, HttpServletResponse response,
        Authentication authentication) throws IOException, ServletException
{

    String username;
    Object principal = authentication.getPrincipal();
    if (principal instanceof UserDetails) 
        {
            username = ((UserDetails)principal).getUsername();
        } 
        else 
        {
            username = principal.toString();

        }

    System.out.println("rememberMeService :"+rememberMeService);
    if(rememberMeService != null)
        {
            Cookie cookie=new Cookie("remember_token",rememberMeService.getRememberMeToken(username));
            cookie.setMaxAge(200);
            response.addCookie(cookie);
        }


    response.setStatus(200);
    response.sendRedirect("home");


}

}

最佳答案

我从您的代码中了解到,您正在尝试实现 Spring Security 为您提供开箱即用的功能。

如果您正确实现了 Spring Security,我不明白为什么在成功进行身份验证后,记住我 token 不会像您尝试做的那样自动存储在用户的浏览器上。

关于java - Autowired 注释在 AuthenticationSuccessHandler 中返回 null,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45663290/

相关文章:

java - 连接移动设备 (Android) 作为 MTP,现在我们可以访问此设备并获取时间

java - 标准 API : Using the Criteria API to Create Queries documentation

spring - 无法在Spring Security登录事件监听器中获取 “remember me”用户的 session ID

grails - 为什么 UserRole 实现 Serializable 并覆盖 equals() 和 hashcode() 方法

java - 获取通过 Eclipse 生成的 Javadoc 的命令行

java - 我如何确定一个 Eclipse 工作区中 2 个项目的启动顺序?

spring-mvc - Spring 启动 : Log all incoming HTTP requests when using an embedded Jetty server?

Spring mvc 应用程序在 tomcat 中不能作为 war 运行,但在 IDE 中运行良好

java - 无法使用 Spring 在 AppFog 上维持 session

java - 如何修复 Spring Security 中的角色?