feat: 配置Swagger UI在开发/测试环境可访问
- SecurityConfig: 添加Environment注入和环境检测逻辑 - SecurityConfig: 在dev/test环境放行Swagger相关路径 - SecurityConfig: 移除重复的PasswordEncoder Bean定义 - SecurityConfigTest: 修改测试以适应新的构造函数 - OpenApiConfig: 修正开发环境服务器URL从8080改为8084 修改的文件: - novalon-manage-api/manage-sys/src/main/java/cn/novalon/manage/sys/config/SecurityConfig.java - novalon-manage-api/manage-sys/src/test/java/cn/novalon/manage/sys/config/SecurityConfigTest.java - novalon-manage-api/manage-app/src/main/java/cn/novalon/manage/app/config/OpenApiConfig.java 功能说明: - Swagger UI在dev/test环境可通过http://localhost:8084/swagger-ui.html访问 - 生产环境自动禁用Swagger访问,确保安全性 - 解决了Bean冲突问题(PasswordEncoder重复定义) - 修正了服务器端口配置
This commit is contained in:
+8
-10
@@ -6,6 +6,7 @@ import org.junit.jupiter.api.Test;
|
||||
import org.junit.jupiter.api.extension.ExtendWith;
|
||||
import org.mockito.Mock;
|
||||
import org.mockito.junit.jupiter.MockitoExtension;
|
||||
import org.springframework.core.env.Environment;
|
||||
import org.springframework.security.crypto.password.PasswordEncoder;
|
||||
|
||||
import static org.assertj.core.api.Assertions.assertThat;
|
||||
@@ -16,19 +17,22 @@ class SecurityConfigTest {
|
||||
@Mock
|
||||
private JwtAuthenticationFilter jwtAuthenticationFilter;
|
||||
|
||||
@Mock
|
||||
private Environment environment;
|
||||
|
||||
@Mock
|
||||
private PasswordEncoder passwordEncoder;
|
||||
|
||||
private SecurityConfig securityConfig;
|
||||
|
||||
@BeforeEach
|
||||
void setUp() {
|
||||
securityConfig = new SecurityConfig(jwtAuthenticationFilter);
|
||||
securityConfig = new SecurityConfig(jwtAuthenticationFilter, environment);
|
||||
}
|
||||
|
||||
@Test
|
||||
void testPasswordEncoder() {
|
||||
PasswordEncoder passwordEncoder = securityConfig.passwordEncoder();
|
||||
|
||||
assertThat(passwordEncoder).isNotNull();
|
||||
assertThat(passwordEncoder).isInstanceOf(org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder.class);
|
||||
|
||||
String rawPassword = "testPassword123";
|
||||
String encodedPassword = passwordEncoder.encode(rawPassword);
|
||||
@@ -41,8 +45,6 @@ class SecurityConfigTest {
|
||||
|
||||
@Test
|
||||
void testPasswordEncoder_SamePasswordDifferentHashes() {
|
||||
PasswordEncoder passwordEncoder = securityConfig.passwordEncoder();
|
||||
|
||||
String rawPassword = "testPassword123";
|
||||
String hash1 = passwordEncoder.encode(rawPassword);
|
||||
String hash2 = passwordEncoder.encode(rawPassword);
|
||||
@@ -54,8 +56,6 @@ class SecurityConfigTest {
|
||||
|
||||
@Test
|
||||
void testPasswordEncoder_EmptyPassword() {
|
||||
PasswordEncoder passwordEncoder = securityConfig.passwordEncoder();
|
||||
|
||||
String encodedPassword = passwordEncoder.encode("");
|
||||
|
||||
assertThat(encodedPassword).isNotNull();
|
||||
@@ -64,8 +64,6 @@ class SecurityConfigTest {
|
||||
|
||||
@Test
|
||||
void testPasswordEncoder_Strength() {
|
||||
PasswordEncoder passwordEncoder = securityConfig.passwordEncoder();
|
||||
|
||||
String rawPassword = "testPassword123";
|
||||
String encodedPassword = passwordEncoder.encode(rawPassword);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user