How to Manually Authenticate User with Spring Security

1. Overview

In this quick article, we’ll focus on how to programmatically set an authenticated user in Spring Security and Spring MVC.

2. Spring Security

Simply put, Spring Security hold the principal information of each authenticated user in a ThreadLocal – represented as an Authentication object.

In order to construct and set this Authentication object – we need to use the same approach Spring Security typically uses to build the object on a standard authentication.

To, let’s manually trigger authentication and then set the resulting Authentication object into the current SecurityContext used by the framework to hold the currently logged-in user:

UsernamePasswordAuthenticationToken authReq
 = new UsernamePasswordAuthenticationToken(user, pass);
Authentication auth = authManager.authenticate(authReq);
SecurityContext sc = SecurityContextHolder.getContext();
sc.setAuthentication(auth);

After setting the Authentication in the context, we’ll now be able to check if the current user is authenticated – using securityContext.getAuthentication().isAuthenticated().

3. Spring MVC

By default, Spring Security adds an additional filter in the Spring Security filter chain – which is capable of persisting the Security Context (SecurityContextPersistenceFilter class).

In turn, it delegates the persistence of the Security Context to an instance of SecurityContextRepository, defaulting to the HttpSessionSecurityContextRepository class.

So, in order to set the authentication on the request and hence, make it available for all subsequent requests from the client, we need to manually set the SecurityContext containing the Authentication in the HTTP session:

public void login(HttpServletRequest req, String user, String pass) { 
    UsernamePasswordAuthenticationToken authReq
      = new UsernamePasswordAuthenticationToken(user, pass);
    Authentication auth = authManager.authenticate(authReq);
    
    SecurityContext sc = SecurityContextHolder.getContext();
    sc.setAuthentication(auth);
    HttpSession session = req.getSession(true);
    session.setAttribute(SPRING_SECURITY_CONTEXT_KEY, sc);
}

SPRING_SECURITY_CONTEXT_KEY is a statically imported HttpSessionSecurityContextRepository.SPRING_SECURITY_CONTEXT_KEY.

It should be noted that we can’t directly use the HttpSessionSecurityContextRepository – because it works in conjunction with the SecurityContextPersistenceFilter.

That is because the filter uses the repository in order to load and store the security context before and after the execution of the rest of defined filters in the chain, but it uses a custom wrapper over the response which is passed to the chain.

So in this case, you should know the class type of the wrapper used and pass it to the appropriate save method in the repository.

4. Conclusion

In this quick tutorial, we went over how to manually set the user Authentication in the Spring Security context and how it can be made available for Spring MVC purposes, focusing on the code samples that illustrate the simplest way to achieve it.

As always, code samples can be found over on GitHub.

Related posts:

Tính đa hình (Polymorphism) trong Java
Java Program to Check whether Directed Graph is Connected using DFS
Java Program to Implement Min Hash
The Registration Process With Spring Security
Java Program to Convert a Decimal Number to Binary Number using Stacks
Spring Boot - Securing Web Applications
ClassNotFoundException vs NoClassDefFoundError
Converting String to Stream of chars
Java Program to Find Strongly Connected Components in Graphs
Java Program to Implement Max-Flow Min-Cut Theorem
Java Program to Implement Graph Structured Stack
Adding a Newline Character to a String in Java
Spring Security 5 – OAuth2 Login
Lớp Collections trong Java (Collections Utility Class)
Java Program to find the maximum subarray sum using Binary Search approach
HTTP Authentification and CGI/Servlet
Java Program to Check if a Point d lies Inside or Outside a Circle Defined by Points a, b, c in a Pl...
Java Program to Implement RenderingHints API
String Initialization in Java
Using a List of Values in a JdbcTemplate IN Clause
Chuyển đổi từ HashMap sang ArrayList
Java Program to Find Minimum Element in an Array using Linear Search
Spring Boot - Building RESTful Web Services
Java Program to implement Array Deque
Java Program to Implement Sorted List
Java Program to Find kth Largest Element in a Sequence
Guide To CompletableFuture
Java Program to Find the Peak Element of an Array O(n) time (Naive Method)
Spring Boot - Code Structure
Java Program to Compute Discrete Fourier Transform Using Naive Approach
Java Program to Check whether Graph is a Bipartite using BFS
Guide to the Java Queue Interface