diff --git a/pom.xml b/pom.xml index 29884dc..8b4d3d8 100644 --- a/pom.xml +++ b/pom.xml @@ -163,12 +163,6 @@ 0.11.5 - - - - - - org.springframework.boot @@ -181,17 +175,17 @@ 2.11.1 - + - org.springdoc - springdoc-openapi-ui - 1.6.14 + io.springfox + springfox-swagger2 + 2.9.2 - org.webjars - swagger-ui - 4.15.5 + io.springfox + springfox-swagger-ui + 2.9.2 @@ -206,6 +200,21 @@ reactor-core 3.2.2.RELEASE + + + + org.mapstruct + mapstruct + 1.5.5.Final + + + + + org.mapstruct + mapstruct-processor + 1.5.5.Final + provided + @@ -249,32 +258,6 @@ - - org.apache.maven.plugins - maven-dependency-plugin - 3.6.0 - - - unpack - process-resources - - unpack - - - - - org.webjars - swagger-ui - 4.15.5 - jar - ${project.build.outputDirectory} - META-INF/resources/** - - - - - - org.apache.maven.plugins maven-source-plugin diff --git a/src/main/java/com/sczx/user/Application.java b/src/main/java/com/sczx/user/Application.java index 01e45ce..38ea2a9 100644 --- a/src/main/java/com/sczx/user/Application.java +++ b/src/main/java/com/sczx/user/Application.java @@ -29,6 +29,6 @@ public class Application { ConfigurableApplicationContext context = SpringApplication.run(Application.class, args); Environment environment = context.getBean(Environment.class); System.out.println("启动成功,后端服务API地址:http://" + ComputerInfo.getIpAddr() + ":" - + environment.getProperty("server.port") + "/doc.html"); + + environment.getProperty("server.port") + "/swagger-ui.html"); } } diff --git a/src/main/java/com/sczx/user/config/SpringDocConfig.java b/src/main/java/com/sczx/user/config/SpringDocConfig.java deleted file mode 100644 index 9428737..0000000 --- a/src/main/java/com/sczx/user/config/SpringDocConfig.java +++ /dev/null @@ -1,16 +0,0 @@ -package com.sczx.user.config; - - -import org.springdoc.core.GroupedOpenApi; -import org.springframework.context.annotation.Bean; - -//@Configuration -public class SpringDocConfig { - @Bean - public GroupedOpenApi publicApi() { - return GroupedOpenApi.builder() - .group("sczx-service") - .packagesToScan("com.sczx.app.controller") - .build(); - } -} diff --git a/src/main/java/com/sczx/user/config/SwaggerConfig.java b/src/main/java/com/sczx/user/config/SwaggerConfig.java new file mode 100644 index 0000000..564c725 --- /dev/null +++ b/src/main/java/com/sczx/user/config/SwaggerConfig.java @@ -0,0 +1,35 @@ +package com.sczx.user.config; + + + +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import springfox.documentation.builders.ApiInfoBuilder; +import springfox.documentation.builders.PathSelectors; +import springfox.documentation.builders.RequestHandlerSelectors; +import springfox.documentation.service.ApiInfo; +import springfox.documentation.spi.DocumentationType; +import springfox.documentation.spring.web.plugins.Docket; +import springfox.documentation.swagger2.annotations.EnableSwagger2; + +@Configuration +@EnableSwagger2 +public class SwaggerConfig { + @Bean + public Docket createRestApi() { + return new Docket(DocumentationType.SWAGGER_2) + .apiInfo(apiInfo()) + .select() + .apis(RequestHandlerSelectors.basePackage("com.sczx.user.controller")) // 修改为你的 controller 包路径 + .paths(PathSelectors.any()) + .build(); + } + + private ApiInfo apiInfo() { + return new ApiInfoBuilder() + .title("用户服务接口文档") + .description("sczx_user用户服务接口文档文档") + .version("1.0") + .build(); + } +} diff --git a/src/main/java/com/sczx/user/config/WebConfig.java b/src/main/java/com/sczx/user/config/WebConfig.java deleted file mode 100644 index 404a05d..0000000 --- a/src/main/java/com/sczx/user/config/WebConfig.java +++ /dev/null @@ -1,44 +0,0 @@ -package com.sczx.user.config; - -import org.springframework.context.annotation.Configuration; -import org.springframework.http.MediaType; -import org.springframework.http.converter.HttpMessageConverter; -import org.springframework.http.converter.StringHttpMessageConverter; -import org.springframework.http.converter.json.MappingJackson2HttpMessageConverter; -import org.springframework.web.servlet.config.annotation.EnableWebMvc; -import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry; -import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; - -import java.nio.charset.StandardCharsets; -import java.util.Collections; -import java.util.List; - -@Configuration -@EnableWebMvc -public class WebConfig implements WebMvcConfigurer { - - @Override - public void addResourceHandlers(ResourceHandlerRegistry registry) { - registry.addResourceHandler("/swagger-ui/**") - .addResourceLocations("classpath:/META-INF/resources/webjars/swagger-ui/4.15.5/"); - registry.addResourceHandler("/swagger-ui.html") - .addResourceLocations("classpath:/META-INF/resources/swagger-ui.html"); - registry.addResourceHandler("/v3/api-docs/**") - .addResourceLocations("classpath:/META-INF/resources/swagger-ui/"); - } - - @Override - public void configureMessageConverters(List> converters) { - - converters.add(new StringHttpMessageConverter(StandardCharsets.UTF_8)); - // 添加支持 application/json;charset=UTF-8 的 Jackson 转换器 - converters.add(new MappingJackson2HttpMessageConverter() { - @Override - public List getSupportedMediaTypes() { - return Collections.singletonList(MediaType.APPLICATION_JSON_UTF8); - } - }); - - - } -} diff --git a/src/main/java/com/sczx/user/controller/AuthController.java b/src/main/java/com/sczx/user/controller/AuthController.java index 91b9fdd..ade6cab 100644 --- a/src/main/java/com/sczx/user/controller/AuthController.java +++ b/src/main/java/com/sczx/user/controller/AuthController.java @@ -3,8 +3,10 @@ package com.sczx.user.controller; import com.sczx.user.model.LoginRequest; import com.sczx.user.service.IUserService; import com.sczx.user.util.JwtUtil; -import io.swagger.v3.oas.annotations.Operation; -import io.swagger.v3.oas.annotations.tags.Tag; +import io.swagger.annotations.Api; + +import io.swagger.annotations.ApiOperation; + import org.springframework.beans.factory.annotation.Autowired; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.PostMapping; @@ -12,7 +14,7 @@ import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; -@Tag(name = "登录控制器", description = "注册、登录") +@Api(value = "登录控制器", produces = "注册、登录") @RequestMapping("/auth") @RestController public class AuthController { @@ -22,13 +24,13 @@ public class AuthController { @Autowired private JwtUtil jwtUtil; - @Operation(summary = "注册", description = "用户注册") + @ApiOperation(value = "注册", notes = "用户注册",produces = "application/json") @PostMapping("/register") public ResponseEntity register(@RequestBody LoginRequest request) { return ResponseEntity.ok(userService.register(request)); } - @Operation(summary = "登录", description = "用户登录返回token") + @ApiOperation(value = "登录", notes = "用户登录返回token",produces = "application/json") @PostMapping("/login") public ResponseEntity login(@RequestBody LoginRequest request) { String token = userService.login(request); diff --git a/src/main/java/com/sczx/user/controller/DemoController.java b/src/main/java/com/sczx/user/controller/DemoController.java index b57d580..8f56a19 100644 --- a/src/main/java/com/sczx/user/controller/DemoController.java +++ b/src/main/java/com/sczx/user/controller/DemoController.java @@ -1,15 +1,15 @@ package com.sczx.user.controller; -import io.swagger.v3.oas.annotations.Operation; -import io.swagger.v3.oas.annotations.tags.Tag; +import io.swagger.annotations.Api; +import io.swagger.annotations.ApiOperation; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; @RestController -@Tag(name = "示例接口", description = "用于演示 Springdoc 的接口") +@Api(value = "示例接口", produces = "用于演示 Springdoc 的接口") public class DemoController { @GetMapping("/test") - @Operation(summary = "测试接口", description = "返回一个测试字符串") + @ApiOperation(value = "测试接口", notes = "返回一个测试字符串") public String test() { return "OK"; } diff --git a/src/main/java/com/sczx/user/model/LoginRequest.java b/src/main/java/com/sczx/user/model/LoginRequest.java index 1045ed3..ef45447 100644 --- a/src/main/java/com/sczx/user/model/LoginRequest.java +++ b/src/main/java/com/sczx/user/model/LoginRequest.java @@ -1,7 +1,8 @@ package com.sczx.user.model; -import io.swagger.v3.oas.annotations.media.Schema; -import io.swagger.v3.oas.annotations.tags.Tag; + +import io.swagger.annotations.ApiModel; +import io.swagger.annotations.ApiModelProperty; import lombok.Data; /** @@ -9,15 +10,15 @@ import lombok.Data; * @Date: 2025/07/06/13:41 * @Description: */ -@Schema(description = "用户注册请求") +@ApiModel(value = "用户注册请求") @Data public class LoginRequest { - @Schema(description = "用户名") + @ApiModelProperty(value = "用户名") private String username; - @Schema(description = "密码") + @ApiModelProperty(value = "密码") private String password; - @Schema(description = "微信登录 code") + @ApiModelProperty(value = "微信登录 code") private String wechatCode; // 微信登录 code - @Schema(description = "支付宝 user_id") + @ApiModelProperty(value = "支付宝 user_id") private String alipayUserId; // 支付宝 user_id } \ No newline at end of file diff --git a/src/main/java/com/sczx/user/model/LoginResponse.java b/src/main/java/com/sczx/user/model/LoginResponse.java index 648594d..a774b6d 100644 --- a/src/main/java/com/sczx/user/model/LoginResponse.java +++ b/src/main/java/com/sczx/user/model/LoginResponse.java @@ -1,6 +1,8 @@ package com.sczx.user.model; -import io.swagger.v3.oas.annotations.media.Schema; + +import io.swagger.annotations.ApiModel; +import io.swagger.annotations.ApiModelProperty; import lombok.Data; /** @@ -9,13 +11,13 @@ import lombok.Data; * @Description: */ -@Schema(description = "登录返回") +@ApiModel(value = "登录返回") @Data public class LoginResponse { - @Schema(description = "登录的token") + @ApiModelProperty(value = "登录的token") private String token; - @Schema(description = "登录的refreshToken") + @ApiModelProperty(value = "登录的refreshToken") private String refreshToken; - @Schema(description = "登录用户的角色") + @ApiModelProperty(value = "登录用户的角色") private String role; } \ No newline at end of file diff --git a/src/main/java/com/sczx/user/util/JwtUtil.java b/src/main/java/com/sczx/user/util/JwtUtil.java index 5058bbb..2db4e26 100644 --- a/src/main/java/com/sczx/user/util/JwtUtil.java +++ b/src/main/java/com/sczx/user/util/JwtUtil.java @@ -4,7 +4,10 @@ import io.jsonwebtoken.JwtException; import io.jsonwebtoken.Jwts; import io.jsonwebtoken.SignatureAlgorithm; import io.jsonwebtoken.security.Keys; -import lombok.extern.slf4j.Slf4j; + + +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Component; @@ -16,9 +19,10 @@ import java.util.Date; * @Date: 2025/07/06/14:00 * @Description: */ -@Slf4j +//@Slf4j @Component public class JwtUtil { + private static final Logger log = LoggerFactory.getLogger(JwtUtil.class); @Value("${auth.token-expiration}") private long expiration; diff --git a/src/main/resources/application.yml b/src/main/resources/application.yml index 7d8a02a..72df045 100644 --- a/src/main/resources/application.yml +++ b/src/main/resources/application.yml @@ -23,11 +23,6 @@ spring: # version: 1.0.0 # env: dev - jpa: - hibernate: - ddl-auto: update - show-sql: true - database-platform: org.hibernate.dialect.MySQL5InnoDBDialect lifecycle: timeout-per-shutdown-phase: 30s # 设置优雅停机时间 @@ -58,15 +53,9 @@ hystrix: thread: timeoutInMilliseconds: 10000 # 默认熔断超时时间 -springdoc: - swagger-ui: - url: /v3/api-docs - path: /doc.html - packages-to-scan: com.sczx.user.controller # 替换为你的 controller 包路径 - mybatis-plus: mapper-locations: classpath*:mapper/**/*.xml - type-aliases-package: com.sczx.user.entity # 实体类包路径 + type-aliases-package: com.sczx.user.po # 实体类包路径 configuration: mapUnderscoreToCamelCase: true log-impl: org.apache.ibatis.logging.stdout.StdOutImpl # 控制台打印 SQL(调试用) diff --git a/src/test/java/com/sczx/user/CodeGenerator.java b/src/test/java/com/sczx/user/CodeGenerator.java new file mode 100644 index 0000000..16994ad --- /dev/null +++ b/src/test/java/com/sczx/user/CodeGenerator.java @@ -0,0 +1,41 @@ +package com.sczx.user; + +import com.baomidou.mybatisplus.generator.FastAutoGenerator; +import com.baomidou.mybatisplus.generator.config.DataSourceConfig; +import com.baomidou.mybatisplus.generator.config.OutputFile; +import com.baomidou.mybatisplus.generator.config.rules.DateType; +import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine; + +import java.util.Collections; + +public class CodeGenerator { + + private static final String parentPackage = "com.sczx.store"; + private static final String jdbcUrl = "jdbc:mysql://115.190.8.52:3306/sczx?useUnicode=true&characterEncoding=UTF-8&allowPublicKeyRetrieval=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&useSSL=false&serverTimezone=Asia/Shanghai"; + private static final String username = "sczx_user"; + private static final String password = "Sczx123@"; + private static final String author = "zhangli"; + public static void main(String[] args) { + DataSourceConfig.Builder DATA_SOURCE_CONFIG = new DataSourceConfig.Builder(jdbcUrl, username, password); + + FastAutoGenerator.create(DATA_SOURCE_CONFIG) + // 全局配置 + .globalConfig(builder -> builder.outputDir(System.getProperty("user.dir") + "/src/main/java") + .author(author).disableOpenDir().enableSwagger() + .dateType(DateType.TIME_PACK).commentDate("yyyy-MM-dd HH:mm:ss") + .fileOverride()) + // 包配置 + .packageConfig(builder -> builder.parent(parentPackage).entity("po.base").service("repository.base").serviceImpl("repository.impl.base").xml("") + .mapper("mapper.base").pathInfo(Collections.singletonMap(OutputFile.mapperXml, System.getProperty("user.dir") + "/src/main/resources/mapper/base"))) + + // 策略配置 + .strategyConfig((scanner, builder) -> builder.addInclude(scanner.apply("请输入表名:")) + .addTablePrefix("zc_"/*,"zd_"*/)//可支持多个,按逗号分隔 + .entityBuilder().formatFileName("%sPO").enableLombok() + .mapperBuilder().formatMapperFileName("%sMapper").formatXmlFileName("%sMapper") + .controllerBuilder().formatFileName("%sController").enableRestStyle() + .serviceBuilder().formatServiceFileName("%sRepo").formatServiceImplFileName("%sRepoImpl")) + .templateEngine(new FreemarkerTemplateEngine()) + .execute(); + } +}