spring security實現記錄用戶登錄時間等信息
上一篇: spring security實現記住我下次自動登錄功能
一、原理分析
spring security提供了一個接口 AuthenticationSuccessHandler,該接口中只有一個方法,用來進行登錄成功后的操作
public interface AuthenticationSuccessHandler {
/**
* Called when a user has been successfully authenticated.
*
* @param request the request which caused the successful authentication
* @param response the response
* @param authentication the <tt>Authentication</tt> object which was created during
* the authentication process.
*/
void onAuthenticationSuccess(HttpServletRequest request,
HttpServletResponse response, Authentication authentication)
throws IOException, ServletException;
}
我們可以通過實現該接口來自定義登錄成功后的操作,但spring security提供了一個SavedRequestAwareAuthenticationSuccessHandler
實現類,這個實現類可以記住用戶未登錄前要訪問的地址,這樣登錄成功后就可以把用戶再跳轉到他想去的頁面。所以我們一般使用繼承這個類的方式來實現自定義登錄后續操作的功能。
二、實現方式
2.1 自定義AuthenticationSuccessHandler實現類
自定義AuthenticationSuccessHandler接口的實現類,繼承SavedRequestAwareAuthenticationSuccessHandler類,並加入到spring容器中
@Component("loginSuccessHandler")
public class LoginSuccessHandler extends SavedRequestAwareAuthenticationSuccessHandler {
@Autowired
private IUserDao userDao;
public void onAuthenticationSuccess(HttpServletRequest request, HttpServletResponse response, Authentication authentication) throws IOException, ServletException {
//記錄相關的用戶信息,如上次登錄時間
String name = authentication.getName();
userDao.updateLastLonginTime(System.currentTimeMillis(),name);
//調用父類的方法把用戶引導到未登錄前要去的頁面
super.onAuthenticationSuccess(request,response,authentication);
}
}
其中remember-me-parameter="remembermeParamater"
指定前台傳遞的是否rememberme的參數名,前台要傳遞的參數值是true或false
2.2 在spring-security的配置文件中指定自定義的AuthenticationSuccessHandler
<!--自定義登錄頁面-->
<security:form-login login-page="/login.html" login-processing-url="/login"
username-parameter="username" password-parameter="password"
authentication-failure-forward-url="/failed.html"
default-target-url="/index.html"
authentication-success-handler-ref="loginSuccessHandler"
/>
實例上就是在定義自定義登錄頁面的標簽內指定authentication-success-handler-ref="loginSuccessHandler"
,其中loginSuccessHandler是自定義的這個bean在容器中的名稱
2.3 測試
啟動工程,進行登錄,登錄成功后會更新用戶表中的last_login_time
字段。
需要注意的是如果是通過readme進行的登錄,不會更新當前用戶的登錄時間,只有通過賬號密碼登錄時才會進行更新,也就是只有這時才會執行這個onAuthenticationSuccess方法
三、總結
在用戶登錄成功后記錄本次登錄相關的信息,需要繼承spring-security提供的SavedRequestAwareAuthenticationSuccessHandler
類,重寫其中的onAuthenticationSuccess方法,在其中進行記錄用戶信息的操作,在方法的最后調用父類的方法把用戶引導到未登錄前要去的頁面。
測試工程代碼的地址:工程示例