Last active
February 26, 2025 03:12
-
-
Save unclebean/6cb0da70c5a87be276782656c91457f9 to your computer and use it in GitHub Desktop.
spring security
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import jakarta.servlet.FilterChain; | |
import jakarta.servlet.ServletException; | |
import jakarta.servlet.http.HttpServletRequest; | |
import jakarta.servlet.http.HttpServletResponse; | |
import org.springframework.security.core.context.SecurityContextHolder; | |
import org.springframework.security.core.userdetails.User; | |
import org.springframework.security.core.userdetails.UserDetails; | |
import org.springframework.security.web.authentication.UsernamePasswordAuthenticationToken; | |
import org.springframework.stereotype.Component; | |
import org.springframework.web.filter.OncePerRequestFilter; | |
import java.io.IOException; | |
@Component | |
public class JwtAuthenticationFilter extends OncePerRequestFilter { | |
private final JwtUtil jwtUtil; | |
public JwtAuthenticationFilter(JwtUtil jwtUtil) { | |
this.jwtUtil = jwtUtil; | |
} | |
@Override | |
protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) | |
throws ServletException, IOException { | |
String authHeader = request.getHeader("Authorization"); | |
if (authHeader == null || !authHeader.startsWith("Bearer ")) { | |
filterChain.doFilter(request, response); | |
return; | |
} | |
String token = authHeader.substring(7); | |
if (jwtUtil.validateToken(token)) { | |
String username = jwtUtil.extractUsername(token); | |
UserDetails userDetails = User.withUsername(username).password("").authorities("USER").build(); | |
UsernamePasswordAuthenticationToken authentication = | |
new UsernamePasswordAuthenticationToken(userDetails, null, userDetails.getAuthorities()); | |
SecurityContextHolder.getContext().setAuthentication(authentication); | |
} | |
filterChain.doFilter(request, response); | |
} | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import com.auth0.jwt.JWT; | |
import com.auth0.jwt.algorithms.Algorithm; | |
import com.auth0.jwt.interfaces.DecodedJWT; | |
import org.springframework.stereotype.Component; | |
import java.util.Date; | |
@Component | |
public class JwtUtil { | |
private static final String SECRET = "your-secret-key"; | |
public String generateToken(String username) { | |
return JWT.create() | |
.withSubject(username) | |
.withIssuedAt(new Date()) | |
.withExpiresAt(new Date(System.currentTimeMillis() + 86400000)) | |
.sign(Algorithm.HMAC256(SECRET)); | |
} | |
public boolean validateToken(String token) { | |
try { | |
JWT.require(Algorithm.HMAC256(SECRET)).build().verify(token); | |
return true; | |
} catch (Exception e) { | |
return false; | |
} | |
} | |
public String extractUsername(String token) { | |
DecodedJWT decodedJWT = JWT.require(Algorithm.HMAC256(SECRET)).build().verify(token); | |
return decodedJWT.getSubject(); | |
} | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import io.swagger.v3.oas.annotations.OpenAPIDefinition; | |
import io.swagger.v3.oas.annotations.enums.SecuritySchemeType; | |
import io.swagger.v3.oas.annotations.info.Info; | |
import io.swagger.v3.oas.annotations.security.SecurityRequirement; | |
import io.swagger.v3.oas.annotations.security.SecurityScheme; | |
import org.springframework.context.annotation.Configuration; | |
@Configuration | |
@OpenAPIDefinition( | |
info = @Info(title = "My API", version = "1.0", description = "API documentation with JWT"), | |
security = @SecurityRequirement(name = "bearerAuth") // Apply security globally | |
) | |
@SecurityScheme( | |
name = "bearerAuth", | |
scheme = "bearer", | |
type = SecuritySchemeType.HTTP, | |
bearerFormat = "JWT" | |
) | |
public class OpenAPIConfig { | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import org.springframework.context.annotation.Bean; | |
import org.springframework.context.annotation.Configuration; | |
import org.springframework.security.config.annotation.web.builders.HttpSecurity; | |
import org.springframework.security.config.http.SessionCreationPolicy; | |
import org.springframework.security.oauth2.server.resource.authentication.JwtAuthenticationConverter; | |
import org.springframework.security.web.SecurityFilterChain; | |
@Configuration | |
public class SecurityConfig { | |
@Bean | |
public SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception { | |
http | |
.csrf(csrf -> csrf.disable()) | |
.sessionManagement(session -> session.sessionCreationPolicy(SessionCreationPolicy.STATELESS)) | |
.authorizeHttpRequests(auth -> auth | |
.requestMatchers("/auth/**").permitAll() | |
.anyRequest().authenticated() | |
) | |
.oauth2ResourceServer(oauth2 -> oauth2.jwt(jwt -> jwt.jwtAuthenticationConverter(new JwtAuthenticationConverter()))); | |
return http.build(); | |
} | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import org.springframework.context.annotation.Bean; | |
import org.springframework.context.annotation.Configuration; | |
import org.springframework.security.config.annotation.web.builders.HttpSecurity; | |
import org.springframework.security.config.http.SessionCreationPolicy; | |
import org.springframework.security.oauth2.server.resource.authentication.JwtAuthenticationConverter; | |
import org.springframework.security.oauth2.server.resource.authentication.JwtGrantedAuthoritiesConverter; | |
@Configuration | |
public class SecurityConfig { | |
@Bean | |
public SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception { | |
http | |
.authorizeHttpRequests(auth -> auth | |
.anyRequest().authenticated() | |
) | |
.oauth2ResourceServer(oauth2 -> oauth2 | |
.jwt(jwtConfigurer -> jwtConfigurer.jwtAuthenticationConverter(jwtAuthenticationConverter())) | |
) | |
.sessionManagement(session -> session.sessionCreationPolicy(SessionCreationPolicy.STATELESS)); | |
return http.build(); | |
} | |
@Bean | |
public JwtAuthenticationConverter jwtAuthenticationConverter() { | |
JwtGrantedAuthoritiesConverter grantedAuthoritiesConverter = new JwtGrantedAuthoritiesConverter(); | |
grantedAuthoritiesConverter.setAuthorityPrefix("ROLE_"); | |
JwtAuthenticationConverter converter = new JwtAuthenticationConverter(); | |
converter.setJwtGrantedAuthoritiesConverter(grantedAuthoritiesConverter); | |
return converter; | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment