Преглед на файлове

feat: 添加redis相关配置与依赖

yangliu преди 3 месеца
родител
ревизия
da8e53011a
променени са 47 файла, в които са добавени 7950 реда и са изтрити 6 реда
  1. 0 5
      hfln-framework-common/pom.xml
  2. 119 0
      hfln-framework-design-starter/knife4j-doc-spring-boot-starter/src/main/resources/application-gateway.yml
  3. 182 0
      hfln-framework-design-starter/knife4j-doc-spring-boot-starter/src/test/java/cn/hfln/framework/knife4j/doc/ServersFieldTest.java
  4. 192 0
      hfln-framework-design-starter/knife4j-doc-spring-boot-starter/src/test/java/cn/hfln/framework/knife4j/doc/SimpleServersTest.java
  5. 274 0
      hfln-framework-design-starter/mqtt-spring-boot-starter/src/test/java/cn/hfln/framework/mqtt/integration/ConfigurationCompatibilityTest.java
  6. 337 0
      hfln-framework-design-starter/mqtt-spring-boot-starter/src/test/java/cn/hfln/framework/mqtt/integration/ExternalApplicationSimulationTest.java
  7. 261 0
      hfln-framework-design-starter/mqtt-spring-boot-starter/src/test/java/cn/hfln/framework/mqtt/integration/ExternalEnvironmentIntegrationTest.java
  8. 59 0
      hfln-framework-design-starter/mqtt-spring-boot-starter/src/test/java/cn/hfln/framework/mqtt/integration/StarterIntegrationTestSuite.java
  9. 14 0
      hfln-framework-design-starter/mqtt-spring-boot-starter/src/test/resources/application-dev.yml
  10. 8 0
      hfln-framework-design-starter/mqtt-spring-boot-starter/src/test/resources/application-no-mqtt.yml
  11. 380 0
      hfln-framework-design-starter/mqtt-spring-boot-starter/src/test/resources/外部应用示例配置.md
  12. 222 0
      hfln-framework-design-starter/mqtt-spring-boot-starter/src/test/resources/完整外部应用示例.md
  13. 1 1
      hfln-framework-design-starter/pom.xml
  14. 60 0
      hfln-framework-design-starter/redis-spring-boot-starter/pom.xml
  15. 25 0
      hfln-framework-design-starter/redis-spring-boot-starter/src/main/java/cn/hfln/framework/redis/autoconfigure/AutoRedisConfiguration.java
  16. 28 0
      hfln-framework-design-starter/redis-spring-boot-starter/src/main/java/cn/hfln/framework/redis/properties/RedisProperties.java
  17. 114 0
      hfln-framework-design-starter/redis-spring-boot-starter/src/main/java/cn/hfln/framework/redis/util/RedisUtil.java
  18. 2 0
      hfln-framework-design-starter/redis-spring-boot-starter/src/main/resources/META-INF/spring.factories
  19. 8 0
      hfln-framework-design-starter/redis-spring-boot-starter/src/test/java/cn/hfln/framework/redis/RedisTestApplication.java
  20. 23 0
      hfln-framework-design-starter/redis-spring-boot-starter/src/test/java/cn/hfln/framework/redis/RedisUtilIntegrationTest.java
  21. 4 0
      hfln-framework-design-starter/redis-spring-boot-starter/src/test/resources/application.yml
  22. 33 0
      temp_knife4j/deploy.ps1
  23. 616 0
      temp_knife4j/lib/classgraph-4.8.149.pom
  24. 1008 0
      temp_knife4j/lib/commons-lang3-3.12.0.pom
  25. 173 0
      temp_knife4j/lib/jackson-annotations-2.14.0.pom
  26. 148 0
      temp_knife4j/lib/jackson-core-2.13.3.pom
  27. 434 0
      temp_knife4j/lib/jackson-databind-2.14.0.pom
  28. 66 0
      temp_knife4j/lib/jackson-dataformat-yaml-2.14.0.pom
  29. 123 0
      temp_knife4j/lib/jackson-datatype-jsr310-2.14.0.pom
  30. 111 0
      temp_knife4j/lib/jakarta.activation-api-1.2.1.pom
  31. 283 0
      temp_knife4j/lib/jakarta.validation-api-2.0.2.pom
  32. 341 0
      temp_knife4j/lib/jakarta.xml.bind-api-2.3.2.pom
  33. 49 0
      temp_knife4j/lib/knife4j-core-4.1.0.pom
  34. 84 0
      temp_knife4j/lib/knife4j-openapi3-spring-boot-starter-4.1.0.pom
  35. 31 0
      temp_knife4j/lib/knife4j-openapi3-ui-4.1.0.pom
  36. 120 0
      temp_knife4j/lib/slf4j-api-1.7.28.pom
  37. 825 0
      temp_knife4j/lib/snakeyaml-1.33.pom
  38. 62 0
      temp_knife4j/lib/springdoc-openapi-common-1.6.15.pom
  39. 67 0
      temp_knife4j/lib/springdoc-openapi-ui-1.6.15.pom
  40. 59 0
      temp_knife4j/lib/springdoc-openapi-webflux-core-1.6.15.pom
  41. 74 0
      temp_knife4j/lib/springdoc-openapi-webmvc-core-1.6.15.pom
  42. 119 0
      temp_knife4j/lib/swagger-annotations-2.2.8.pom
  43. 175 0
      temp_knife4j/lib/swagger-core-2.2.8.pom
  44. 103 0
      temp_knife4j/lib/swagger-models-2.2.8.pom
  45. 154 0
      temp_knife4j/lib/swagger-ui-4.17.1.pom
  46. 349 0
      temp_knife4j/lib/webjars-locator-core-0.52.pom
  47. 30 0
      temp_knife4j/pom.xml

+ 0 - 5
hfln-framework-common/pom.xml

@@ -68,11 +68,6 @@
 			<artifactId>javax.servlet-api</artifactId>
 		</dependency>
 
-		<!-- Apache Lang3 -->
-		<dependency>
-			<groupId>org.apache.commons</groupId>
-			<artifactId>commons-lang3</artifactId>
-		</dependency>
 		<!-- Transmittable ThreadLocal -->
 		<dependency>
 			<groupId>com.alibaba</groupId>

+ 119 - 0
hfln-framework-design-starter/knife4j-doc-spring-boot-starter/src/main/resources/application-gateway.yml

@@ -0,0 +1,119 @@
+# Knife4j 网关配置示例
+lnxx:
+  knife4j:
+    doc:
+      # 基础配置
+      enable: false  # 禁用普通模式
+      title: "微服务 API 文档聚合"
+      description: "统一管理所有微服务的 API 文档"
+      version: "1.0.0"
+      
+      # 网关配置
+      gateway:
+        enable: true  # 启用网关模式
+        services:
+          # 用户服务
+          - name: "用户服务"
+            url: "/v3/api-docs"  # 注意:不需要服务名称前缀
+            description: "用户注册、登录、权限管理等相关接口"
+          
+          # 订单服务
+          - name: "订单服务"
+            url: "/v3/api-docs"  # 注意:不需要服务名称前缀
+            description: "订单创建、查询、状态管理等相关接口"
+          
+          # 商品服务
+          - name: "商品服务"
+            url: "/v3/api-docs"  # 注意:不需要服务名称前缀
+            description: "商品信息、库存、分类管理等相关接口"
+          
+          # 支付服务
+          - name: "支付服务"
+            url: "/v3/api-docs"  # 注意:不需要服务名称前缀
+            description: "支付处理、退款、对账等相关接口"
+          
+          # 通知服务
+          - name: "通知服务"
+            url: "/v3/api-docs"  # 注意:不需要服务名称前缀
+            description: "短信、邮件、推送通知等相关接口"
+          
+          # 文件服务
+          - name: "文件服务"
+            url: "/v3/api-docs"  # 注意:不需要服务名称前缀
+            description: "文件上传、下载、管理等相关接口"
+          
+          # 日志服务
+          - name: "日志服务"
+            url: "/v3/api-docs"  # 注意:不需要服务名称前缀
+            description: "系统日志、操作日志等相关接口"
+
+# Spring Boot 配置
+spring:
+  application:
+    name: gateway-service
+  
+  # 网关路由配置
+  cloud:
+    gateway:
+      routes:
+        # 用户服务路由
+        - id: user-service
+          uri: lb://user-service
+          predicates:
+            - Path=/user-service/**
+          filters:
+            - StripPrefix=1  # 移除路径前缀
+        
+        # 订单服务路由
+        - id: order-service
+          uri: lb://order-service
+          predicates:
+            - Path=/order-service/**
+          filters:
+            - StripPrefix=1  # 移除路径前缀
+        
+        # 商品服务路由
+        - id: product-service
+          uri: lb://product-service
+          predicates:
+            - Path=/product-service/**
+          filters:
+            - StripPrefix=1  # 移除路径前缀
+        
+        # 支付服务路由
+        - id: payment-service
+          uri: lb://payment-service
+          predicates:
+            - Path=/payment-service/**
+          filters:
+            - StripPrefix=1  # 移除路径前缀
+        
+        # 通知服务路由
+        - id: notification-service
+          uri: lb://notification-service
+          predicates:
+            - Path=/notification-service/**
+          filters:
+            - StripPrefix=1  # 移除路径前缀
+        
+        # 文件服务路由
+        - id: file-service
+          uri: lb://file-service
+          predicates:
+            - Path=/file-service/**
+          filters:
+            - StripPrefix=1  # 移除路径前缀
+        
+        # 日志服务路由
+        - id: log-service
+          uri: lb://log-service
+          predicates:
+            - Path=/log-service/**
+          filters:
+            - StripPrefix=1  # 移除路径前缀
+
+# 服务器配置
+server:
+  port: 8080
+  servlet:
+    context-path: / 

+ 182 - 0
hfln-framework-design-starter/knife4j-doc-spring-boot-starter/src/test/java/cn/hfln/framework/knife4j/doc/ServersFieldTest.java

@@ -0,0 +1,182 @@
+package cn.hfln.framework.knife4j.doc;
+
+import cn.hfln.framework.knife4j.doc.base.SwaggerProperties;
+import cn.hfln.framework.knife4j.doc.configure.DocAutoConfigure;
+import cn.hfln.framework.knife4j.doc.properties.DocProperties;
+import io.swagger.v3.oas.models.OpenAPI;
+
+import java.util.Arrays;
+
+/**
+ * Servers 字段测试
+ * 验证 yml 配置是否正确传递到 OpenAPI 文档
+ */
+public class ServersFieldTest {
+
+    public static void main(String[] args) {
+        System.out.println("=== 开始 Knife4j Servers 字段测试 ===");
+        
+        try {
+            testServersConfiguration();
+            testSingleServerUrl();
+            testRealWorldScenario();
+            
+            System.out.println("\n=== 所有测试通过!===");
+            System.out.println("结论:starter 正确处理了 servers 字段配置");
+            
+        } catch (Exception e) {
+            System.err.println("\n=== 测试失败 ===");
+            e.printStackTrace();
+        }
+    }
+
+    /**
+     * 测试 servers 字段配置
+     */
+    private static void testServersConfiguration() {
+        System.out.println("\n============================================================");
+        System.out.println("测试1:servers 字段配置");
+        System.out.println("============================================================");
+        
+        // 创建配置
+        DocProperties properties = createBaseProperties();
+        
+        // 设置 servers 配置(模拟 yml 配置)
+        DocProperties.ServerConfig server = new DocProperties.ServerConfig();
+        server.setUrl("/portal-service-server");
+        server.setDescription("门户服务前缀");
+        properties.setServers(Arrays.asList(server));
+        
+        // 创建 DocAutoConfigure
+        DocAutoConfigure configure = new DocAutoConfigure(properties);
+        
+        // 验证 SwaggerProperties
+        SwaggerProperties swaggerProps = configure.swaggerProperties();
+        System.out.println("SwaggerProperties.servers: " + 
+            (swaggerProps.getServers() != null ? swaggerProps.getServers().size() + " 个" : "null"));
+        
+        if (swaggerProps.getServers() != null && !swaggerProps.getServers().isEmpty()) {
+            SwaggerProperties.ServerConfig sc = swaggerProps.getServers().get(0);
+            System.out.println("  [0] url: " + sc.getUrl() + ", description: " + sc.getDescription());
+        }
+        
+        // 验证 OpenAPI
+        OpenAPI openAPI = configure.customOpenAPI();
+        System.out.println("OpenAPI.servers: " + 
+            (openAPI.getServers() != null ? openAPI.getServers().size() + " 个" : "null"));
+        
+        if (openAPI.getServers() != null && !openAPI.getServers().isEmpty()) {
+            openAPI.getServers().forEach(s -> 
+                System.out.println("  server: " + s.getUrl() + " - " + s.getDescription()));
+        }
+        
+        // 断言验证
+        assert swaggerProps.getServers() != null : "SwaggerProperties.servers 不应为 null";
+        assert swaggerProps.getServers().size() == 1 : "应该有 1 个 server";
+        assert "/portal-service-server".equals(swaggerProps.getServers().get(0).getUrl()) : "server url 不匹配";
+        
+        assert openAPI.getServers() != null : "OpenAPI.servers 不应为 null";
+        assert openAPI.getServers().size() == 1 : "OpenAPI 应该有 1 个 server";
+        assert "/portal-service-server".equals(openAPI.getServers().get(0).getUrl()) : "OpenAPI server url 不匹配";
+        
+        System.out.println("✅ servers 字段配置测试通过");
+    }
+
+    /**
+     * 测试单个 serverUrl 配置
+     */
+    private static void testSingleServerUrl() {
+        System.out.println("\n============================================================");
+        System.out.println("测试2:单个 serverUrl 配置");
+        System.out.println("============================================================");
+        
+        DocProperties properties = createBaseProperties();
+        properties.setServerUrl("/portal-service-server");
+        properties.setServers(null);
+        
+        DocAutoConfigure configure = new DocAutoConfigure(properties);
+        OpenAPI openAPI = configure.customOpenAPI();
+        
+        System.out.println("serverUrl 设置: " + properties.getServerUrl());
+        System.out.println("OpenAPI.servers: " + 
+            (openAPI.getServers() != null ? openAPI.getServers().size() + " 个" : "null"));
+        
+        if (openAPI.getServers() != null && !openAPI.getServers().isEmpty()) {
+            System.out.println("  server: " + openAPI.getServers().get(0).getUrl());
+        }
+        
+        // 断言验证
+        assert openAPI.getServers() != null : "OpenAPI.servers 不应为 null";
+        assert openAPI.getServers().size() == 1 : "应该有 1 个 server";
+        assert "/portal-service-server".equals(openAPI.getServers().get(0).getUrl()) : "server url 不匹配";
+        
+        System.out.println("✅ 单个 serverUrl 配置测试通过");
+    }
+
+    /**
+     * 测试实际场景
+     */
+    private static void testRealWorldScenario() {
+        System.out.println("\n============================================================");
+        System.out.println("测试3:实际场景模拟");
+        System.out.println("============================================================");
+        
+        // 模拟实际的 yml 配置
+        DocProperties properties = createBaseProperties();
+        properties.setTitle("PORTAL-SERVICE-SERVER");
+        properties.setDescription("门户服务");
+        
+        DocProperties.ServerConfig server = new DocProperties.ServerConfig();
+        server.setUrl("/portal-service-server");
+        server.setDescription("服务前缀(与网关路由一致)");
+        properties.setServers(Arrays.asList(server));
+        
+        DocAutoConfigure configure = new DocAutoConfigure(properties);
+        OpenAPI openAPI = configure.customOpenAPI();
+        
+        System.out.println("=== 模拟访问 /v3/api-docs 返回的内容 ===");
+        System.out.println("标题: " + openAPI.getInfo().getTitle());
+        System.out.println("描述: " + openAPI.getInfo().getDescription());
+        System.out.println("servers:");
+        
+        if (openAPI.getServers() != null) {
+            openAPI.getServers().forEach(s -> 
+                System.out.println("  - url: " + s.getUrl() + ", description: " + s.getDescription()));
+        }
+        
+        System.out.println("\n=== UI 应该如何处理 ===");
+        System.out.println("当 UI 调试接口 /wap/user/wx/logout 时:");
+        System.out.println("应该请求: " + openAPI.getServers().get(0).getUrl() + "/wap/user/wx/logout");
+        System.out.println("即: /portal-service-server/wap/user/wx/logout");
+        
+        System.out.println("\n=== 如果 UI 不带前缀的原因分析 ===");
+        System.out.println("1. OpenAPI 文档的 servers 字段:✅ 已正确设置");
+        System.out.println("2. starter 代码处理:✅ 正确传递了配置");
+        System.out.println("3. 可能的问题:");
+        System.out.println("   - Knife4j UI 版本过低,不支持 OpenAPI 3.0 servers 字段");
+        System.out.println("   - 浏览器缓存了旧的 swagger-config");
+        System.out.println("   - springdoc 配置覆盖了 servers 字段");
+        
+        // 验证
+        assert openAPI.getServers() != null && !openAPI.getServers().isEmpty() : "servers 字段必须存在";
+        assert "/portal-service-server".equals(openAPI.getServers().get(0).getUrl()) : "servers url 必须正确";
+        
+        System.out.println("✅ 实际场景模拟测试通过");
+    }
+
+    /**
+     * 创建基础配置
+     */
+    private static DocProperties createBaseProperties() {
+        DocProperties properties = new DocProperties();
+        properties.setEnable(true);
+        properties.setTitle("测试服务API");
+        properties.setDescription("用于测试的API文档");
+        properties.setVersion("1.0.0");
+        properties.setBasePackage("cn.hfln.test");
+        properties.setName("测试团队");
+        properties.setUrl("https://test.hfln.cn");
+        properties.setEmail("test@hfln.cn");
+        return properties;
+    }
+} 

+ 192 - 0
hfln-framework-design-starter/knife4j-doc-spring-boot-starter/src/test/java/cn/hfln/framework/knife4j/doc/SimpleServersTest.java

@@ -0,0 +1,192 @@
+package cn.hfln.framework.knife4j.doc;
+
+import cn.hfln.framework.knife4j.doc.properties.DocProperties;
+import cn.hfln.framework.knife4j.doc.base.SwaggerProperties;
+
+import java.util.Arrays;
+
+/**
+ * 简化的 Servers 字段测试
+ * 不依赖外部库,专门验证 servers 字段转换逻辑
+ */
+public class SimpleServersTest {
+
+    public static void main(String[] args) {
+        System.out.println("=== 开始 Servers 字段转换测试 ===");
+        
+        try {
+            testServersConversion();
+            testSingleServerUrl();
+            testPriorityLogic();
+            
+            System.out.println("\n=== 所有测试通过!===");
+            System.out.println("结论:servers 字段转换逻辑正常,问题可能在 UI 或其他环节");
+            
+        } catch (Exception e) {
+            System.err.println("\n=== 测试失败 ===");
+            e.printStackTrace();
+        }
+    }
+
+    /**
+     * 测试 servers 字段转换
+     */
+    private static void testServersConversion() {
+        System.out.println("\n============================================================");
+        System.out.println("测试1:DocProperties.ServerConfig -> SwaggerProperties.ServerConfig 转换");
+        System.out.println("============================================================");
+        
+        // 创建 DocProperties 配置
+        DocProperties docProps = new DocProperties();
+        
+        DocProperties.ServerConfig server1 = new DocProperties.ServerConfig();
+        server1.setUrl("/portal-service-server");
+        server1.setDescription("门户服务前缀");
+        
+        DocProperties.ServerConfig server2 = new DocProperties.ServerConfig();
+        server2.setUrl("/user-service-server");
+        server2.setDescription("用户服务前缀");
+        
+        docProps.setServers(Arrays.asList(server1, server2));
+        
+        System.out.println("输入 DocProperties.servers:");
+        for (int i = 0; i < docProps.getServers().size(); i++) {
+            DocProperties.ServerConfig s = docProps.getServers().get(i);
+            System.out.println("  [" + i + "] url: " + s.getUrl() + ", desc: " + s.getDescription());
+        }
+        
+        // 模拟 DocAutoConfigure 中的转换逻辑
+        SwaggerProperties.SwaggerPropertiesBuilder builder = SwaggerProperties.builder()
+                .title("测试服务")
+                .version("1.0.0");
+        
+        if (docProps.getServers() != null && !docProps.getServers().isEmpty()) {
+            System.out.println("\n正在转换 servers 字段...");
+            java.util.List<SwaggerProperties.ServerConfig> convertedServers = docProps.getServers().stream()
+                    .map(s -> {
+                        SwaggerProperties.ServerConfig sc = new SwaggerProperties.ServerConfig();
+                        sc.setUrl(s.getUrl());
+                        sc.setDescription(s.getDescription());
+                        System.out.println("  转换: " + s.getUrl() + " -> " + sc.getUrl());
+                        return sc;
+                    })
+                    .collect(java.util.stream.Collectors.toList());
+            builder.servers(convertedServers);
+        }
+        
+        SwaggerProperties swaggerProps = builder.build();
+        
+        System.out.println("\n输出 SwaggerProperties.servers:");
+        if (swaggerProps.getServers() != null) {
+            for (int i = 0; i < swaggerProps.getServers().size(); i++) {
+                SwaggerProperties.ServerConfig s = swaggerProps.getServers().get(i);
+                System.out.println("  [" + i + "] url: " + s.getUrl() + ", desc: " + s.getDescription());
+            }
+        }
+        
+        // 验证
+        assert swaggerProps.getServers() != null : "转换后 servers 不应为 null";
+        assert swaggerProps.getServers().size() == 2 : "应该有 2 个 server";
+        assert "/portal-service-server".equals(swaggerProps.getServers().get(0).getUrl()) : "第一个 server url 不匹配";
+        assert "/user-service-server".equals(swaggerProps.getServers().get(1).getUrl()) : "第二个 server url 不匹配";
+        
+        System.out.println("✅ servers 字段转换测试通过");
+    }
+
+    /**
+     * 测试单个 serverUrl
+     */
+    private static void testSingleServerUrl() {
+        System.out.println("\n============================================================");
+        System.out.println("测试2:单个 serverUrl 处理");
+        System.out.println("============================================================");
+        
+        DocProperties docProps = new DocProperties();
+        docProps.setServerUrl("/portal-service-server");
+        docProps.setServers(null); // 确保 servers 为空
+        
+        System.out.println("输入:");
+        System.out.println("  serverUrl: " + docProps.getServerUrl());
+        System.out.println("  servers: " + docProps.getServers());
+        
+        // 模拟转换逻辑
+        SwaggerProperties.SwaggerPropertiesBuilder builder = SwaggerProperties.builder()
+                .title("测试服务")
+                .version("1.0.0")
+                .serverUrl(docProps.getServerUrl());
+        
+        if (docProps.getServers() != null && !docProps.getServers().isEmpty()) {
+            // 这里不会执行,因为 servers 为 null
+            System.out.println("使用 servers 字段");
+        } else {
+            System.out.println("使用 serverUrl 字段: " + docProps.getServerUrl());
+            builder.servers(null);
+        }
+        
+        SwaggerProperties swaggerProps = builder.build();
+        
+        System.out.println("\n输出 SwaggerProperties:");
+        System.out.println("  serverUrl: " + swaggerProps.getServerUrl());
+        System.out.println("  servers: " + swaggerProps.getServers());
+        
+        // 验证
+        assert "/portal-service-server".equals(swaggerProps.getServerUrl()) : "serverUrl 不匹配";
+        assert swaggerProps.getServers() == null : "servers 应该为 null";
+        
+        System.out.println("✅ 单个 serverUrl 处理测试通过");
+    }
+
+    /**
+     * 测试优先级逻辑
+     */
+    private static void testPriorityLogic() {
+        System.out.println("\n============================================================");
+        System.out.println("测试3:servers 优先于 serverUrl 的逻辑");
+        System.out.println("============================================================");
+        
+        DocProperties docProps = new DocProperties();
+        docProps.setServerUrl("/should-be-ignored"); // 应该被忽略
+        
+        DocProperties.ServerConfig server = new DocProperties.ServerConfig();
+        server.setUrl("/portal-service-server");
+        server.setDescription("来自 servers 配置");
+        docProps.setServers(Arrays.asList(server));
+        
+        System.out.println("输入:");
+        System.out.println("  serverUrl: " + docProps.getServerUrl() + " (应该被忽略)");
+        System.out.println("  servers[0]: " + docProps.getServers().get(0).getUrl());
+        
+        // 模拟优先级逻辑
+        SwaggerProperties.SwaggerPropertiesBuilder builder = SwaggerProperties.builder()
+                .title("测试服务")
+                .version("1.0.0")
+                .serverUrl(docProps.getServerUrl());
+        
+        if (docProps.getServers() != null && !docProps.getServers().isEmpty()) {
+            System.out.println("\n✅ 检测到 servers 配置,优先使用 servers(忽略 serverUrl)");
+            java.util.List<SwaggerProperties.ServerConfig> convertedServers = docProps.getServers().stream()
+                    .map(s -> {
+                        SwaggerProperties.ServerConfig sc = new SwaggerProperties.ServerConfig();
+                        sc.setUrl(s.getUrl());
+                        sc.setDescription(s.getDescription());
+                        return sc;
+                    })
+                    .collect(java.util.stream.Collectors.toList());
+            builder.servers(convertedServers);
+        } else {
+            System.out.println("使用 serverUrl");
+        }
+        
+        SwaggerProperties swaggerProps = builder.build();
+        
+        System.out.println("\n最终结果:");
+        System.out.println("  实际使用的配置来自 servers: " + swaggerProps.getServers().get(0).getUrl());
+        System.out.println("  serverUrl 被正确忽略: " + swaggerProps.getServerUrl());
+        
+        // 验证
+        assert swaggerProps.getServers() != null && !swaggerProps.getServers().isEmpty() : "应该有 servers";
+        assert "/portal-service-server".equals(swaggerProps.getServers().get(0).getUrl()) : "应该使用 servers 的值";
+        
+        System.out.println("✅ 优先级逻辑测试通过");
+    }
+} 

+ 274 - 0
hfln-framework-design-starter/mqtt-spring-boot-starter/src/test/java/cn/hfln/framework/mqtt/integration/ConfigurationCompatibilityTest.java

@@ -0,0 +1,274 @@
+package cn.hfln.framework.mqtt.integration;
+
+import cn.hfln.framework.mqtt.config.MqttAutoConfiguration;
+import cn.hfln.framework.mqtt.config.MqttProperties;
+import org.eclipse.paho.client.mqttv3.MqttClient;
+import org.junit.jupiter.api.DisplayName;
+import org.junit.jupiter.api.Test;
+import org.springframework.boot.autoconfigure.AutoConfigurations;
+import org.springframework.boot.test.context.runner.ApplicationContextRunner;
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+
+import static org.assertj.core.api.Assertions.assertThat;
+import static org.mockito.Mockito.mock;
+
+/**
+ * 配置兼容性测试
+ * 测试不同配置组合的兼容性和冲突处理
+ */
+@DisplayName("配置兼容性测试")
+class ConfigurationCompatibilityTest {
+
+    private final ApplicationContextRunner contextRunner = new ApplicationContextRunner()
+            .withConfiguration(AutoConfigurations.of(MqttAutoConfiguration.class));
+
+    @Test
+    @DisplayName("测试Spring Boot 2.x兼容性")
+    void testSpringBoot2Compatibility() {
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://localhost:1883",
+                        // Spring Boot 2.x 风格的配置
+                        "spring.application.name=boot2-app",
+                        "management.endpoints.web.exposure.include=health,info"
+                )
+                .run(context -> {
+                    assertThat(context).hasNotFailed();
+                    assertThat(context).hasSingleBean(MqttProperties.class);
+                });
+    }
+
+    @Test
+    @DisplayName("测试application.properties配置格式")
+    void testPropertiesFormatConfiguration() {
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        // properties格式的配置
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://properties.mqtt.server:1883",
+                        "mqtt.client-id=properties-client",
+                        "mqtt.username=props-user",
+                        "mqtt.password=props-pass",
+                        "mqtt.timeout=45",
+                        "mqtt.keepalive=90",
+                        "mqtt.clean-session=true",
+                        "mqtt.automatic-reconnect=false",
+                        "mqtt.default-qos=1",
+                        "mqtt.default-retained=false",
+                        "mqtt.async=true"
+                )
+                .run(context -> {
+                    MqttProperties properties = context.getBean(MqttProperties.class);
+                    assertThat(properties.getBroker()).isEqualTo("tcp://properties.mqtt.server:1883");
+                    assertThat(properties.getClientId()).isEqualTo("properties-client");
+                    assertThat(properties.getUsername()).isEqualTo("props-user");
+                    assertThat(properties.getPassword()).isEqualTo("props-pass");
+                    assertThat(properties.getTimeout()).isEqualTo(45);
+                    assertThat(properties.getKeepalive()).isEqualTo(90);
+                    assertThat(properties.isCleanSession()).isTrue();
+                    assertThat(properties.isAutomaticReconnect()).isFalse();
+                });
+    }
+
+    @Test
+    @DisplayName("测试环境变量配置覆盖")
+    void testEnvironmentVariableOverride() {
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        // 基础配置
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://localhost:1883",
+                        "mqtt.username=default-user",
+                        // 模拟环境变量覆盖(通过系统属性模拟)
+                        "MQTT_BROKER=tcp://env.mqtt.server:1883",
+                        "MQTT_USERNAME=env-user",
+                        "MQTT_PASSWORD=env-pass"
+                )
+                .withSystemProperties(
+                        "mqtt.broker=tcp://env.mqtt.server:1883",
+                        "mqtt.username=env-user",
+                        "mqtt.password=env-pass"
+                )
+                .run(context -> {
+                    MqttProperties properties = context.getBean(MqttProperties.class);
+                    // 系统属性应该覆盖application配置
+                    assertThat(properties.getBroker()).isEqualTo("tcp://env.mqtt.server:1883");
+                    assertThat(properties.getUsername()).isEqualTo("env-user");
+                    assertThat(properties.getPassword()).isEqualTo("env-pass");
+                });
+    }
+
+    @Test
+    @DisplayName("测试Profile特定配置")
+    void testProfileSpecificConfiguration() {
+        // 测试开发环境配置
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        "spring.profiles.active=development",
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://dev.mqtt.server:1883",
+                        "mqtt.clean-session=true", // 开发环境使用clean session
+                        "mqtt.automatic-reconnect=true"
+                )
+                .run(context -> {
+                    MqttProperties properties = context.getBean(MqttProperties.class);
+                    assertThat(properties.getBroker()).isEqualTo("tcp://dev.mqtt.server:1883");
+                    assertThat(properties.isCleanSession()).isTrue();
+                });
+
+        // 测试生产环境配置
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        "spring.profiles.active=production",
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://prod.mqtt.server:1883",
+                        "mqtt.clean-session=false", // 生产环境保持会话
+                        "mqtt.automatic-reconnect=true",
+                        "mqtt.max-reconnect-attempts=10"
+                )
+                .run(context -> {
+                    MqttProperties properties = context.getBean(MqttProperties.class);
+                    assertThat(properties.getBroker()).isEqualTo("tcp://prod.mqtt.server:1883");
+                    assertThat(properties.isCleanSession()).isFalse();
+                    assertThat(properties.getMaxReconnectAttempts()).isEqualTo(10);
+                });
+    }
+
+    @Test
+    @DisplayName("测试配置验证和默认值")
+    void testConfigurationValidationAndDefaults() {
+        // 测试最小配置
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        "mqtt.enabled=true"
+                        // 只设置enabled,其他使用默认值
+                )
+                .run(context -> {
+                    MqttProperties properties = context.getBean(MqttProperties.class);
+                    // 验证默认值
+                    assertThat(properties.getBroker()).isEqualTo("tcp://localhost:1883");
+                    assertThat(properties.getTimeout()).isEqualTo(30);
+                    assertThat(properties.getKeepalive()).isEqualTo(60);
+                    assertThat(properties.isCleanSession()).isTrue();
+                    assertThat(properties.isAutomaticReconnect()).isTrue();
+                    assertThat(properties.getDefaultQos()).isEqualTo(1);
+                    assertThat(properties.isDefaultRetained()).isFalse();
+                    assertThat(properties.isAsync()).isTrue();
+                });
+    }
+
+    @Test
+    @DisplayName("测试不兼容配置的处理")
+    void testIncompatibleConfigurationHandling() {
+        // 测试无效的数值配置
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://localhost:1883",
+                        "mqtt.timeout=-1", // 无效的超时时间
+                        "mqtt.keepalive=0", // 无效的心跳间隔
+                        "mqtt.default-qos=5" // 无效的QoS级别 (应该是0,1,2)
+                )
+                .run(context -> {
+                    // 配置应该能正常加载,但可能使用默认值或边界值
+                    assertThat(context).hasNotFailed();
+                    MqttProperties properties = context.getBean(MqttProperties.class);
+                    // 验证无效值是否被处理(具体行为取决于实现)
+                    assertThat(properties).isNotNull();
+                });
+    }
+
+    @Test
+    @DisplayName("测试类路径资源配置")
+    void testClasspathResourceConfiguration() {
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://localhost:1883",
+                        // 测试是否能正确处理classpath资源引用
+                        "logging.config=classpath:logback-test.xml"
+                )
+                .run(context -> {
+                    assertThat(context).hasNotFailed();
+                    assertThat(context).hasSingleBean(MqttProperties.class);
+                });
+    }
+
+    @Test
+    @DisplayName("测试外部配置文件加载")
+    void testExternalConfigurationFileLoading() {
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        // 模拟从外部配置文件加载的配置
+                        "spring.config.additional-location=classpath:external-mqtt.properties",
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://external.mqtt.server:1883"
+                )
+                .run(context -> {
+                    assertThat(context).hasNotFailed();
+                    MqttProperties properties = context.getBean(MqttProperties.class);
+                    assertThat(properties.getBroker()).isEqualTo("tcp://external.mqtt.server:1883");
+                });
+    }
+
+    @Test
+    @DisplayName("测试配置刷新兼容性")
+    void testConfigurationRefreshCompatibility() {
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://localhost:1883",
+                        // 启用配置刷新相关功能
+                        "management.endpoints.web.exposure.include=refresh",
+                        "spring.cloud.config.enabled=false" // 避免云配置依赖
+                )
+                .run(context -> {
+                    assertThat(context).hasNotFailed();
+                    assertThat(context).hasSingleBean(MqttProperties.class);
+                });
+    }
+
+    @Test
+    @DisplayName("测试多配置源优先级")
+    void testMultipleConfigurationSourcePriority() {
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        // application.properties中的配置
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://props.mqtt.server:1883",
+                        "mqtt.username=props-user"
+                )
+                .withSystemProperties(
+                        // 系统属性配置(应该有更高优先级)
+                        "mqtt.broker=tcp://system.mqtt.server:1883",
+                        "mqtt.username=system-user"
+                )
+                .run(context -> {
+                    MqttProperties properties = context.getBean(MqttProperties.class);
+                    // 系统属性应该覆盖application.properties
+                    assertThat(properties.getBroker()).isEqualTo("tcp://system.mqtt.server:1883");
+                    assertThat(properties.getUsername()).isEqualTo("system-user");
+                });
+    }
+
+    @Configuration
+    static class MockConfiguration {
+        @Bean
+        public MqttClient mqttClient() {
+            return mock(MqttClient.class);
+        }
+    }
+} 

+ 337 - 0
hfln-framework-design-starter/mqtt-spring-boot-starter/src/test/java/cn/hfln/framework/mqtt/integration/ExternalApplicationSimulationTest.java

@@ -0,0 +1,337 @@
+package cn.hfln.framework.mqtt.integration;
+
+import cn.hfln.framework.mqtt.annotation.MqttSubscribe;
+import cn.hfln.framework.mqtt.config.MqttAutoConfiguration;
+import cn.hfln.framework.mqtt.gateway.MqttGateway;
+import cn.hfln.framework.mqtt.template.MqttTemplate;
+import org.eclipse.paho.client.mqttv3.MqttClient;
+import org.junit.jupiter.api.DisplayName;
+import org.junit.jupiter.api.Test;
+import org.springframework.boot.autoconfigure.AutoConfigurations;
+import org.springframework.boot.test.context.runner.ApplicationContextRunner;
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+import org.springframework.stereotype.Component;
+
+import static org.assertj.core.api.Assertions.assertThat;
+import static org.mockito.Mockito.mock;
+
+/**
+ * 外部应用程序模拟测试
+ * 模拟真实的外部Spring Boot应用程序使用此starter
+ */
+@DisplayName("外部应用程序模拟测试")
+class ExternalApplicationSimulationTest {
+
+    private final ApplicationContextRunner contextRunner = new ApplicationContextRunner()
+            .withConfiguration(AutoConfigurations.of(MqttAutoConfiguration.class));
+
+    @Test
+    @DisplayName("模拟典型的Web应用程序集成")
+    void testTypicalWebApplicationIntegration() {
+        contextRunner
+                .withUserConfiguration(TypicalWebAppConfiguration.class)
+                .withPropertyValues(
+                        "spring.application.name=test-web-app",
+                        "server.port=8080",
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://localhost:1883",
+                        "mqtt.client-id=web-app-client",
+                        "mqtt.username=webuser",
+                        "mqtt.password=webpass",
+                        "mqtt.subscribe-topics=sensor/+/data,alert/+/emergency"
+                )
+                .run(context -> {
+                    // 验证starter与典型Web应用配置的兼容性
+                    assertThat(context).hasNotFailed();
+                    assertThat(context).hasSingleBean(MqttTemplate.class);
+                    assertThat(context).hasSingleBean(MqttGateway.class);
+                    assertThat(context).hasSingleBean(ExternalMqttService.class);
+                    
+                    // 验证业务服务能正常注入MQTT组件
+                    ExternalMqttService service = context.getBean(ExternalMqttService.class);
+                    assertThat(service.getMqttTemplate()).isNotNull();
+                    assertThat(service.getMqttGateway()).isNotNull();
+                });
+    }
+
+    @Test
+    @DisplayName("模拟微服务应用程序集成")
+    void testMicroserviceApplicationIntegration() {
+        contextRunner
+                .withUserConfiguration(MicroserviceAppConfiguration.class)
+                .withPropertyValues(
+                        "spring.application.name=device-service",
+                        "spring.cloud.service-registry.auto-registration.enabled=false", // 禁用服务注册避免测试依赖
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://mqtt.microservice.local:1883",
+                        "mqtt.client-id=${spring.application.name}-${random.uuid}",
+                        "mqtt.automatic-reconnect=true",
+                        "mqtt.max-reconnect-attempts=5",
+                        "mqtt.subscribe-topics=device/+/status,device/+/telemetry"
+                )
+                .run(context -> {
+                    // 验证starter与微服务架构的兼容性
+                    assertThat(context).hasNotFailed();
+                    assertThat(context).hasSingleBean(DeviceEventHandler.class);
+                    
+                    DeviceEventHandler handler = context.getBean(DeviceEventHandler.class);
+                    assertThat(handler.getMqttGateway()).isNotNull();
+                });
+    }
+
+    @Test
+    @DisplayName("模拟IoT平台应用程序集成")
+    void testIoTPlatformApplicationIntegration() {
+        contextRunner
+                .withUserConfiguration(IoTPlatformConfiguration.class)
+                .withPropertyValues(
+                        "spring.application.name=iot-platform",
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://iot.mqtt.server:1883",
+                        "mqtt.username=iot-platform",
+                        "mqtt.password=iot-secret",
+                        "mqtt.default-qos=2", // IoT平台通常需要较高的QoS
+                        "mqtt.clean-session=false", // 持久化会话
+                        "mqtt.subscribe-topics=+/+/telemetry,+/+/status,+/+/alert",
+                        "mqtt.max-message-size=2097152" // 2MB
+                )
+                .run(context -> {
+                    // 验证starter与IoT平台的兼容性
+                    assertThat(context).hasNotFailed();
+                    assertThat(context).hasSingleBean(IoTMessageProcessor.class);
+                    
+                    IoTMessageProcessor processor = context.getBean(IoTMessageProcessor.class);
+                    assertThat(processor).isNotNull();
+                });
+    }
+
+    @Test
+    @DisplayName("模拟批处理应用程序集成")
+    void testBatchApplicationIntegration() {
+        contextRunner
+                .withUserConfiguration(BatchAppConfiguration.class)
+                .withPropertyValues(
+                        "spring.application.name=data-batch-processor",
+                        "spring.batch.job.enabled=false", // 禁用自动启动
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://batch.mqtt.server:1883",
+                        "mqtt.client-id=batch-processor",
+                        "mqtt.async=false", // 批处理通常需要同步处理
+                        "mqtt.subscribe-topics=batch/+/input"
+                )
+                .run(context -> {
+                    // 验证starter与批处理应用的兼容性
+                    assertThat(context).hasNotFailed();
+                    assertThat(context).hasSingleBean(BatchDataProcessor.class);
+                });
+    }
+
+    @Test
+    @DisplayName("测试starter与Spring Security集成")
+    void testSpringSecurityIntegration() {
+        contextRunner
+                .withUserConfiguration(SecurityAppConfiguration.class)
+                .withPropertyValues(
+                        "spring.application.name=secure-mqtt-app",
+                        "spring.security.user.name=admin",
+                        "spring.security.user.password=admin123",
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://secure.mqtt.server:8883",
+                        "mqtt.username=secure-user",
+                        "mqtt.password=secure-pass"
+                )
+                .run(context -> {
+                    // 验证starter与Spring Security的兼容性
+                    assertThat(context).hasNotFailed();
+                    assertThat(context).hasSingleBean(SecureMessageHandler.class);
+                });
+    }
+
+    @Test
+    @DisplayName("测试starter与多数据源集成")
+    void testMultiDataSourceIntegration() {
+        contextRunner
+                .withUserConfiguration(MultiDataSourceConfiguration.class)
+                .withPropertyValues(
+                        "spring.application.name=multi-datasource-app",
+                        "spring.datasource.primary.url=jdbc:h2:mem:primary",
+                        "spring.datasource.secondary.url=jdbc:h2:mem:secondary",
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://localhost:1883"
+                )
+                .run(context -> {
+                    // 验证starter与多数据源配置的兼容性
+                    assertThat(context).hasNotFailed();
+                    assertThat(context).hasSingleBean(DataSyncService.class);
+                });
+    }
+
+    // 典型Web应用配置
+    @Configuration
+    static class TypicalWebAppConfiguration {
+        @Bean
+        public MqttClient mqttClient() {
+            return mock(MqttClient.class);
+        }
+
+        @Bean
+        public ExternalMqttService externalMqttService(MqttTemplate mqttTemplate, MqttGateway mqttGateway) {
+            return new ExternalMqttService(mqttTemplate, mqttGateway);
+        }
+    }
+
+    // 微服务应用配置
+    @Configuration
+    static class MicroserviceAppConfiguration {
+        @Bean
+        public MqttClient mqttClient() {
+            return mock(MqttClient.class);
+        }
+
+        @Bean
+        public DeviceEventHandler deviceEventHandler(MqttGateway mqttGateway) {
+            return new DeviceEventHandler(mqttGateway);
+        }
+    }
+
+    // IoT平台配置
+    @Configuration
+    static class IoTPlatformConfiguration {
+        @Bean
+        public MqttClient mqttClient() {
+            return mock(MqttClient.class);
+        }
+
+        @Bean
+        public IoTMessageProcessor ioTMessageProcessor() {
+            return new IoTMessageProcessor();
+        }
+    }
+
+    // 批处理应用配置
+    @Configuration
+    static class BatchAppConfiguration {
+        @Bean
+        public MqttClient mqttClient() {
+            return mock(MqttClient.class);
+        }
+
+        @Bean
+        public BatchDataProcessor batchDataProcessor() {
+            return new BatchDataProcessor();
+        }
+    }
+
+    // 安全应用配置
+    @Configuration
+    static class SecurityAppConfiguration {
+        @Bean
+        public MqttClient mqttClient() {
+            return mock(MqttClient.class);
+        }
+
+        @Bean
+        public SecureMessageHandler secureMessageHandler() {
+            return new SecureMessageHandler();
+        }
+    }
+
+    // 多数据源配置
+    @Configuration
+    static class MultiDataSourceConfiguration {
+        @Bean
+        public MqttClient mqttClient() {
+            return mock(MqttClient.class);
+        }
+
+        @Bean
+        public DataSyncService dataSyncService() {
+            return new DataSyncService();
+        }
+    }
+
+    // 模拟的外部业务服务类
+    static class ExternalMqttService {
+        private final MqttTemplate mqttTemplate;
+        private final MqttGateway mqttGateway;
+
+        public ExternalMqttService(MqttTemplate mqttTemplate, MqttGateway mqttGateway) {
+            this.mqttTemplate = mqttTemplate;
+            this.mqttGateway = mqttGateway;
+        }
+
+        public MqttTemplate getMqttTemplate() {
+            return mqttTemplate;
+        }
+
+        public MqttGateway getMqttGateway() {
+            return mqttGateway;
+        }
+    }
+
+    // 模拟的设备事件处理器
+    @Component
+    static class DeviceEventHandler {
+        private final MqttGateway mqttGateway;
+
+        public DeviceEventHandler(MqttGateway mqttGateway) {
+            this.mqttGateway = mqttGateway;
+        }
+
+        @MqttSubscribe(topic = "device/+/status")
+        public void handleDeviceStatus(String message) {
+            // 处理设备状态消息
+        }
+
+        @MqttSubscribe(topic = "device/+/telemetry")
+        public void handleDeviceTelemetry(String message) {
+            // 处理设备遥测数据
+        }
+
+        public MqttGateway getMqttGateway() {
+            return mqttGateway;
+        }
+    }
+
+    // 模拟的IoT消息处理器
+    @Component
+    static class IoTMessageProcessor {
+        @MqttSubscribe(topic = "+/+/telemetry")
+        public void processTelemetryData(String deviceId, String sensorId, String data) {
+            // 处理遥测数据
+        }
+
+        @MqttSubscribe(topic = "+/+/alert")
+        public void processAlert(String deviceId, String alertType, String alertData) {
+            // 处理告警数据
+        }
+    }
+
+    // 模拟的批处理数据处理器
+    @Component
+    static class BatchDataProcessor {
+        @MqttSubscribe(topic = "batch/+/input")
+        public void processBatchData(String batchId, String data) {
+            // 处理批量数据
+        }
+    }
+
+    // 模拟的安全消息处理器
+    @Component
+    static class SecureMessageHandler {
+        @MqttSubscribe(topic = "secure/+/message")
+        public void handleSecureMessage(String userId, String encryptedMessage) {
+            // 处理加密消息
+        }
+    }
+
+    // 模拟的数据同步服务
+    @Component
+    static class DataSyncService {
+        @MqttSubscribe(topic = "sync/+/data")
+        public void syncData(String sourceId, String data) {
+            // 同步数据到多个数据源
+        }
+    }
+} 

+ 261 - 0
hfln-framework-design-starter/mqtt-spring-boot-starter/src/test/java/cn/hfln/framework/mqtt/integration/ExternalEnvironmentIntegrationTest.java

@@ -0,0 +1,261 @@
+package cn.hfln.framework.mqtt.integration;
+
+import cn.hfln.framework.mqtt.config.MqttAutoConfiguration;
+import cn.hfln.framework.mqtt.config.MqttProperties;
+import cn.hfln.framework.mqtt.converter.MessageConverter;
+import cn.hfln.framework.mqtt.gateway.MqttGateway;
+import cn.hfln.framework.mqtt.template.MqttTemplate;
+import org.eclipse.paho.client.mqttv3.MqttClient;
+import org.junit.jupiter.api.DisplayName;
+import org.junit.jupiter.api.Test;
+import org.springframework.boot.autoconfigure.AutoConfigurations;
+import org.springframework.boot.test.context.runner.ApplicationContextRunner;
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+
+import static org.assertj.core.api.Assertions.assertThat;
+
+/**
+ * 外部环境集成测试
+ * 测试当前starter在外部项目引用时是否正常工作
+ */
+@DisplayName("外部环境集成测试")
+class ExternalEnvironmentIntegrationTest {
+
+    private final ApplicationContextRunner contextRunner = new ApplicationContextRunner()
+            .withConfiguration(AutoConfigurations.of(MqttAutoConfiguration.class));
+
+    @Test
+    @DisplayName("测试默认配置下的自动装配")
+    void testDefaultAutoConfiguration() {
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://localhost:1883"
+                )
+                .run(context -> {
+                    // 验证核心Bean是否正确创建
+                    assertThat(context).hasSingleBean(MqttProperties.class);
+                    assertThat(context).hasSingleBean(MqttTemplate.class);
+                    assertThat(context).hasSingleBean(MqttGateway.class);
+                    assertThat(context).hasSingleBean(MessageConverter.class);
+                    
+                    // 验证配置属性是否正确加载
+                    MqttProperties properties = context.getBean(MqttProperties.class);
+                    assertThat(properties.getBroker()).isEqualTo("tcp://localhost:1883");
+                    assertThat(properties.isEnabled()).isTrue();
+                });
+    }
+
+    @Test
+    @DisplayName("测试禁用MQTT时的配置")
+    void testDisabledMqttConfiguration() {
+        contextRunner
+                .withPropertyValues("mqtt.enabled=false")
+                .run(context -> {
+                    // 当MQTT被禁用时,相关Bean不应该被创建
+                    assertThat(context).doesNotHaveBean(MqttTemplate.class);
+                    assertThat(context).doesNotHaveBean(MqttGateway.class);
+                });
+    }
+
+    @Test
+    @DisplayName("测试完整配置属性的加载")
+    void testFullConfigurationProperties() {
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://test.mqtt.server:1883",
+                        "mqtt.client-id=test-client-123",
+                        "mqtt.username=testuser",
+                        "mqtt.password=testpass",
+                        "mqtt.timeout=60",
+                        "mqtt.keepalive=120",
+                        "mqtt.clean-session=false",
+                        "mqtt.automatic-reconnect=true",
+                        "mqtt.max-reconnect-attempts=5",
+                        "mqtt.reconnect-interval=3000",
+                        "mqtt.default-qos=2",
+                        "mqtt.default-retained=true",
+                        "mqtt.async=false"
+                )
+                .run(context -> {
+                    MqttProperties properties = context.getBean(MqttProperties.class);
+                    
+                    // 验证所有配置属性是否正确设置
+                    assertThat(properties.isEnabled()).isTrue();
+                    assertThat(properties.getBroker()).isEqualTo("tcp://test.mqtt.server:1883");
+                    assertThat(properties.getClientId()).isEqualTo("test-client-123");
+                    assertThat(properties.getUsername()).isEqualTo("testuser");
+                    assertThat(properties.getPassword()).isEqualTo("testpass");
+                    assertThat(properties.getTimeout()).isEqualTo(60);
+                    assertThat(properties.getKeepalive()).isEqualTo(120);
+                    assertThat(properties.isCleanSession()).isFalse();
+                    assertThat(properties.isAutomaticReconnect()).isTrue();
+                    assertThat(properties.getMaxReconnectAttempts()).isEqualTo(5);
+                    assertThat(properties.getReconnectInterval()).isEqualTo(3000);
+                    assertThat(properties.getDefaultQos()).isEqualTo(2);
+                    assertThat(properties.isDefaultRetained()).isTrue();
+                    assertThat(properties.isAsync()).isFalse();
+                });
+    }
+
+    @Test
+    @DisplayName("测试自定义Bean的覆盖")
+    void testCustomBeanOverride() {
+        contextRunner
+                .withUserConfiguration(CustomConfiguration.class)
+                .withPropertyValues(
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://localhost:1883"
+                )
+                .run(context -> {
+                    // 验证自定义Bean是否正确覆盖默认Bean
+                    assertThat(context).hasSingleBean(MessageConverter.class);
+                    MessageConverter converter = context.getBean(MessageConverter.class);
+                    assertThat(converter).isInstanceOf(CustomMessageConverter.class);
+                });
+    }
+
+    @Test
+    @DisplayName("测试配置前缀错误时的处理")
+    void testInvalidConfigurationPrefix() {
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        // 使用错误的配置前缀
+                        "invalid.broker=tcp://localhost:1883"
+                )
+                .run(context -> {
+                    // 应该使用默认配置
+                    MqttProperties properties = context.getBean(MqttProperties.class);
+                    assertThat(properties.getBroker()).isEqualTo("tcp://localhost:1883"); // 默认值
+                });
+    }
+
+    @Test
+    @DisplayName("测试缺少必要依赖时的处理")
+    void testMissingDependenciesHandling() {
+        // 在没有Mock配置的情况下运行,模拟缺少MQTT客户端依赖的情况
+        contextRunner
+                .withPropertyValues(
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://localhost:1883"
+                )
+                .run(context -> {
+                    // 由于缺少Mock配置,某些Bean创建可能失败,但不应该导致上下文启动失败
+                    assertThat(context).hasSingleBean(MqttProperties.class);
+                });
+    }
+
+    @Test
+    @DisplayName("测试多环境配置")
+    void testMultiEnvironmentConfiguration() {
+        // 测试开发环境配置
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        "spring.profiles.active=dev",
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://dev.mqtt.server:1883",
+                        "mqtt.clean-session=true"
+                )
+                .run(context -> {
+                    MqttProperties properties = context.getBean(MqttProperties.class);
+                    assertThat(properties.getBroker()).isEqualTo("tcp://dev.mqtt.server:1883");
+                    assertThat(properties.isCleanSession()).isTrue();
+                });
+
+        // 测试生产环境配置
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        "spring.profiles.active=prod",
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://prod.mqtt.server:1883",
+                        "mqtt.clean-session=false",
+                        "mqtt.automatic-reconnect=true"
+                )
+                .run(context -> {
+                    MqttProperties properties = context.getBean(MqttProperties.class);
+                    assertThat(properties.getBroker()).isEqualTo("tcp://prod.mqtt.server:1883");
+                    assertThat(properties.isCleanSession()).isFalse();
+                    assertThat(properties.isAutomaticReconnect()).isTrue();
+                });
+    }
+
+    @Test
+    @DisplayName("测试YAML配置解析")
+    void testYamlConfigurationParsing() {
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://yaml.mqtt.server:1883",
+                        "mqtt.subscribe-topics[0]=topic1",
+                        "mqtt.subscribe-topics[1]=topic2",
+                        "mqtt.subscribe-topics[2]=topic3"
+                )
+                .run(context -> {
+                    MqttProperties properties = context.getBean(MqttProperties.class);
+                    assertThat(properties.getSubscribeTopics()).hasSize(3);
+                    assertThat(properties.getSubscribeTopics()).containsExactly("topic1", "topic2", "topic3");
+                });
+    }
+
+    @Test
+    @DisplayName("测试Bean循环依赖检测")
+    void testCircularDependencyDetection() {
+        contextRunner
+                .withUserConfiguration(MockConfiguration.class)
+                .withPropertyValues(
+                        "mqtt.enabled=true",
+                        "mqtt.broker=tcp://localhost:1883"
+                )
+                .run(context -> {
+                    // 验证没有循环依赖问题
+                    assertThat(context).hasNotFailed();
+                    assertThat(context).hasSingleBean(MqttTemplate.class);
+                    assertThat(context).hasSingleBean(MqttGateway.class);
+                });
+    }
+
+    // Mock配置类,提供测试所需的Mock Bean
+    @Configuration
+    static class MockConfiguration {
+        @Bean
+        public MqttClient mqttClient() {
+            return org.mockito.Mockito.mock(MqttClient.class);
+        }
+        
+        @Bean
+        public org.springframework.scheduling.TaskScheduler taskScheduler() {
+            return org.mockito.Mockito.mock(org.springframework.scheduling.TaskScheduler.class);
+        }
+    }
+
+    // 自定义配置类,用于测试Bean覆盖
+    @Configuration
+    static class CustomConfiguration extends MockConfiguration {
+        @Bean
+        public MessageConverter messageConverter() {
+            return new CustomMessageConverter();
+        }
+    }
+
+    // 自定义消息转换器,用于测试Bean覆盖
+    static class CustomMessageConverter implements MessageConverter {
+        @Override
+        public org.eclipse.paho.client.mqttv3.MqttMessage toMessage(Object payload) {
+            String customPayload = "custom:" + payload;
+            return new org.eclipse.paho.client.mqttv3.MqttMessage(customPayload.getBytes());
+        }
+
+        @Override
+        public <T> T fromMessage(org.eclipse.paho.client.mqttv3.MqttMessage message, Class<T> targetType) {
+            return null;
+        }
+    }
+} 

+ 59 - 0
hfln-framework-design-starter/mqtt-spring-boot-starter/src/test/java/cn/hfln/framework/mqtt/integration/StarterIntegrationTestSuite.java

@@ -0,0 +1,59 @@
+package cn.hfln.framework.mqtt.integration;
+
+import org.junit.jupiter.api.DisplayName;
+
+/**
+ * MQTT Spring Boot Starter 外部环境集成测试套件
+ * 
+ * 本测试套件包含了所有针对外部环境引用的集成测试,用于验证:
+ * 1. Starter的自动配置是否正确
+ * 2. 在不同外部环境下的兼容性
+ * 3. 配置的正确性和灵活性
+ * 4. Bean的创建和依赖注入
+ * 5. 与其他Spring Boot组件的集成
+ * 
+ * 测试覆盖场景:
+ * - 典型Web应用程序集成
+ * - 微服务应用程序集成
+ * - IoT平台应用程序集成
+ * - 批处理应用程序集成
+ * - Spring Security集成
+ * - 多数据源集成
+ * - 配置兼容性测试
+ * - 多环境配置测试
+ * - Bean覆盖和自定义测试
+ * 
+ * 运行方式:
+ * 1. 运行 ExternalEnvironmentIntegrationTest 测试基本的外部环境集成
+ * 2. 运行 ExternalApplicationSimulationTest 测试模拟的外部应用程序
+ * 3. 运行 ConfigurationCompatibilityTest 测试配置兼容性
+ */
+@DisplayName("MQTT Starter 外部环境集成测试套件")
+public class StarterIntegrationTestSuite {
+    
+    /**
+     * 测试结果说明:
+     * 
+     * 如果所有测试都通过,说明:
+     * ✅ Starter能够正确地在外部环境中自动配置
+     * ✅ 配置属性能够正确绑定和验证
+     * ✅ Bean能够正确创建和注入
+     * ✅ 与其他Spring Boot组件兼容
+     * ✅ 支持多环境配置
+     * ✅ 支持自定义配置覆盖
+     * 
+     * 如果测试失败,可能的问题:
+     * ❌ 自动配置类缺少必要的条件注解
+     * ❌ 配置属性绑定有问题
+     * ❌ Bean创建存在循环依赖
+     * ❌ 与其他组件存在冲突
+     * ❌ 配置验证过于严格或过于宽松
+     * ❌ 类路径问题或依赖冲突
+     * 
+     * 测试建议:
+     * 1. 在CI/CD流水线中运行这些测试
+     * 2. 在发布前确保所有测试通过
+     * 3. 定期更新测试以反映新的使用场景
+     * 4. 监控测试执行时间,避免测试过慢
+     */
+} 

+ 14 - 0
hfln-framework-design-starter/mqtt-spring-boot-starter/src/test/resources/application-dev.yml

@@ -0,0 +1,14 @@
+mqtt:
+  enabled: true
+  broker: tcp://localhost:1883
+  client-id: dev-client-${random.uuid}
+  fail-fast-on-initial-connection: false  # 初始连接失败时不抛出异常
+  automatic-reconnect: true
+  max-reconnect-attempts: 3
+  reconnect-interval: 5000
+
+logging:
+  level:
+    cn.hfln.framework.mqtt: INFO
+    org.springframework.integration.mqtt: WARN
+    org.eclipse.paho: WARN 

+ 8 - 0
hfln-framework-design-starter/mqtt-spring-boot-starter/src/test/resources/application-no-mqtt.yml

@@ -0,0 +1,8 @@
+mqtt:
+  enabled: false  # 完全禁用MQTT功能
+
+logging:
+  level:
+    cn.hfln.framework.mqtt: DEBUG
+    org.springframework.integration.mqtt: WARN
+    org.eclipse.paho: WARN 

+ 380 - 0
hfln-framework-design-starter/mqtt-spring-boot-starter/src/test/resources/外部应用示例配置.md

@@ -0,0 +1,380 @@
+# MQTT Spring Boot Starter 外部应用示例配置
+
+## 问题解决总结
+
+### 遇到的问题
+在外部应用引用该starter时,出现了以下错误:
+```
+Parameter 0 of method mqttTemplate in cn.hfln.framework.mqtt.config.MqttAutoConfiguration required a bean named 'mqttConnectionListeners' that could not be found.
+```
+
+### 问题原因
+1. **NullPointerException**: 当配置属性中的用户名或密码为null时,调用`toCharArray()`方法会抛出异常
+2. **TaskScheduler缺失**: `MqttPahoMessageDrivenChannelAdapter`需要`TaskScheduler` Bean
+3. **Bean名称冲突**: Spring的依赖注入使用参数名匹配Bean名称,可能导致匹配错误
+4. **@Autowired冲突**: `MqttTemplate`类上的多个`@Autowired`构造函数导致Spring自动装配冲突
+
+### 解决方案
+
+#### 1. 修复NullPointerException
+```java
+@Bean
+@ConditionalOnMissingBean
+public MqttConnectOptions mqttConnectOptions() {
+    MqttConnectOptions options = new MqttConnectOptions();
+    options.setServerURIs(new String[]{mqttProperties.getBroker()});
+    
+    // 设置用户名,如果不为null
+    if (mqttProperties.getUsername() != null) {
+        options.setUserName(mqttProperties.getUsername());
+    }
+    
+    // 设置密码,如果不为null
+    if (mqttProperties.getPassword() != null) {
+        options.setPassword(mqttProperties.getPassword().toCharArray());
+    }
+    
+    options.setKeepAliveInterval(mqttProperties.getKeepalive());
+    options.setConnectionTimeout(mqttProperties.getTimeout());
+    options.setCleanSession(mqttProperties.isCleanSession());
+    options.setAutomaticReconnect(mqttProperties.isAutomaticReconnect());
+    return options;
+}
+```
+
+#### 2. 添加TaskScheduler Bean
+```java
+@Bean
+@ConditionalOnMissingBean
+public TaskScheduler taskScheduler() {
+    ThreadPoolTaskScheduler scheduler = new ThreadPoolTaskScheduler();
+    scheduler.setPoolSize(1);
+    scheduler.setThreadNamePrefix("mqtt-task-");
+    scheduler.setWaitForTasksToCompleteOnShutdown(true);
+    scheduler.setAwaitTerminationSeconds(30);
+    return scheduler;
+}
+```
+
+#### 3. 使用@Qualifier注解明确Bean引用
+```java
+@Bean
+@ConditionalOnMissingBean
+public MqttTemplate mqttTemplate(@Qualifier("mqttClient") MqttClient mqttClient,
+                                 @Qualifier("messageConverter") MessageConverter messageConverter,
+                                 @Qualifier("mqttMessageInterceptors") List<MqttMessageInterceptor> mqttMessageInterceptors) {
+    return new MqttTemplate(mqttClient, mqttMessageInterceptors, messageConverter);
+}
+```
+
+#### 4. 移除冲突的@Component和@Autowired注解
+- 从`MqttTemplate`类中移除`@Component`注解,使用配置类管理Bean创建
+- 移除`MqttTemplate`构造函数上的`@Autowired(required = false)`注解,避免自动装配冲突
+
+#### 5. 重写Bean创建方法
+```java
+@Bean
+@ConditionalOnMissingBean
+public MqttTemplate mqttTemplate() {
+    try {
+        MqttClient client = mqttClient(mqttClientPersistence());
+        MessageConverter converter = messageConverter();
+        List<MqttMessageInterceptor> interceptors = mqttMessageInterceptors();
+        return new MqttTemplate(client, interceptors, converter);
+    } catch (MqttException e) {
+        throw new RuntimeException("Failed to create MqttTemplate", e);
+    }
+}
+```
+
+## 外部应用使用示例
+
+### 1. Maven依赖
+
+#### 基本依赖
+```xml
+<dependency>
+    <groupId>cn.hfln.framework</groupId>
+    <artifactId>mqtt-spring-boot-starter</artifactId>
+    <version>1.0.0-SNAPSHOT</version>
+</dependency>
+```
+
+#### 如果遇到ClassNotFoundException错误
+如果外部应用启动时遇到以下错误:
+```
+java.lang.ClassNotFoundException: org.eclipse.paho.client.mqttv3.MqttClient
+```
+
+请确保在外部应用的`pom.xml`中明确添加MQTT客户端依赖:
+```xml
+<dependency>
+    <groupId>org.eclipse.paho</groupId>
+    <artifactId>org.eclipse.paho.client.mqttv3</artifactId>
+    <version>1.2.5</version>
+</dependency>
+<dependency>
+    <groupId>org.springframework.integration</groupId>
+    <artifactId>spring-integration-mqtt</artifactId>
+</dependency>
+```
+
+### 2. 配置文件 (application.yml)
+```yaml
+spring:
+  application:
+    name: my-mqtt-app
+
+mqtt:
+  enabled: true
+  broker: tcp://localhost:1883
+  client-id: my-app-client
+  username: myuser
+  password: mypass
+  timeout: 30
+  keepalive: 60
+  clean-session: true
+  automatic-reconnect: true
+  default-qos: 1
+  subscribe-topics:
+    - sensor/+/data
+    - alert/+/emergency
+```
+
+### 3. 业务代码示例
+
+#### 消息发送
+```java
+@Service
+public class MqttService {
+    
+    @Autowired
+    private MqttTemplate mqttTemplate;
+    
+    @Autowired
+    private MqttGateway mqttGateway;
+    
+    public void sendMessage(String topic, String message) {
+        mqttTemplate.send(topic, message);
+    }
+    
+    public void sendJsonMessage(String topic, Object data) {
+        mqttTemplate.sendJson(topic, data);
+    }
+}
+```
+
+#### 消息接收
+```java
+@Component
+public class MqttMessageHandler {
+    
+    @MqttSubscribe(topic = "sensor/+/data")
+    public void handleSensorData(String sensorId, String data) {
+        System.out.println("Received sensor data from " + sensorId + ": " + data);
+    }
+    
+    @MqttSubscribe(topic = "alert/+/emergency")
+    public void handleEmergencyAlert(String deviceId, String alertData) {
+        System.out.println("Emergency alert from " + deviceId + ": " + alertData);
+    }
+}
+```
+
+### 4. 自定义配置
+```java
+@Configuration
+public class CustomMqttConfiguration {
+    
+    // 自定义消息转换器
+    @Bean
+    @Primary
+    public MessageConverter customMessageConverter() {
+        return new MyCustomMessageConverter();
+    }
+    
+    // 自定义连接监听器
+    @Bean
+    public MqttConnectionListener customConnectionListener() {
+        return new MqttConnectionListener() {
+            @Override
+            public void connectionLost(Throwable cause) {
+                // 处理连接丢失
+            }
+            
+            @Override
+            public void deliveryComplete(IMqttDeliveryToken token) {
+                // 处理消息发送完成
+            }
+        };
+    }
+}
+```
+
+### 5. 测试配置
+```yaml
+# application-test.yml
+mqtt:
+  enabled: false  # 测试环境可以禁用MQTT
+
+# 或者使用内存MQTT服务器进行测试
+mqtt:
+  enabled: true
+  broker: tcp://localhost:1883
+  client-id: test-client-${random.uuid}
+```
+
+## 完整的外部应用示例
+
+### 主应用类
+```java
+@SpringBootApplication
+public class MqttDemoApplication {
+    public static void main(String[] args) {
+        SpringApplication.run(MqttDemoApplication.class, args);
+    }
+}
+```
+
+### 业务服务
+```java
+@Service
+@Slf4j
+public class DeviceService {
+    
+    @Autowired
+    private MqttTemplate mqttTemplate;
+    
+    public void publishDeviceStatus(String deviceId, DeviceStatus status) {
+        String topic = "device/" + deviceId + "/status";
+        mqttTemplate.sendJson(topic, status);
+        log.info("Published device status: {} -> {}", deviceId, status);
+    }
+    
+    @MqttSubscribe(topic = "device/+/command")
+    public void handleDeviceCommand(String deviceId, String command) {
+        log.info("Received command for device {}: {}", deviceId, command);
+        // 处理设备命令
+    }
+}
+```
+
+## 修复验证
+
+我们创建了专门的测试来验证修复效果:
+
+```java
+@SpringBootTest(classes = {MqttAutoConfiguration.class})
+@TestPropertySource(properties = {
+    "mqtt.enabled=true",
+    "mqtt.broker=tcp://localhost:1883",
+    "mqtt.client-id=test-client"
+})
+public class FinalBeanInjectionTest {
+    @Test
+    public void testApplicationContextLoads() {
+        // 如果能到这里说明Spring上下文启动成功,Bean注入问题已解决
+        System.out.println("SUCCESS: Spring context loaded successfully!");
+    }
+}
+```
+
+测试结果显示:**SUCCESS: Spring context loaded successfully! Bean injection issue is fixed!**
+
+## 问题总结
+
+通过以上修复,我们解决了以下问题:
+1. **NullPointerException**: 空指针异常 - 添加了null检查
+2. **TaskScheduler缺失**: 任务调度器缺失 - 添加了TaskScheduler Bean
+3. **Bean注入冲突**: Bean名称匹配问题 - 使用@Qualifier明确指定
+4. **@Autowired冲突**: 构造函数自动装配冲突 - 移除了冲突的@Autowired注解
+5. **循环依赖**: Bean创建时的循环调用问题 - 重构了Bean创建方式
+
+## 故障排除
+
+### 1. 连接错误:无法连接至服务器
+```
+org.eclipse.paho.client.mqttv3.MqttException: 无法连接至服务器
+Caused by: java.net.ConnectException: Connection refused
+```
+
+**原因**:MQTT服务器未启动或网络连接问题
+
+**解决方案**:
+1. **启动MQTT服务器**(推荐使用Docker):
+   ```bash
+   docker run -it -p 1883:1883 -p 9001:9001 eclipse-mosquitto
+   ```
+
+2. **禁用MQTT功能**(用于测试环境):
+   ```yaml
+   mqtt:
+     enabled: false
+   ```
+
+3. **配置为非强制连接**:
+   ```yaml
+   mqtt:
+     enabled: true
+     broker: tcp://localhost:1883
+     fail-fast-on-initial-connection: false
+     automatic-reconnect: true
+   ```
+
+### 2. 类找不到错误
+```
+java.lang.ClassNotFoundException: org.eclipse.paho.client.mqttv3.MqttClient
+```
+
+**原因**:外部应用缺少MQTT客户端依赖
+
+**解决方案**:在外部应用的`pom.xml`中添加依赖(见上面的Maven依赖部分)
+
+### 3. Bean注入错误
+```
+Parameter 0 of method mqttTemplate required a bean named 'mqttConnectionListeners' that could not be found
+```
+
+**原因**:Bean创建顺序或依赖注入问题
+
+**解决方案**:这个问题已在当前版本中修复,确保使用最新版本的starter
+
+### 4. MqttTemplate Bean找不到
+```
+Field mqttPublisher required a bean of type 'cn.hfln.framework.mqtt.template.MqttTemplate' that could not be found
+```
+
+**原因**:自动配置没有被激活
+
+**解决方案**:
+1. **确保配置正确**:
+   ```yaml
+   mqtt:
+     enabled: true  # 明确启用MQTT
+     broker: tcp://localhost:1883
+   ```
+
+2. **检查依赖是否完整**:确保外部应用包含了所有必需的依赖
+
+3. **启用调试日志**:
+   ```yaml
+   logging:
+     level:
+       cn.hfln.framework.mqtt: DEBUG
+   ```
+
+4. **手动配置Bean**(临时解决方案):
+   ```java
+   @Configuration
+   public class MqttManualConfiguration {
+       
+       @Bean
+       @ConditionalOnMissingBean
+       public MqttTemplate mqttTemplate() {
+           // 手动创建MqttTemplate
+           return new MqttTemplate(/* 参数 */);
+       }
+   }
+   ```
+
+这个starter现在已经可以在外部应用中正常使用,不会出现Bean注入或配置相关的问题。 

+ 222 - 0
hfln-framework-design-starter/mqtt-spring-boot-starter/src/test/resources/完整外部应用示例.md

@@ -0,0 +1,222 @@
+# 完整外部应用集成示例
+
+## 1. 项目结构
+```
+external-app/
+├── pom.xml
+├── src/main/java/
+│   ├── com/example/Application.java
+│   ├── com/example/config/MqttConfig.java
+│   └── com/example/controller/TestController.java
+└── src/main/resources/
+    └── application.yml
+```
+
+## 2. pom.xml
+```xml
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0"
+         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 
+         http://maven.apache.org/xsd/maven-4.0.0.xsd">
+    <modelVersion>4.0.0</modelVersion>
+
+    <groupId>com.example</groupId>
+    <artifactId>external-mqtt-app</artifactId>
+    <version>1.0.0</version>
+
+    <parent>
+        <groupId>org.springframework.boot</groupId>
+        <artifactId>spring-boot-starter-parent</artifactId>
+        <version>2.7.0</version>
+        <relativePath/>
+    </parent>
+
+    <dependencies>
+        <!-- Spring Boot Web Starter -->
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot-starter-web</artifactId>
+        </dependency>
+
+        <!-- MQTT Spring Boot Starter -->
+        <dependency>
+            <groupId>cn.hfln.framework</groupId>
+            <artifactId>mqtt-spring-boot-starter</artifactId>
+            <version>1.0.0-SNAPSHOT</version>
+        </dependency>
+
+        <!-- 如果遇到ClassNotFoundException,添加这些依赖 -->
+        <dependency>
+            <groupId>org.eclipse.paho</groupId>
+            <artifactId>org.eclipse.paho.client.mqttv3</artifactId>
+            <version>1.2.5</version>
+        </dependency>
+        <dependency>
+            <groupId>org.springframework.integration</groupId>
+            <artifactId>spring-integration-mqtt</artifactId>
+        </dependency>
+    </dependencies>
+
+    <build>
+        <plugins>
+            <plugin>
+                <groupId>org.springframework.boot</groupId>
+                <artifactId>spring-boot-maven-plugin</artifactId>
+            </plugin>
+        </plugins>
+    </build>
+</project>
+```
+
+## 3. application.yml
+```yaml
+server:
+  port: 8080
+
+spring:
+  application:
+    name: external-mqtt-app
+
+# MQTT配置
+mqtt:
+  enabled: true
+  broker: tcp://localhost:1883
+  client-id: external-app-${random.uuid}
+  fail-fast-on-initial-connection: false
+  automatic-reconnect: true
+  max-reconnect-attempts: 5
+  reconnect-interval: 3000
+
+# 日志配置
+logging:
+  level:
+    root: INFO
+    cn.hfln.framework.mqtt: DEBUG
+    org.springframework.integration.mqtt: WARN
+    org.eclipse.paho: WARN
+```
+
+## 4. Application.java
+```java
+package com.example;
+
+import org.springframework.boot.SpringApplication;
+import org.springframework.boot.autoconfigure.SpringBootApplication;
+
+@SpringBootApplication
+public class Application {
+    public static void main(String[] args) {
+        SpringApplication.run(Application.class, args);
+    }
+}
+```
+
+## 5. TestController.java
+```java
+package com.example.controller;
+
+import cn.hfln.framework.mqtt.template.MqttTemplate;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.RequestParam;
+import org.springframework.web.bind.annotation.RestController;
+
+@RestController
+public class TestController {
+
+    @Autowired
+    private MqttTemplate mqttTemplate;
+
+    @GetMapping("/send")
+    public String sendMessage(@RequestParam String topic, @RequestParam String message) {
+        try {
+            mqttTemplate.send(topic, message);
+            return "Message sent successfully to topic: " + topic;
+        } catch (Exception e) {
+            return "Failed to send message: " + e.getMessage();
+        }
+    }
+
+    @GetMapping("/health")
+    public String health() {
+        return "External MQTT App is running!";
+    }
+}
+```
+
+## 6. MqttConfig.java(可选的手动配置)
+```java
+package com.example.config;
+
+import cn.hfln.framework.mqtt.template.MqttTemplate;
+import cn.hfln.framework.mqtt.converter.JsonMessageConverter;
+import lombok.extern.slf4j.Slf4j;
+import org.eclipse.paho.client.mqttv3.MqttClient;
+import org.eclipse.paho.client.mqttv3.MqttException;
+import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;
+import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+
+import java.util.Collections;
+import java.util.UUID;
+
+@Slf4j
+@Configuration
+public class MqttConfig {
+
+    /**
+     * 备用MqttTemplate配置
+     * 如果自动配置失败,这个Bean会被创建
+     */
+    @Bean
+    @ConditionalOnMissingBean
+    public MqttTemplate backupMqttTemplate() {
+        log.warn("Creating backup MqttTemplate - auto-configuration may have failed");
+        try {
+            String clientId = "backup-client-" + UUID.randomUUID();
+            MqttClient mqttClient = new MqttClient("tcp://localhost:1883", clientId, new MemoryPersistence());
+            return new MqttTemplate(mqttClient, Collections.emptyList(), new JsonMessageConverter());
+        } catch (MqttException e) {
+            log.error("Failed to create backup MqttTemplate", e);
+            throw new RuntimeException("Failed to create backup MqttTemplate", e);
+        }
+    }
+}
+```
+
+## 7. 启动和测试
+
+### 启动应用
+```bash
+mvn spring-boot:run
+```
+
+### 测试API
+```bash
+# 健康检查
+curl http://localhost:8080/health
+
+# 发送MQTT消息
+curl "http://localhost:8080/send?topic=test/topic&message=Hello%20MQTT"
+```
+
+## 8. 故障排除
+
+### 如果看到以下日志,说明配置成功:
+```
+MqttSimpleAutoConfiguration initialized with broker: tcp://localhost:1883
+Creating MessageConverter bean
+Creating simplified MqttTemplate bean
+```
+
+### 如果没有看到上述日志,检查:
+1. `mqtt.enabled=true` 是否配置
+2. MQTT依赖是否正确添加
+3. 日志级别是否设置为DEBUG
+
+### 常见问题解决:
+- **ClassNotFoundException**: 添加明确的MQTT依赖
+- **Bean not found**: 启用调试日志,检查自动配置是否被激活
+- **Connection refused**: 启动MQTT服务器或配置为非强制连接 

+ 1 - 1
hfln-framework-design-starter/pom.xml

@@ -17,7 +17,7 @@
         <module>minio-spring-boot-starter</module>
         <module>xxl-spring-boot-starter</module>
         <module>mqtt-spring-boot-starter</module>
-<!--        <module>emqx-spring-boot-starter</module>-->
+        <module>redis-spring-boot-starter</module>
     </modules>
 
     <properties>

+ 60 - 0
hfln-framework-design-starter/redis-spring-boot-starter/pom.xml

@@ -0,0 +1,60 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0"
+         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+    <parent>
+        <artifactId>hfln-framework-design-starter</artifactId>
+        <groupId>cn.hfln.framework</groupId>
+        <version>1.0.0-SNAPSHOT</version>
+    </parent>
+    <modelVersion>4.0.0</modelVersion>
+    <artifactId>redis-spring-boot-starter</artifactId>
+    <name>redis-spring-boot-starter</name>
+    <description>通用 Redis Starter,自动装配,支持常用 Redis 操作</description>
+    <dependencies>
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot-starter-data-redis</artifactId>
+        </dependency>
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot-autoconfigure</artifactId>
+        </dependency>
+        <dependency>
+            <groupId>org.springframework</groupId>
+            <artifactId>spring-context</artifactId>
+        </dependency>
+        <dependency>
+            <groupId>org.springframework</groupId>
+            <artifactId>spring-core</artifactId>
+        </dependency>
+        <dependency>
+            <groupId>org.apache.commons</groupId>
+            <artifactId>commons-lang3</artifactId>
+        </dependency>
+        <!-- Jackson 依赖 -->
+        <dependency>
+            <groupId>com.fasterxml.jackson.core</groupId>
+            <artifactId>jackson-databind</artifactId>
+        </dependency>
+        <dependency>
+            <groupId>com.fasterxml.jackson.core</groupId>
+            <artifactId>jackson-core</artifactId>
+        </dependency>
+        <dependency>
+            <groupId>com.fasterxml.jackson.core</groupId>
+            <artifactId>jackson-annotations</artifactId>
+        </dependency>
+        <!-- 测试依赖 -->
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot-starter-test</artifactId>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.junit.jupiter</groupId>
+            <artifactId>junit-jupiter</artifactId>
+            <scope>test</scope>
+        </dependency>
+    </dependencies>
+</project> 

+ 25 - 0
hfln-framework-design-starter/redis-spring-boot-starter/src/main/java/cn/hfln/framework/redis/autoconfigure/AutoRedisConfiguration.java

@@ -0,0 +1,25 @@
+package cn.hfln.framework.redis.autoconfigure;
+
+import cn.hfln.framework.redis.util.RedisUtil;
+import cn.hfln.framework.redis.properties.RedisProperties;
+import org.springframework.boot.autoconfigure.AutoConfigureAfter;
+import org.springframework.boot.autoconfigure.condition.ConditionalOnBean;
+import org.springframework.boot.context.properties.EnableConfigurationProperties;
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+import org.springframework.data.redis.core.RedisTemplate;
+
+@Configuration
+@AutoConfigureAfter(name = "org.springframework.boot.autoconfigure.data.redis.RedisAutoConfiguration")
+@EnableConfigurationProperties(RedisProperties.class)
+public class AutoRedisConfiguration {
+
+    public AutoRedisConfiguration() {
+    }
+
+    @Bean
+    @ConditionalOnBean(RedisTemplate.class)
+    public RedisUtil redisUtil(RedisTemplate<String, Object> redisTemplate, RedisProperties redisProperties) {
+        return new RedisUtil(redisTemplate, redisProperties);
+    }
+}

+ 28 - 0
hfln-framework-design-starter/redis-spring-boot-starter/src/main/java/cn/hfln/framework/redis/properties/RedisProperties.java

@@ -0,0 +1,28 @@
+package cn.hfln.framework.redis.properties;
+
+import org.springframework.boot.context.properties.ConfigurationProperties;
+
+@ConfigurationProperties(prefix = "hfln.redis")
+public class RedisProperties {
+    /**
+     * key 前缀
+     */
+    private String keyPrefix = "";
+    /**
+     * 默认超时时间(秒)
+     */
+    private long defaultTimeout = 3600;
+
+    public String getKeyPrefix() {
+        return keyPrefix;
+    }
+    public void setKeyPrefix(String keyPrefix) {
+        this.keyPrefix = keyPrefix;
+    }
+    public long getDefaultTimeout() {
+        return defaultTimeout;
+    }
+    public void setDefaultTimeout(long defaultTimeout) {
+        this.defaultTimeout = defaultTimeout;
+    }
+} 

+ 114 - 0
hfln-framework-design-starter/redis-spring-boot-starter/src/main/java/cn/hfln/framework/redis/util/RedisUtil.java

@@ -0,0 +1,114 @@
+package cn.hfln.framework.redis.util;
+
+import cn.hfln.framework.redis.properties.RedisProperties;
+import org.springframework.data.redis.core.RedisTemplate;
+
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.concurrent.TimeUnit;
+
+/**
+ * Redis 工具类,封装常用操作,支持 key 前缀、默认超时、分布式锁等
+ */
+public class RedisUtil {
+    private final RedisTemplate<String, Object> redisTemplate;
+    private final RedisProperties redisProperties;
+
+    public RedisUtil(RedisTemplate<String, Object> redisTemplate, RedisProperties redisProperties) {
+        System.out.println("【RedisUtil】构造方法被调用");
+        this.redisTemplate = redisTemplate;
+        this.redisProperties = redisProperties;
+    }
+
+    private String wrapKey(String key) {
+        String prefix = redisProperties != null ? redisProperties.getKeyPrefix() : "";
+        return prefix + key;
+    }
+
+    // ============================= String ============================
+    public void set(String key, Object value) {
+        set(key, value, redisProperties != null ? redisProperties.getDefaultTimeout() : 3600, TimeUnit.SECONDS);
+    }
+    public void set(String key, Object value, long timeout, TimeUnit unit) {
+        redisTemplate.opsForValue().set(wrapKey(key), value, timeout, unit);
+    }
+    public Object get(String key) {
+        return redisTemplate.opsForValue().get(wrapKey(key));
+    }
+    public boolean del(String key) {
+        return Boolean.TRUE.equals(redisTemplate.delete(wrapKey(key)));
+    }
+
+    // ============================= Hash =============================
+    public void hSet(String key, String field, Object value) {
+        redisTemplate.opsForHash().put(wrapKey(key), field, value);
+    }
+    public Object hGet(String key, String field) {
+        return redisTemplate.opsForHash().get(wrapKey(key), field);
+    }
+    public Map<Object, Object> hGetAll(String key) {
+        return redisTemplate.opsForHash().entries(wrapKey(key));
+    }
+    public void hDel(String key, String... fields) {
+        redisTemplate.opsForHash().delete(wrapKey(key), (Object[]) fields);
+    }
+
+    // ============================= List =============================
+    public void lPush(String key, Object value) {
+        redisTemplate.opsForList().leftPush(wrapKey(key), value);
+    }
+    public Object lPop(String key) {
+        return redisTemplate.opsForList().leftPop(wrapKey(key));
+    }
+    public List<Object> lRange(String key, long start, long end) {
+        return redisTemplate.opsForList().range(wrapKey(key), start, end);
+    }
+
+    // ============================= Set ==============================
+    public void sAdd(String key, Object... values) {
+        redisTemplate.opsForSet().add(wrapKey(key), values);
+    }
+    public Set<Object> sMembers(String key) {
+        return redisTemplate.opsForSet().members(wrapKey(key));
+    }
+    public boolean sIsMember(String key, Object value) {
+        return Boolean.TRUE.equals(redisTemplate.opsForSet().isMember(wrapKey(key), value));
+    }
+
+    // ============================= ZSet =============================
+    public void zAdd(String key, Object value, double score) {
+        redisTemplate.opsForZSet().add(wrapKey(key), value, score);
+    }
+    public Set<Object> zRange(String key, long start, long end) {
+        return redisTemplate.opsForZSet().range(wrapKey(key), start, end);
+    }
+
+    // ============================= 通用 =============================
+    public boolean expire(String key, long timeout, TimeUnit unit) {
+        return Boolean.TRUE.equals(redisTemplate.expire(wrapKey(key), timeout, unit));
+    }
+    public long getExpire(String key, TimeUnit unit) {
+        return redisTemplate.getExpire(wrapKey(key), unit);
+    }
+    public boolean hasKey(String key) {
+        return Boolean.TRUE.equals(redisTemplate.hasKey(wrapKey(key)));
+    }
+
+    // ============================= 原子操作 =========================
+    public Long incr(String key) {
+        return redisTemplate.opsForValue().increment(wrapKey(key));
+    }
+    public Long incrBy(String key, long delta) {
+        return redisTemplate.opsForValue().increment(wrapKey(key), delta);
+    }
+
+    // ============================= 分布式锁(简单实现) =============
+    public boolean tryLock(String key, String value, long timeout, TimeUnit unit) {
+        Boolean success = redisTemplate.opsForValue().setIfAbsent(wrapKey(key), value, timeout, unit);
+        return Boolean.TRUE.equals(success);
+    }
+    public void unlock(String key) {
+        del(key);
+    }
+} 

+ 2 - 0
hfln-framework-design-starter/redis-spring-boot-starter/src/main/resources/META-INF/spring.factories

@@ -0,0 +1,2 @@
+org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
+cn.hfln.framework.redis.autoconfigure.AutoRedisConfiguration

+ 8 - 0
hfln-framework-design-starter/redis-spring-boot-starter/src/test/java/cn/hfln/framework/redis/RedisTestApplication.java

@@ -0,0 +1,8 @@
+package cn.hfln.framework.redis;
+
+import org.springframework.boot.autoconfigure.SpringBootApplication;
+
+@SpringBootApplication
+public class RedisTestApplication {
+    // 仅用于测试上下文启动,无需实现内容
+} 

+ 23 - 0
hfln-framework-design-starter/redis-spring-boot-starter/src/test/java/cn/hfln/framework/redis/RedisUtilIntegrationTest.java

@@ -0,0 +1,23 @@
+package cn.hfln.framework.redis;
+
+import cn.hfln.framework.redis.util.RedisUtil;
+import org.junit.jupiter.api.Test;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.boot.test.context.SpringBootTest;
+
+import static org.junit.jupiter.api.Assertions.*;
+
+@SpringBootTest(classes = RedisTestApplication.class)
+class RedisUtilIntegrationTest {
+
+    @Autowired
+    private RedisUtil redisUtil;
+
+    @Test
+    void testSetGetDel() {
+        redisUtil.set("testKey", "testValue");
+        Object value = redisUtil.get("testKey");
+        assertEquals("testValue", value);
+        redisUtil.del("testKey");
+    }
+} 

+ 4 - 0
hfln-framework-design-starter/redis-spring-boot-starter/src/test/resources/application.yml

@@ -0,0 +1,4 @@
+spring:
+  redis:
+    host: 8.130.28.21
+    port: 6379 

+ 33 - 0
temp_knife4j/deploy.ps1

@@ -0,0 +1,33 @@
+$repoUrl = "http://8.130.28.21:8081/nexus/repository/hfln_releases/"
+$files = Get-ChildItem -Path "lib" -Filter "*.jar"
+
+foreach ($file in $files) {
+    $groupId = switch -Wildcard ($file.Name) {
+        "knife4j-*" { "com.github.xiaoymin" }
+        "spring-*" { "org.springframework" }
+        "springdoc-*" { "org.springdoc" }
+        "swagger-*" { "io.swagger.core.v3" }
+        "jackson-*" { "com.fasterxml.jackson.core" }
+        "jakarta.*" { "jakarta.activation" }
+        "slf4j-*" { "org.slf4j" }
+        "lombok-*" { "org.projectlombok" }
+        "commons-*" { "org.apache.commons" }
+        "snakeyaml-*" { "org.yaml" }
+        "classgraph-*" { "io.github.classgraph" }
+        "reactive-streams-*" { "org.reactivestreams" }
+        "reactor-*" { "io.projectreactor" }
+        default { "com.github.xiaoymin" }
+    }
+    
+    if ($file.Name -match "^(.*?)-([0-9].*)\.jar$") {
+        $artifactId = $matches[1]
+        $version = $matches[2]
+        
+        Write-Host "Deploying $($file.Name)..."
+        Write-Host "GroupId: $groupId"
+        Write-Host "ArtifactId: $artifactId"
+        Write-Host "Version: $version"
+        
+        mvn deploy:deploy-file "-DgroupId=$groupId" "-DartifactId=$artifactId" "-Dversion=$version" "-Dpackaging=jar" "-Dfile=lib\$($file.Name)" "-Durl=$repoUrl" "-DrepositoryId=hfln_releases"
+    }
+} 

+ 616 - 0
temp_knife4j/lib/classgraph-4.8.149.pom

@@ -0,0 +1,616 @@
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+    <modelVersion>4.0.0</modelVersion>
+
+    <groupId>io.github.classgraph</groupId>
+    <artifactId>classgraph</artifactId>
+    <version>4.8.149</version>
+    <name>ClassGraph</name>
+
+    <description>The uber-fast, ultra-lightweight classpath and module scanner for JVM languages.</description>
+
+    <url>https://github.com/classgraph/classgraph</url>
+
+    <licenses>
+        <license>
+            <name>The MIT License (MIT)</name>
+            <url>http://opensource.org/licenses/MIT</url>
+            <distribution>repo</distribution>
+        </license>
+    </licenses>
+
+    <developers>
+        <developer>
+            <name>Luke Hutchison</name>
+            <email>luke.hutch@gmail.com</email>
+            <organization>ClassGraph</organization>
+            <organizationUrl>https://github.com/classgraph</organizationUrl>
+        </developer>
+    </developers>
+
+    <scm>
+        <connection>scm:git:git@github.com:classgraph/classgraph.git</connection>
+        <developerConnection>scm:git:git@github.com:classgraph/classgraph.git</developerConnection>
+        <url>https://github.com/classgraph/classgraph</url>
+      <tag>classgraph-4.8.149</tag>
+    </scm>
+
+    <issueManagement>
+        <url>https://github.com/classgraph/classgraph/issues</url>
+    </issueManagement>
+
+    <distributionManagement>
+        <snapshotRepository>
+            <id>ossrh</id>
+            <url>https://oss.sonatype.org/content/repositories/snapshots</url>
+        </snapshotRepository>
+        <repository>
+            <id>ossrh</id>
+            <url>https://oss.sonatype.org/service/local/staging/deploy/maven2/</url>
+        </repository>
+    </distributionManagement>
+
+    <properties>
+        <!-- Set UTF-8 encoding for Maven plugins and output -->
+        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
+        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
+
+        <!-- Default to generating Javadoc in HTML 4.01 format -->
+        <javadoc.html.version />
+
+        <!-- Warnings are disabled, in order to suppress warning about bootstrap classpath not being set -->
+        <!-- (which arises as a result of building for JDK 7 on JDK8+, allowing for use of @FunctionalInterface) -->
+        <!-- <maven.compiler.showWarnings>true</maven.compiler.showWarnings> -->
+        <!-- <maven.compiler.showDeprecation>true</maven.compiler.showDeprecation> -->
+    </properties>
+
+    <!-- Find dependency updates with: ./mvnw versions:display-dependency-updates -->
+    <dependencies>
+        <!-- Optional runtime dependency: -->
+        <dependency>
+            <groupId>io.github.toolfactory</groupId>
+            <artifactId>narcissus</artifactId>
+            <version>1.0.7</version>
+            <optional>true</optional>
+        </dependency>
+        <dependency>
+            <groupId>io.github.toolfactory</groupId>
+            <artifactId>jvm-driver</artifactId>
+            <version>8.9.6</version>
+            <optional>true</optional>
+        </dependency>
+
+        <!-- Test dependencies: -->
+        <dependency>
+            <groupId>org.junit.jupiter</groupId>
+            <artifactId>junit-jupiter</artifactId>
+            <version>5.8.2</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.openjdk.jmh</groupId>
+            <artifactId>jmh-core</artifactId>
+            <version>1.35</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.openjdk.jmh</groupId>
+            <artifactId>jmh-generator-annprocess</artifactId>
+            <version>1.35</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.assertj</groupId>
+            <artifactId>assertj-core</artifactId>
+            <version>3.22.0</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>javax.enterprise</groupId>
+            <artifactId>cdi-api</artifactId>
+            <version>2.0</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.ops4j.pax.url</groupId>
+            <artifactId>pax-url-aether</artifactId>
+            <version>2.6.1</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.slf4j</groupId>
+            <artifactId>slf4j-api</artifactId>
+            <version>2.0.0-alpha7</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.slf4j</groupId>
+            <artifactId>slf4j-jdk14</artifactId>
+            <version>2.0.0-alpha7</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.hibernate.javax.persistence</groupId>
+            <artifactId>hibernate-jpa-2.1-api</artifactId>
+            <version>1.0.2.Final</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>com.google.jimfs</groupId>
+            <artifactId>jimfs</artifactId>
+            <version>1.2</version>
+            <scope>test</scope>
+        </dependency>
+
+        <!-- "provided" dependencies (soft compile-time dependencies that do not create a runtime dependency): -->
+
+        <dependency>
+            <!-- Needed for Eclipse nullability analysis to work, but use "provided" as the scope so that we -->
+            <!-- don't add a hard dependency on the JDT annotations, because we don't use the annotations in -->
+            <!-- any of the ClassGraph code, so these annotations are not needed at runtime. -->
+            <!-- See: https://bugs.eclipse.org/bugs/show_bug.cgi?id=552198 -->
+            <groupId>org.eclipse.jdt</groupId>
+            <artifactId>org.eclipse.jdt.annotation</artifactId>
+            <version>2.2.600</version>
+            <scope>provided</scope>
+        </dependency>
+    </dependencies>
+
+    <build>
+        <plugins>
+            <!-- Plugins are listed here, but configured in pluginManagement, for compatibility with Eclipse. -->
+            <!-- See: https://stackoverflow.com/a/10483284/3950982 -->
+            <!-- Find plugin updates with: ./mvnw versions:display-plugin-updates -->
+            <!-- List order of plugin execution with: ./mvnw -Prelease fr.jcgay.maven.plugins:buildplan-maven-plugin:list-phase -->
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-enforcer-plugin</artifactId>
+                <version>3.0.0</version>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-resources-plugin</artifactId>
+                <version>3.2.0</version>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-compiler-plugin</artifactId>
+                <version>3.10.1</version>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-surefire-plugin</artifactId>
+                <version>3.0.0-M6</version>
+            </plugin>
+            <plugin>
+                <groupId>org.codehaus.mojo</groupId>
+                <artifactId>build-helper-maven-plugin</artifactId>
+                <version>3.3.0</version>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-jar-plugin</artifactId>
+                <version>3.2.2</version>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-antrun-plugin</artifactId>
+                <version>3.1.0</version><!--$NO-MVN-MAN-VER$ -->
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-source-plugin</artifactId>
+                <version>3.2.1</version>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-javadoc-plugin</artifactId>
+                <version>3.4.0</version>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-gpg-plugin</artifactId>
+                <version>3.0.1</version>
+            </plugin>
+            <plugin>
+                <groupId>org.sonatype.plugins</groupId>
+                <artifactId>nexus-staging-maven-plugin</artifactId>
+                <version>1.6.12</version>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-release-plugin</artifactId>
+                <version>3.0.0-M5</version>
+            </plugin>
+
+            <!-- Override versions of the following plugins, inherited from the super-pom, with latest versions -->
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-clean-plugin</artifactId>
+                <version>3.2.0</version>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-deploy-plugin</artifactId>
+                <version>3.0.0-M2</version>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-install-plugin</artifactId>
+                <version>3.0.0-M1</version>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-site-plugin</artifactId>
+                <version>3.12.0</version>
+            </plugin>
+        </plugins>
+
+        <pluginManagement>
+            <plugins>
+                <!-- Enforce minimum Maven version, and JDK 7 API -->
+                <plugin>
+                    <groupId>org.apache.maven.plugins</groupId>
+                    <artifactId>maven-enforcer-plugin</artifactId>
+                    <dependencies>
+                        <dependency>
+                            <groupId>org.codehaus.mojo</groupId>
+                            <artifactId>animal-sniffer-enforcer-rule</artifactId>
+                            <version>1.21</version>
+                        </dependency>
+                    </dependencies>
+                    <executions>
+                        <!-- Require Maven version. -->
+                        <execution>
+                            <id>enforce-versions</id>
+                            <phase>validate</phase>
+                            <goals>
+                                <goal>enforce</goal>
+                            </goals>
+                            <configuration>
+                                <rules>
+                                    <requireMavenVersion>
+                                        <version>[3.6.3,)</version>
+                                    </requireMavenVersion>
+                                </rules>
+                            </configuration>
+                        </execution>
+                        <!-- Check main project for compatibility with JDK 7 API -->
+                        <execution>
+                            <id>check-signatures</id>
+                            <phase>compile</phase>
+                            <goals>
+                                <goal>enforce</goal>
+                            </goals>
+                            <configuration>
+                                <rules>
+                                    <checkSignatureRule implementation="org.codehaus.mojo.animal_sniffer.enforcer.CheckSignatureRule">
+                                        <signature>
+                                            <groupId>org.codehaus.mojo.signature</groupId>
+                                            <artifactId>java17</artifactId>
+                                            <version>1.0</version>
+                                        </signature>
+                                    </checkSignatureRule>
+                                </rules>
+                            </configuration>
+                        </execution>
+                    </executions>
+                </plugin>
+
+                <plugin>
+                    <groupId>org.apache.maven.plugins</groupId>
+                    <artifactId>maven-resources-plugin</artifactId>
+                    <executions>
+                        <!-- Copy LICENSE-ClassGraph.txt to build root -->
+                        <execution>
+                            <id>copy-license-to-target</id>
+                            <phase>process-resources</phase>
+                            <goals>
+                                <goal>copy-resources</goal>
+                            </goals>
+                            <configuration>
+                                <outputDirectory>${project.build.outputDirectory}</outputDirectory>
+                                <resources>
+                                    <resource>
+                                        <directory>${basedir}</directory>
+                                        <filtering>false</filtering>
+                                        <includes>
+                                            <include>LICENSE-ClassGraph.txt</include>
+                                        </includes>
+                                    </resource>
+                                </resources>
+                            </configuration>
+                        </execution>
+                        <execution>
+                            <id>copy-license-to-javadocs</id>
+                            <phase>process-resources</phase>
+                            <goals>
+                                <goal>copy-resources</goal>
+                            </goals>
+                            <configuration>
+                                <outputDirectory>${project.build.directory}/apidocs</outputDirectory>
+                                <resources>
+                                    <resource>
+                                        <directory>${basedir}</directory>
+                                        <filtering>false</filtering>
+                                        <includes>
+                                            <include>LICENSE-ClassGraph.txt</include>
+                                        </includes>
+                                    </resource>
+                                </resources>
+                            </configuration>
+                        </execution>
+                    </executions>
+                </plugin>
+
+                <plugin>
+                    <groupId>org.apache.maven.plugins</groupId>
+                    <artifactId>maven-antrun-plugin</artifactId>
+                    <executions>
+                        <execution>
+                            <!-- Put module-info.class in META-INF/versions/9 to maximize backwards -->
+                            <!-- compatibility. This has to be done after the jar is created, since -->
+                            <!-- module-info.class cannot be copied to the target directory, otherwise -->
+                            <!-- this build or the following incremental build will cause Animal Sniffer -->
+                            <!-- to fail, since it depends upon ASM 5, which balks when it hits -->
+                            <!-- module-info.class with: "Execution check-signatures of goal -->
+                            <!-- org.apache.maven.plugins:maven-enforcer-plugin:3.0.0-M3:enforce failed: -->
+                            <!-- This feature requires ASM6". -->
+                            <id>add-module-info-to-jar</id>
+                            <phase>package</phase>
+                            <goals>
+                                <goal>run</goal>
+                            </goals>
+                            <configuration>
+                                <target>
+                                    <jar update="true" destfile="${project.build.directory}/${project.build.finalName}.jar">
+                                        <zipfileset prefix="META-INF/versions/9" dir="${project.basedir}/src/module-info/io.github.classgraph" includes="module-info.class" />
+                                    </jar>
+                                </target>
+                            </configuration>
+                        </execution>
+                        <execution>
+                            <!-- Make duplicate copy of Javadoc into a subdirectory with the name of the module, -->
+                            <!-- since Eclipse (and possibly other tools) detects the presence of the module -->
+                            <!-- descriptor, and expects the Javadoc files to use modular paths (#583). -->
+                            <!-- Needs to happen before maven-gpg-plugin runs, otherwise signature will be invalid. -->
+                            <id>add-modular-javadoc</id>
+                            <phase>verify</phase>
+                            <goals>
+                                <goal>run</goal>
+                            </goals>
+                            <configuration>
+                                <target>
+                                    <jar update="true" destfile="${project.build.directory}/${project.build.finalName}-javadoc.jar">
+                                        <zipfileset prefix="io.github.classgraph" dir="${project.build.directory}/apidocs" includes="**/*" />
+                                    </jar>
+                                </target>
+                            </configuration>
+                        </execution>
+                    </executions>
+                </plugin>
+
+                <!-- Compile sources (main for JDK 7, test for JDK 8) -->
+                <plugin>
+                    <groupId>org.apache.maven.plugins</groupId>
+                    <artifactId>maven-compiler-plugin</artifactId>
+                    <configuration>
+                        <encoding>UTF-8</encoding>
+                        <!-- Can't use "release" option, because ClassGraph needs to be built in JDK 7 -->
+                        <!-- compatibility mode, and the @FunctionalInterface annotation was not available -->
+                        <!-- in JDK 7. If building with "source" and "target" switches, unknown annotations -->
+                        <!-- compile fine as long as they exist in the compiling JDK (in this case, JDK 8+). -->
+                        <!-- Missing annotations don't trigger a linkage error or ClassNotFoundException -->
+                        <!-- unless the annotation is actually read. -->
+                        <!-- However, note that not explicitly specifying a JDK 7 rt.jar as the bootstrap -->
+                        <!-- classpath (in order to build on a newer JDK, which does have @FunctionalInterface) -->
+                        <!-- will lead to the following build-time warning, if maven.compiler.showWarnings -->
+                        <!-- is set to true: -->
+                        <!-- "[WARNING] bootstrap class path not set in conjunction with -source 7" -->
+                        <source>7</source>
+                        <target>7</target>
+                        <!-- Tests use some JDK 8 features, such as lambdas -->
+                        <testSource>8</testSource>
+                        <testTarget>8</testTarget>
+                        <useIncrementalCompilation>false</useIncrementalCompilation>
+                        <compilerArgs>
+                            <arg>-Xlint:all</arg>
+                            <arg>-Werror</arg>
+                        </compilerArgs>
+                    </configuration>
+                    <executions>
+                        <execution>
+                            <id>default-testCompile</id>
+                            <phase>test-compile</phase>
+                            <goals>
+                                <goal>testCompile</goal>
+                            </goals>
+                            <configuration>
+                                <encoding>UTF-8</encoding>
+                                <!-- Tests use some JDK 8 features, such as lambdas -->
+                                <source>8</source>
+                                <target>8</target>
+                                <compilerArgs>
+                                    <arg>-parameters</arg>
+                                </compilerArgs>
+                            </configuration>
+                        </execution>
+                    </executions>
+                </plugin>
+
+                <!-- Execute unit tests -->
+                <plugin>
+                    <groupId>org.apache.maven.plugins</groupId>
+                    <artifactId>maven-surefire-plugin</artifactId>
+                </plugin>
+
+                <!-- Add src/test/perf to test sources -->
+                <plugin>
+                    <groupId>org.codehaus.mojo</groupId>
+                    <artifactId>build-helper-maven-plugin</artifactId>
+                    <executions>
+                        <execution>
+                            <id>add-test-source</id>
+                            <phase>generate-test-sources</phase>
+                            <goals>
+                                <goal>add-test-source</goal>
+                            </goals>
+                            <configuration>
+                                <sources>
+                                    <source>src/test/perf</source>
+                                </sources>
+                            </configuration>
+                        </execution>
+                    </executions>
+                </plugin>
+
+                <!-- Create binary jar -->
+                <plugin>
+                    <groupId>org.apache.maven.plugins</groupId>
+                    <artifactId>maven-jar-plugin</artifactId>
+                    <configuration>
+                        <forceCreation>true</forceCreation>
+                        <archive>
+                            <forced>true</forced>
+                            <manifest>
+                                <addDefaultImplementationEntries>true</addDefaultImplementationEntries>
+                                <addDefaultSpecificationEntries>true</addDefaultSpecificationEntries>
+                            </manifest>
+                            <manifestEntries>
+                                <!-- Add OSGi bundle attributes to manifest -->
+                                <Bundle-Category>Utilities</Bundle-Category>
+                                <Bundle-License>http://opensource.org/licenses/MIT</Bundle-License>
+                                <Bundle-ManifestVersion>2</Bundle-ManifestVersion>
+                                <Bundle-Name>ClassGraph</Bundle-Name>
+                                <Bundle-SymbolicName>${project.groupId}.${project.artifactId}</Bundle-SymbolicName>
+                                <Bundle-Vendor>Luke Hutchison</Bundle-Vendor>
+                                <Bundle-Description>${project.description}</Bundle-Description>
+                                <Bundle-Version>${project.version}</Bundle-Version>
+                                <Require-Capability>osgi.ee;filter:="(&amp;(osgi.ee=JavaSE)(version=1.7))"</Require-Capability>
+                                <Export-Package>io.github.classgraph;version="${project.version}"</Export-Package>
+                                <!-- Make sure "requires" entries in the module descriptor match these imports: -->
+                                <!-- src/main/module-info/io.github.classgraph/module-info.java -->
+                                <Import-Package>javax.xml.xpath,javax.xml.namespace,javax.xml.parsers,org.w3c.dom,sun.misc;resolution:="optional",sun.nio.ch;resolution:="optional",io.github.toolfactory.narcissus;resolution:="optional",io.github.toolfactory.jvm;resolution:="optional"</Import-Package>
+                                <!-- This is a multi-release jar, since module-info.class will be added to -->
+                                <!-- META-INF/versions/9 , so we need to set the Multi-Release entry to true -->
+                                <Multi-Release>true</Multi-Release>
+                            </manifestEntries>
+                        </archive>
+                    </configuration>
+                </plugin>
+
+                <!-- Create source jar -->
+                <plugin>
+                    <groupId>org.apache.maven.plugins</groupId>
+                    <artifactId>maven-source-plugin</artifactId>
+                    <executions>
+                        <execution>
+                            <id>attach-sources</id>
+                            <phase>package</phase>
+                            <goals>
+                                <goal>jar-no-fork</goal>
+                            </goals>
+                        </execution>
+                    </executions>
+                </plugin>
+
+                <!-- Create Javadoc jar -->
+                <plugin>
+                    <groupId>org.apache.maven.plugins</groupId>
+                    <artifactId>maven-javadoc-plugin</artifactId>
+                    <executions>
+                        <execution>
+                            <id>attach-javadocs</id>
+                            <phase>package</phase>
+                            <goals>
+                                <goal>jar</goal>
+                            </goals>
+                            <configuration>
+                                <source>8</source>
+                                <additionalOptions>${javadoc.html.version}</additionalOptions>
+                                <doclint>all</doclint>
+                                <excludePackageNames>nonapi.*</excludePackageNames>
+                                <show>public</show>
+                            </configuration>
+                        </execution>
+                    </executions>
+                </plugin>
+
+                <!-- Stage jars on Sonatype Nexus -->
+                <!-- See: http://java.dzone.com/articles/deploy-maven-central -->
+                <!-- and: http://central.sonatype.org/pages/apache-maven.html -->
+                <plugin>
+                    <groupId>org.sonatype.plugins</groupId>
+                    <artifactId>nexus-staging-maven-plugin</artifactId>
+                    <extensions>true</extensions>
+                    <configuration>
+                        <serverId>ossrh</serverId>
+                        <nexusUrl>https://oss.sonatype.org/</nexusUrl>
+                        <autoReleaseAfterClose>true</autoReleaseAfterClose>
+                        <stagingProgressTimeoutMinutes>10</stagingProgressTimeoutMinutes>
+                    </configuration>
+                </plugin>
+
+                <!-- Deploy jars -->
+                <plugin>
+                    <groupId>org.apache.maven.plugins</groupId>
+                    <artifactId>maven-release-plugin</artifactId>
+                    <configuration>
+                        <phase>deploy</phase>
+                        <goals>deploy</goals>
+                        <autoVersionSubmodules>true</autoVersionSubmodules>
+                        <!-- Activate release profile -->
+                        <releaseProfiles>release</releaseProfiles>
+                        <!-- Work around bug where releaseProfiles tag doesn't actually work yet -->
+                        <arguments>-Prelease</arguments>
+                    </configuration>
+                </plugin>
+            </plugins>
+        </pluginManagement>
+    </build>
+
+    <profiles>
+        <!-- Compile Javadoc to HTML5 if building with JDK 9+ -->
+        <profile>
+            <id>jdk9plus</id>
+            <properties>
+                <javadoc.html.version>-html5</javadoc.html.version>
+                <!-- coverall version 4.3.0 does not work with java 9. -->
+                <!-- See: https://github.com/trautonen/coveralls-maven-plugin/issues/112 -->
+                <coveralls.skip>true</coveralls.skip>
+            </properties>
+            <activation>
+                <jdk>[9,)</jdk>
+            </activation>
+        </profile>
+
+        <!-- Sign jars for release (./mvnw clean release:prepare release:perform) -->
+        <profile>
+            <id>release</id>
+            <build>
+                <plugins>
+                    <plugin>
+                        <groupId>org.apache.maven.plugins</groupId>
+                        <artifactId>maven-gpg-plugin</artifactId>
+                        <configuration>
+                            <gpgArguments>
+                                <arg>--pinentry-mode</arg>
+                                <arg>loopback</arg>
+                            </gpgArguments>
+                            <keyname>${gpg.keyname}</keyname>
+                            <passphraseServerId>${gpg.keyname}</passphraseServerId>
+                        </configuration>
+                        <executions>
+                            <execution>
+                                <id>sign-artifacts</id>
+                                <phase>verify</phase>
+                                <goals>
+                                    <goal>sign</goal>
+                                </goals>
+                            </execution>
+                        </executions>
+                    </plugin>
+                </plugins>
+            </build>
+        </profile>
+    </profiles>
+</project>

+ 1008 - 0
temp_knife4j/lib/commons-lang3-3.12.0.pom

@@ -0,0 +1,1008 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+ Licensed to the Apache Software Foundation (ASF) under one or more
+ contributor license agreements.  See the NOTICE file distributed with
+ this work for additional information regarding copyright ownership.
+ The ASF licenses this file to You under the Apache License, Version 2.0
+ (the "License"); you may not use this file except in compliance with
+ the License.  You may obtain a copy of the License at
+
+      http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+-->
+<project
+  xmlns="http://maven.apache.org/POM/4.0.0"
+  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
+  <parent>
+    <groupId>org.apache.commons</groupId>
+    <artifactId>commons-parent</artifactId>
+    <version>52</version>
+  </parent>
+  <modelVersion>4.0.0</modelVersion>
+  <artifactId>commons-lang3</artifactId>
+  <version>3.12.0</version>
+  <name>Apache Commons Lang</name>
+
+  <inceptionYear>2001</inceptionYear>
+  <description>
+  Apache Commons Lang, a package of Java utility classes for the
+  classes that are in java.lang's hierarchy, or are considered to be so
+  standard as to justify existence in java.lang.
+  </description>
+
+  <url>https://commons.apache.org/proper/commons-lang/</url>
+
+  <issueManagement>
+    <system>jira</system>
+    <url>https://issues.apache.org/jira/browse/LANG</url>
+  </issueManagement>
+
+  <scm>
+    <connection>scm:git:http://gitbox.apache.org/repos/asf/commons-lang.git</connection>
+    <developerConnection>scm:git:https://gitbox.apache.org/repos/asf/commons-lang.git</developerConnection>
+    <url>https://gitbox.apache.org/repos/asf?p=commons-lang.git</url>
+    <tag>commons-lang-3.12.0</tag>
+  </scm>
+
+  <developers>
+    <developer>
+      <name>Daniel Rall</name>
+      <id>dlr</id>
+      <email>dlr@finemaltcoding.com</email>
+      <organization>CollabNet, Inc.</organization>
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+    </developer>
+    <developer>
+      <name>Stephen Colebourne</name>
+      <id>scolebourne</id>
+      <email>scolebourne@joda.org</email>
+      <organization>SITA ATS Ltd</organization>
+      <timezone>0</timezone>
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+    </developer>
+    <developer>
+      <name>Henri Yandell</name>
+      <id>bayard</id>
+      <email>bayard@apache.org</email>
+      <organization />
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+    </developer>
+    <developer>
+      <name>Steven Caswell</name>
+      <id>scaswell</id>
+      <email>stevencaswell@apache.org</email>
+      <organization />
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+      <timezone>-5</timezone>
+    </developer>
+    <developer>
+      <name>Robert Burrell Donkin</name>
+      <id>rdonkin</id>
+      <email>rdonkin@apache.org</email>
+      <organization />
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+    </developer>
+    <developer>
+      <name>Gary D. Gregory</name>
+      <id>ggregory</id>
+      <email>ggregory@apache.org</email>
+      <timezone>-5</timezone>
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+    </developer>
+    <developer>
+      <name>Fredrik Westermarck</name>
+      <id>fredrik</id>
+      <email />
+      <organization />
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+    </developer>
+    <developer>
+      <name>James Carman</name>
+      <id>jcarman</id>
+      <email>jcarman@apache.org</email>
+      <organization>Carman Consulting, Inc.</organization>
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+    </developer>
+    <developer>
+      <name>Niall Pemberton</name>
+      <id>niallp</id>
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+    </developer>
+    <developer>
+      <name>Matt Benson</name>
+      <id>mbenson</id>
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+    </developer>
+    <developer>
+      <name>Joerg Schaible</name>
+      <id>joehni</id>
+      <email>joerg.schaible@gmx.de</email>
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+      <timezone>+1</timezone>
+    </developer>
+    <developer>
+      <name>Oliver Heger</name>
+      <id>oheger</id>
+      <email>oheger@apache.org</email>
+      <timezone>+1</timezone>
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+    </developer>
+    <developer>
+      <name>Paul Benedict</name>
+      <id>pbenedict</id>
+      <email>pbenedict@apache.org</email>
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+    </developer>
+    <developer>
+      <name>Benedikt Ritter</name>
+      <id>britter</id>
+      <email>britter@apache.org</email>
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+    </developer>
+    <developer>
+      <name>Duncan Jones</name>
+      <id>djones</id>
+      <email>djones@apache.org</email>
+      <timezone>0</timezone>
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+    </developer>
+    <developer>
+      <name>Loic Guibert</name>
+      <id>lguibert</id>
+      <email>lguibert@apache.org</email>
+      <timezone>+4</timezone>
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+    </developer>
+    <developer>
+      <name>Rob Tompkins</name>
+      <id>chtompki</id>
+      <email>chtompki@apache.org</email>
+      <timezone>-5</timezone>
+      <roles>
+        <role>Java Developer</role>
+      </roles>
+    </developer>
+  </developers>
+  <contributors>
+    <contributor>
+      <name>C. Scott Ananian</name>
+    </contributor>
+    <contributor>
+      <name>Chris Audley</name>
+    </contributor>
+    <contributor>
+      <name>Stephane Bailliez</name>
+    </contributor>
+    <contributor>
+      <name>Michael Becke</name>
+    </contributor>
+    <contributor>
+      <name>Benjamin Bentmann</name>
+    </contributor>
+    <contributor>
+      <name>Ola Berg</name>
+    </contributor>
+    <contributor>
+      <name>Nathan Beyer</name>
+    </contributor>
+    <contributor>
+      <name>Stefan Bodewig</name>
+    </contributor>
+    <contributor>
+      <name>Janek Bogucki</name>
+    </contributor>
+    <contributor>
+      <name>Mike Bowler</name>
+    </contributor>
+    <contributor>
+      <name>Sean Brown</name>
+    </contributor>
+    <contributor>
+      <name>Alexander Day Chaffee</name>
+    </contributor>
+    <contributor>
+      <name>Al Chou</name>
+    </contributor>
+    <contributor>
+      <name>Greg Coladonato</name>
+    </contributor>
+    <contributor>
+      <name>Maarten Coene</name>
+    </contributor>
+    <contributor>
+      <name>Justin Couch</name>
+    </contributor>
+    <contributor>
+      <name>Michael Davey</name>
+    </contributor>
+    <contributor>
+      <name>Norm Deane</name>
+    </contributor>
+    <contributor>
+      <name>Morgan Delagrange</name>
+    </contributor>
+    <contributor>
+      <name>Ringo De Smet</name>
+    </contributor>
+    <contributor>
+      <name>Russel Dittmar</name>
+    </contributor>
+    <contributor>
+      <name>Steve Downey</name>
+    </contributor>
+    <contributor>
+      <name>Matthias Eichel</name>
+    </contributor>
+    <contributor>
+      <name>Christopher Elkins</name>
+    </contributor>
+    <contributor>
+      <name>Chris Feldhacker</name>
+    </contributor>
+    <contributor>
+      <name>Roland Foerther</name>
+    </contributor>
+    <contributor>
+      <name>Pete Gieser</name>
+    </contributor>
+    <contributor>
+      <name>Jason Gritman</name>
+    </contributor>
+    <contributor>
+      <name>Matthew Hawthorne</name>
+    </contributor>
+    <contributor>
+      <name>Michael Heuer</name>
+    </contributor>
+    <contributor>
+      <name>Chas Honton</name>
+    </contributor>
+    <contributor>
+      <name>Chris Hyzer</name>
+    </contributor>
+    <contributor>
+      <name>Paul Jack</name>
+    </contributor>
+    <contributor>
+      <name>Marc Johnson</name>
+    </contributor>
+    <contributor>
+      <name>Shaun Kalley</name>
+    </contributor>
+    <contributor>
+      <name>Tetsuya Kaneuchi</name>
+    </contributor>
+    <contributor>
+      <name>Nissim Karpenstein</name>
+    </contributor>
+    <contributor>
+      <name>Ed Korthof</name>
+    </contributor>
+    <contributor>
+      <name>Holger Krauth</name>
+    </contributor>
+    <contributor>
+      <name>Rafal Krupinski</name>
+    </contributor>
+    <contributor>
+      <name>Rafal Krzewski</name>
+    </contributor>
+    <contributor>
+      <name>David Leppik</name>
+    </contributor>
+    <contributor>
+      <name>Eli Lindsey</name>
+    </contributor>
+    <contributor>
+      <name>Sven Ludwig</name>
+    </contributor>
+    <contributor>
+      <name>Craig R. McClanahan</name>
+    </contributor>
+    <contributor>
+      <name>Rand McNeely</name>
+    </contributor>
+    <contributor>
+      <name>Hendrik Maryns</name>
+    </contributor>
+    <contributor>
+      <name>Dave Meikle</name>
+    </contributor>
+    <contributor>
+      <name>Nikolay Metchev</name>
+    </contributor>
+    <contributor>
+      <name>Kasper Nielsen</name>
+    </contributor>
+    <contributor>
+      <name>Tim O'Brien</name>
+    </contributor>
+    <contributor>
+      <name>Brian S O'Neill</name>
+    </contributor>
+    <contributor>
+      <name>Andrew C. Oliver</name>
+    </contributor>
+    <contributor>
+      <name>Alban Peignier</name>
+    </contributor>
+    <contributor>
+      <name>Moritz Petersen</name>
+    </contributor>
+    <contributor>
+      <name>Dmitri Plotnikov</name>
+    </contributor>
+    <contributor>
+      <name>Neeme Praks</name>
+    </contributor>
+    <contributor>
+      <name>Eric Pugh</name>
+    </contributor>
+    <contributor>
+      <name>Stephen Putman</name>
+    </contributor>
+    <contributor>
+      <name>Travis Reeder</name>
+    </contributor>
+    <contributor>
+      <name>Antony Riley</name>
+    </contributor>
+    <contributor>
+      <name>Valentin Rocher</name>
+    </contributor>
+    <contributor>
+      <name>Scott Sanders</name>
+    </contributor>
+    <contributor>
+      <name>James Sawle</name>
+    </contributor>
+    <contributor>
+      <name>Ralph Schaer</name>
+    </contributor>
+    <contributor>
+      <name>Henning P. Schmiedehausen</name>
+    </contributor>
+    <contributor>
+      <name>Sean Schofield</name>
+    </contributor>
+    <contributor>
+      <name>Robert Scholte</name>
+    </contributor>
+    <contributor>
+      <name>Reuben Sivan</name>
+    </contributor>
+    <contributor>
+      <name>Ville Skytta</name>
+    </contributor>
+    <contributor>
+      <name>David M. Sledge</name>
+    </contributor>
+    <contributor>
+      <name>Michael A. Smith</name>
+    </contributor>
+    <contributor>
+      <name>Jan Sorensen</name>
+    </contributor>
+    <contributor>
+      <name>Glen Stampoultzis</name>
+    </contributor>
+    <contributor>
+      <name>Scott Stanchfield</name>
+    </contributor>
+    <contributor>
+      <name>Jon S. Stevens</name>
+    </contributor>
+    <contributor>
+      <name>Sean C. Sullivan</name>
+    </contributor>
+    <contributor>
+      <name>Ashwin Suresh</name>
+    </contributor>
+    <contributor>
+      <name>Helge Tesgaard</name>
+    </contributor>
+    <contributor>
+      <name>Arun Mammen Thomas</name>
+    </contributor>
+    <contributor>
+      <name>Masato Tezuka</name>
+    </contributor>
+    <contributor>
+      <name>Daniel Trebbien</name>
+    </contributor>
+    <contributor>
+      <name>Jeff Varszegi</name>
+    </contributor>
+    <contributor>
+      <name>Chris Webb</name>
+    </contributor>
+    <contributor>
+      <name>Mario Winterer</name>
+    </contributor>
+    <contributor>
+      <name>Stepan Koltsov</name>
+    </contributor>
+    <contributor>
+      <name>Holger Hoffstatte</name>
+    </contributor>
+    <contributor>
+      <name>Derek C. Ashmore</name>
+    </contributor>
+    <contributor>
+      <name>Sebastien Riou</name>
+    </contributor>
+    <contributor>
+      <name>Allon Mureinik</name>
+    </contributor>
+    <contributor>
+      <name>Adam Hooper</name>
+    </contributor>
+    <contributor>
+      <name>Chris Karcher</name>
+    </contributor>
+    <contributor>
+      <name>Michael Osipov</name>
+    </contributor>
+    <contributor>
+      <name>Thiago Andrade</name>
+    </contributor>
+    <contributor>
+      <name>Jonathan Baker</name>
+    </contributor>
+    <contributor>
+      <name>Mikhail Mazursky</name>
+    </contributor>
+    <contributor>
+      <name>Fabian Lange</name>
+    </contributor>
+    <contributor>
+      <name>Michał Kordas</name>
+    </contributor>
+    <contributor>
+      <name>Felipe Adorno</name>
+    </contributor>
+    <contributor>
+      <name>Adrian Ber</name>
+    </contributor>
+    <contributor>
+      <name>Mark Dacek</name>
+    </contributor>
+    <contributor>
+      <name>Peter Verhas</name>
+    </contributor>
+    <contributor>
+      <name>Jin Xu</name>
+    </contributor>
+  </contributors>
+
+  <dependencyManagement>
+    <dependencies>
+      <dependency>
+        <groupId>org.junit</groupId>
+        <artifactId>junit-bom</artifactId>
+        <version>5.7.1</version>
+        <type>pom</type>
+        <scope>import</scope>
+      </dependency>
+    </dependencies>
+  </dependencyManagement>
+
+  <!-- Lang should depend on very little -->
+  <dependencies>
+    <!-- testing -->
+    <dependency>
+      <groupId>org.junit.jupiter</groupId>
+      <artifactId>junit-jupiter</artifactId>
+      <scope>test</scope>
+    </dependency>
+    <dependency>
+      <groupId>org.junit-pioneer</groupId>
+      <artifactId>junit-pioneer</artifactId>
+      <version>1.3.0</version>
+      <scope>test</scope>
+    </dependency>
+    <dependency>
+      <groupId>org.hamcrest</groupId>
+      <artifactId>hamcrest</artifactId>
+      <version>2.2</version>
+      <scope>test</scope>
+    </dependency>
+
+    <dependency>
+      <groupId>org.easymock</groupId>
+      <artifactId>easymock</artifactId>
+      <version>4.2</version>
+      <scope>test</scope>
+    </dependency>
+
+    <dependency>
+      <groupId>org.openjdk.jmh</groupId>
+      <artifactId>jmh-core</artifactId>
+      <version>${jmh.version}</version>
+      <scope>test</scope>
+    </dependency>
+
+    <dependency>
+      <groupId>org.openjdk.jmh</groupId>
+      <artifactId>jmh-generator-annprocess</artifactId>
+      <version>${jmh.version}</version>
+      <scope>test</scope>
+    </dependency>
+    <dependency>
+      <groupId>com.google.code.findbugs</groupId>
+      <artifactId>jsr305</artifactId>
+      <version>3.0.2</version>
+      <scope>test</scope>
+    </dependency>
+  </dependencies>
+
+  <distributionManagement>
+    <site>
+      <id>apache.website</id>
+      <name>Apache Commons Site</name>
+      <url>scm:svn:https://svn.apache.org/repos/infra/websites/production/commons/content/proper/commons-lang/</url>
+    </site>
+  </distributionManagement>
+
+  <properties>
+    <argLine>-Xmx512m</argLine>
+    <project.build.sourceEncoding>ISO-8859-1</project.build.sourceEncoding>
+    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
+    <maven.compiler.source>1.8</maven.compiler.source>
+    <maven.compiler.target>1.8</maven.compiler.target>
+    <!--
+       This is also  used to generate download_xxx file name.
+       To override this when generating the download page:
+
+       mvn commons:download-page -Dcommons.componentid=lang
+
+       The above seems to change the download page name but not any other
+       properties that depend on the componentid.
+
+       N.B. The componentid is also used by the parent pom as part of the OSGI symbolic name.
+    -->
+    <commons.componentid>lang</commons.componentid>
+    <commons.packageId>lang3</commons.packageId>
+    <commons.module.name>org.apache.commons.lang3</commons.module.name>
+    <!-- Current 3.x release series -->
+    <commons.release.version>3.12.0</commons.release.version>
+    <commons.release.desc>(Java 8+)</commons.release.desc>
+    <!-- Previous 2.x release series -->
+    <commons.release.2.version>2.6</commons.release.2.version>
+    <commons.release.2.desc>(Requires Java 1.2 or later)</commons.release.2.desc>
+    <!-- Override generated name -->
+    <commons.release.2.name>commons-lang-${commons.release.2.version}</commons.release.2.name>
+    <commons.jira.id>LANG</commons.jira.id>
+    <commons.jira.pid>12310481</commons.jira.pid>
+
+    <commons.site.path>lang</commons.site.path>
+    <commons.scmPubUrl>https://svn.apache.org/repos/infra/websites/production/commons/content/proper/commons-lang</commons.scmPubUrl>
+    <commons.scmPubCheckoutDirectory>site-content</commons.scmPubCheckoutDirectory>
+    <commons.encoding>utf-8</commons.encoding>
+
+    <checkstyle.plugin.version>3.1.2</checkstyle.plugin.version>
+    <checkstyle.version>8.40</checkstyle.version>
+    <checkstyle.configdir>src/site/resources/checkstyle</checkstyle.configdir>
+
+    <spotbugs.plugin.version>4.2.0</spotbugs.plugin.version>
+    <spotbugs.impl.version>4.2.1</spotbugs.impl.version>
+    <japicmp.skip>false</japicmp.skip>
+    <clirr.skip>true</clirr.skip>
+
+    <!-- JMH Benchmark related properties, version, target compiler and name of the benchmarking uber jar. -->
+    <jmh.version>1.27</jmh.version>
+    <uberjar.name>benchmarks</uberjar.name>
+
+    <commons.jacoco.version>0.8.6</commons.jacoco.version>
+    <commons.surefire.version>3.0.0-M5</commons.surefire.version>
+    <commons.javadoc.version>3.2.0</commons.javadoc.version>
+    <commons.japicmp.version>0.15.2</commons.japicmp.version>
+
+    <!-- Commons Release Plugin -->
+    <commons.bc.version>3.11</commons.bc.version>
+    <commons.rc.version>RC1</commons.rc.version>
+    <commons.release.isDistModule>true</commons.release.isDistModule>
+    <commons.distSvnStagingUrl>scm:svn:https://dist.apache.org/repos/dist/dev/commons/lang</commons.distSvnStagingUrl>
+    <commons.releaseManagerName>Gary Gregory</commons.releaseManagerName>    
+    <commons.releaseManagerKey>86fdc7e2a11262cb</commons.releaseManagerKey>
+  </properties>
+
+
+  <build>
+   <defaultGoal>clean package apache-rat:check checkstyle:check japicmp:cmp spotbugs:check javadoc:javadoc</defaultGoal>
+   <pluginManagement>
+      <plugins>
+        <plugin>
+          <groupId>org.apache.rat</groupId>
+          <artifactId>apache-rat-plugin</artifactId>
+          <configuration>
+            <excludes>
+              <exclude>site-content/**</exclude>
+              <exclude>src/site/resources/.htaccess</exclude>
+              <exclude>src/site/resources/download_lang.cgi</exclude>
+              <exclude>src/site/resources/release-notes/RELEASE-NOTES-*.txt</exclude>
+              <exclude>src/test/resources/lang-708-input.txt</exclude>
+            </excludes>
+          </configuration>
+        </plugin>
+      </plugins>
+    </pluginManagement>
+    <plugins>
+      <plugin>
+        <artifactId>maven-javadoc-plugin</artifactId>
+        <configuration>
+          <source>${maven.compiler.source}</source>
+          <quiet>true</quiet>
+          <notimestamp>true</notimestamp>
+          <links>
+            <link>https://docs.oracle.com/javase/8/docs/api/</link>
+            <link>http://docs.oracle.com/javaee/6/api/</link>
+          </links>
+          <archive>
+            <manifest>
+              <addDefaultImplementationEntries>true</addDefaultImplementationEntries>
+              <addDefaultSpecificationEntries>true</addDefaultSpecificationEntries>
+            </manifest>
+          </archive>
+        </configuration>
+        <executions>
+          <execution>
+            <id>create-javadoc-jar</id>
+            <goals>
+              <goal>javadoc</goal>
+              <goal>jar</goal>
+            </goals>
+            <phase>package</phase>
+          </execution>
+        </executions>
+      </plugin>
+      <plugin>
+        <groupId>org.apache.maven.plugins</groupId>
+        <artifactId>maven-surefire-plugin</artifactId>
+        <version>${commons.surefire.version}</version>
+        <executions>
+          <execution>
+            <id>plain</id>
+            <configuration>
+              <includes>
+                <include>**/*Test.java</include>
+              </includes>
+              <runOrder>random</runOrder>
+            </configuration>
+          </execution>
+          <!-- <execution> <id>security-manager-test</id> <phase>integration-test</phase> <goals> <goal>test</goal> </goals> <configuration>
+            <includes> <include>**/*Test.java</include> </includes> <argLine>-Djava.security.manager -Djava.security.policy=${basedir}/src/test/resources/java.policy</argLine>
+            </configuration> </execution> -->
+        </executions>
+      </plugin>
+      <plugin>
+        <artifactId>maven-assembly-plugin</artifactId>
+        <configuration>
+          <descriptors>
+            <descriptor>src/assembly/bin.xml</descriptor>
+            <descriptor>src/assembly/src.xml</descriptor>
+          </descriptors>
+          <tarLongFileMode>gnu</tarLongFileMode>
+        </configuration>
+      </plugin>
+      <plugin>
+        <groupId>org.apache.maven.plugins</groupId>
+        <artifactId>maven-jar-plugin</artifactId>
+        <executions>
+          <execution>
+            <goals>
+              <goal>test-jar</goal>
+            </goals>
+          </execution>
+        </executions>
+        <configuration>
+          <archive combine.children="append">
+            <manifestEntries>
+              <Automatic-Module-Name>${commons.module.name}</Automatic-Module-Name>
+            </manifestEntries>
+          </archive>
+        </configuration>
+      </plugin>
+      <plugin>
+        <groupId>org.apache.maven.plugins</groupId>
+        <artifactId>maven-scm-publish-plugin</artifactId>
+        <configuration>
+          <ignorePathsToDelete>
+            <ignorePathToDelete>javadocs</ignorePathToDelete>
+          </ignorePathsToDelete>
+        </configuration>
+      </plugin>
+      <plugin>
+        <artifactId>maven-checkstyle-plugin</artifactId>
+        <version>${checkstyle.plugin.version}</version>
+        <configuration>
+          <configLocation>${checkstyle.configdir}/checkstyle.xml</configLocation>
+          <includeTestSourceDirectory>true</includeTestSourceDirectory>
+          <enableRulesSummary>false</enableRulesSummary>
+        </configuration>
+        <dependencies>
+          <dependency>
+            <groupId>com.puppycrawl.tools</groupId>
+            <artifactId>checkstyle</artifactId>
+            <version>${checkstyle.version}</version>
+          </dependency>
+        </dependencies>
+      </plugin>
+      <plugin>
+        <groupId>com.github.spotbugs</groupId>
+        <artifactId>spotbugs-maven-plugin</artifactId>
+        <version>${spotbugs.plugin.version}</version>
+        <dependencies>
+          <dependency>
+            <groupId>com.github.spotbugs</groupId>
+            <artifactId>spotbugs</artifactId>
+            <version>${spotbugs.impl.version}</version>
+         </dependency>
+        </dependencies>        
+        <configuration>
+          <excludeFilterFile>${basedir}/spotbugs-exclude-filter.xml</excludeFilterFile>
+        </configuration>
+      </plugin>
+      <plugin>
+        <groupId>org.apache.felix</groupId>
+        <artifactId>maven-bundle-plugin</artifactId>
+        <dependencies>
+          <dependency>
+            <groupId>biz.aQute.bnd</groupId>
+            <artifactId>biz.aQute.bndlib</artifactId>
+            <version>5.3.0</version>
+          </dependency>
+        </dependencies>
+      </plugin>
+    </plugins>
+  </build>
+
+  <reporting>
+    <plugins>
+      <plugin>
+        <artifactId>maven-checkstyle-plugin</artifactId>
+        <version>${checkstyle.plugin.version}</version>
+        <configuration>
+          <configLocation>${checkstyle.configdir}/checkstyle.xml</configLocation>
+          <includeTestSourceDirectory>true</includeTestSourceDirectory>
+          <enableRulesSummary>false</enableRulesSummary>
+        </configuration>
+        <reportSets>
+          <reportSet>
+            <reports>
+              <report>checkstyle</report>
+            </reports>
+          </reportSet>
+        </reportSets>
+      </plugin>
+      <!-- Requires setting 'export MAVEN_OPTS="-Xmx512m -XX:MaxPermSize=128m" ' -->
+      <plugin>
+        <groupId>com.github.spotbugs</groupId>
+        <artifactId>spotbugs-maven-plugin</artifactId>
+        <version>${spotbugs.plugin.version}</version>
+        <configuration>
+          <excludeFilterFile>${basedir}/spotbugs-exclude-filter.xml</excludeFilterFile>
+        </configuration>
+      </plugin>
+      <plugin>
+        <artifactId>maven-pmd-plugin</artifactId>
+        <version>3.14.0</version>
+        <configuration>
+          <targetJdk>${maven.compiler.target}</targetJdk>
+        </configuration>
+      </plugin>
+      <plugin>
+        <groupId>org.codehaus.mojo</groupId>
+        <artifactId>taglist-maven-plugin</artifactId>
+        <version>2.4</version>
+        <configuration>
+          <tagListOptions>
+            <tagClasses>
+              <tagClass>
+                <displayName>Needs Work</displayName>
+                <tags>
+                  <tag>
+                    <matchString>TODO</matchString>
+                    <matchType>exact</matchType>
+                  </tag>
+                  <tag>
+                    <matchString>FIXME</matchString>
+                    <matchType>exact</matchType>
+                  </tag>
+                  <tag>
+                    <matchString>XXX</matchString>
+                    <matchType>exact</matchType>
+                  </tag>
+                </tags>
+              </tagClass>
+              <tagClass>
+                <displayName>Noteable Markers</displayName>
+                <tags>
+                  <tag>
+                    <matchString>NOTE</matchString>
+                    <matchType>exact</matchType>
+                  </tag>
+                  <tag>
+                    <matchString>NOPMD</matchString>
+                    <matchType>exact</matchType>
+                  </tag>
+                  <tag>
+                    <matchString>NOSONAR</matchString>
+                    <matchType>exact</matchType>
+                  </tag>
+                </tags>
+              </tagClass>
+            </tagClasses>
+          </tagListOptions>
+        </configuration>
+      </plugin>
+    </plugins>
+  </reporting>
+
+  <profiles>
+    <profile>
+      <id>setup-checkout</id>
+      <activation>
+        <file>
+          <missing>site-content</missing>
+        </file>
+      </activation>
+      <build>
+        <plugins>
+          <plugin>
+            <groupId>org.apache.maven.plugins</groupId>
+            <artifactId>maven-antrun-plugin</artifactId>
+            <executions>
+              <execution>
+                <id>prepare-checkout</id>
+                <phase>pre-site</phase>
+                <goals>
+                  <goal>run</goal>
+                </goals>
+                <configuration>
+                  <tasks>
+                    <exec executable="svn">
+                      <arg line="checkout --depth immediates ${commons.scmPubUrl} ${commons.scmPubCheckoutDirectory}" />
+                    </exec>
+
+                    <exec executable="svn">
+                      <arg line="update --set-depth exclude ${commons.scmPubCheckoutDirectory}/javadocs" />
+                    </exec>
+
+                    <pathconvert pathsep=" " property="dirs">
+                      <dirset dir="${commons.scmPubCheckoutDirectory}" includes="*" />
+                    </pathconvert>
+                    <exec executable="svn">
+                      <arg line="update --set-depth infinity ${dirs}" />
+                    </exec>
+                  </tasks>
+                </configuration>
+              </execution>
+            </executions>
+          </plugin>
+        </plugins>
+      </build>
+    </profile>
+
+    <profile>
+      <id>java9+</id>
+      <activation>
+        <jdk>[9,)</jdk>
+      </activation>
+      <properties>
+        <!-- LANG-1265: allow tests to access private fields/methods of java.base classes via reflection -->
+        <argLine>-Xmx512m --add-opens java.base/java.lang.reflect=ALL-UNNAMED --add-opens java.base/java.lang=ALL-UNNAMED</argLine>
+        <!-- coverall version 4.3.0 does not work with java 9, see https://github.com/trautonen/coveralls-maven-plugin/issues/112 -->
+        <coveralls.skip>true</coveralls.skip>
+      </properties>
+    </profile>
+    <profile>
+      <id>java13+</id>
+      <activation>
+        <jdk>[13,)</jdk>
+      </activation>
+      <properties>
+        <!-- jacoco does not work with java 13 yet -->
+        <jacoco.skip>true</jacoco.skip>
+      </properties>
+    </profile>
+    <profile>
+      <id>java15</id>
+      <activation>
+        <!-- This is ONLY activated for Java 15 -->
+        <jdk>15</jdk>
+      </activation>
+      <build>
+        <plugins>
+          <plugin>
+            <groupId>org.apache.maven.plugins</groupId>
+            <artifactId>maven-surefire-plugin</artifactId>
+            <configuration>
+              <excludes>
+                <exclude>org/apache/commons/lang3/time/Java15BugFastDateParserTest.java</exclude>               
+              </excludes>
+            </configuration>
+          </plugin>        
+        </plugins>
+      </build>
+    </profile>
+
+    <profile>
+      <id>benchmark</id>
+      <properties>
+        <skipTests>true</skipTests>
+        <benchmark>org.apache</benchmark>
+      </properties>
+      <build>
+        <plugins>
+          <plugin>
+            <groupId>org.codehaus.mojo</groupId>
+            <artifactId>exec-maven-plugin</artifactId>
+            <version>1.6.0</version>
+            <executions>
+              <execution>
+                <id>benchmark</id>
+                <phase>test</phase>
+                <goals>
+                  <goal>exec</goal>
+                </goals>
+                <configuration>
+                  <classpathScope>test</classpathScope>
+                  <executable>java</executable>
+                  <arguments>
+                    <argument>-classpath</argument>
+                    <classpath/>
+                    <argument>org.openjdk.jmh.Main</argument>
+                    <argument>-rf</argument>
+                    <argument>json</argument>
+                    <argument>-rff</argument>
+                    <argument>target/jmh-result.${benchmark}.json</argument>
+                    <argument>${benchmark}</argument>
+                  </arguments>
+                </configuration>
+              </execution>
+            </executions>
+          </plugin>
+        </plugins>
+      </build>
+    </profile>
+  </profiles>
+</project>

+ 173 - 0
temp_knife4j/lib/jackson-annotations-2.14.0.pom

@@ -0,0 +1,173 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+  <!-- This module was also published with a richer model, Gradle metadata,  -->
+  <!-- which should be used instead. Do not delete the following line which  -->
+  <!-- is to indicate to Gradle or any Gradle module metadata file consumer  -->
+  <!-- that they should prefer consuming it instead. -->
+  <!-- do_not_remove: published-with-gradle-metadata -->
+  <modelVersion>4.0.0</modelVersion> 
+  <parent>
+    <groupId>com.fasterxml.jackson</groupId>
+    <!-- this is one of few Jackson modules that depends on parent and NOT jackson-bom -->
+    <artifactId>jackson-parent</artifactId>
+    <version>2.14</version>
+  </parent>
+
+  <groupId>com.fasterxml.jackson.core</groupId>
+  <artifactId>jackson-annotations</artifactId>
+  <name>Jackson-annotations</name>
+  <version>2.14.0</version>
+  <packaging>bundle</packaging>
+  <description>Core annotations used for value types, used by Jackson data binding package.
+  </description>
+  <inceptionYear>2008</inceptionYear>
+  <licenses>
+    <license>
+      <name>The Apache Software License, Version 2.0</name>
+      <url>https://www.apache.org/licenses/LICENSE-2.0.txt</url>
+      <distribution>repo</distribution>
+    </license>
+  </licenses>
+
+  <url>https://github.com/FasterXML/jackson</url>
+  <scm>
+    <connection>scm:git:git@github.com:FasterXML/jackson-annotations.git</connection>
+    <developerConnection>scm:git:git@github.com:FasterXML/jackson-annotations.git</developerConnection>
+    <url>https://github.com/FasterXML/jackson-annotations</url>
+    <tag>jackson-annotations-2.14.0</tag>
+  </scm>
+
+  <properties>
+    <!-- 04-Mar-2019, tatu: Retain Java6/JDK1.6 compatibility for annotations for Jackson 2.x,
+             but use Moditect to get JDK9+ module info support; need newer bundle plugin as well
+      -->
+    <javac.src.version>1.6</javac.src.version>
+    <javac.target.version>1.6</javac.target.version>
+
+    <maven.compiler.source>1.6</maven.compiler.source>
+    <maven.compiler.target>1.6</maven.compiler.target>
+
+    <osgi.export>com.fasterxml.jackson.annotation.*;version=${project.version}</osgi.export>
+
+    <!-- for Reproducible Builds -->
+    <project.build.outputTimestamp>2022-11-05T20:15:48Z</project.build.outputTimestamp>
+  </properties>
+
+  <dependencies>
+    <dependency>
+      <groupId>junit</groupId>
+      <artifactId>junit</artifactId>
+      <version>${version.junit}</version>
+      <scope>test</scope>
+    </dependency>
+  </dependencies>
+
+  <!-- Alas, need to include snapshot reference since otherwise can not find
+       snapshot of parent... -->
+  <repositories>
+    <repository>
+      <id>sonatype-nexus-snapshots</id>
+      <name>Sonatype Nexus Snapshots</name>
+      <url>https://oss.sonatype.org/content/repositories/snapshots</url>
+      <releases><enabled>false</enabled></releases>
+      <snapshots><enabled>true</enabled></snapshots>
+    </repository>
+  </repositories>
+  
+  <build>
+    <plugins>
+      <!-- First: no replacer plugin (no Packaversion.java.in) for this package -->
+
+      <plugin>
+        <!-- 08-Mar-2019, tatu: Would get these settings from `jackson-bom` except we 
+              do not extend it so...
+          -->
+        <groupId>org.moditect</groupId>
+        <artifactId>moditect-maven-plugin</artifactId>
+        <executions>
+          <execution>
+            <id>add-module-infos</id>
+            <phase>package</phase>
+            <goals>
+              <goal>add-module-info</goal>
+            </goals>
+            <configuration>
+              <overwriteExistingFiles>true</overwriteExistingFiles>
+              <module>
+                <moduleInfoFile>src/moditect/module-info.java</moduleInfoFile>
+              </module>
+            </configuration>
+          </execution>
+        </executions>
+      </plugin>
+
+      <!-- 08-Nov-2019, tatu: Copied from
+           https://github.com/stephenc/git-timestamp-maven-plugin/blob/master/pom.xml#L327-L337
+         -->
+      <plugin>
+        <groupId>org.sonatype.plugins</groupId>
+        <artifactId>nexus-staging-maven-plugin</artifactId>
+        <version>1.6.8</version>
+        <extensions>true</extensions>
+        <configuration>
+          <serverId>sonatype-nexus-staging</serverId>
+          <nexusUrl>https://oss.sonatype.org/</nexusUrl>
+          <stagingProfileId>b34f19b9cc6224</stagingProfileId>
+        </configuration>
+      </plugin>
+
+      <!-- 11-Jun-2020, tatu: [annotations#173] add gradle module metadata
+        -->
+      <plugin>
+        <groupId>de.jjohannes</groupId>
+        <artifactId>gradle-module-metadata-maven-plugin</artifactId>
+        <version>0.2.0</version>
+        <executions>
+          <execution>
+            <goals>
+              <goal>gmm</goal>
+            </goals>
+          </execution>
+        </executions>
+        <configuration>
+          <platformDependencies>
+            <dependency>
+              <groupId>com.fasterxml.jackson</groupId>
+              <artifactId>jackson-bom</artifactId>
+              <version>${project.version}</version>
+            </dependency>
+          </platformDependencies>
+        </configuration>
+      </plugin>
+
+      <!-- 20-Oct-2020, tatu: [annotations#178] copy full LICENSE from main dir
+        -->
+      <plugin>
+        <groupId>org.codehaus.mojo</groupId>
+        <artifactId>build-helper-maven-plugin</artifactId>
+        <executions>
+          <execution>
+            <id>add-resource</id>
+            <phase>generate-resources</phase>
+            <goals>
+              <goal>add-resource</goal>
+            </goals>
+            <configuration>
+              <resources>
+                <resource>
+                  <directory>${project.basedir}</directory>
+                  <targetPath>META-INF</targetPath>
+                  <includes>
+                    <include>LICENSE</include>
+                  </includes>
+                </resource>
+              </resources>
+            </configuration>
+          </execution>
+        </executions>
+      </plugin>
+
+    </plugins>
+  </build>
+
+</project>

+ 148 - 0
temp_knife4j/lib/jackson-core-2.13.3.pom

@@ -0,0 +1,148 @@
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+  <!-- This module was also published with a richer model, Gradle metadata,  -->
+  <!-- which should be used instead. Do not delete the following line which  -->
+  <!-- is to indicate to Gradle or any Gradle module metadata file consumer  -->
+  <!-- that they should prefer consuming it instead. -->
+  <!-- do_not_remove: published-with-gradle-metadata -->
+  <modelVersion>4.0.0</modelVersion> 
+  <parent>
+    <groupId>com.fasterxml.jackson</groupId>
+    <artifactId>jackson-base</artifactId>
+    <version>2.13.3</version>
+  </parent>
+  <groupId>com.fasterxml.jackson.core</groupId>
+  <artifactId>jackson-core</artifactId>
+  <name>Jackson-core</name>
+  <version>2.13.3</version>
+  <packaging>bundle</packaging>
+  <description>Core Jackson processing abstractions (aka Streaming API), implementation for JSON</description>
+  <licenses>
+    <license>
+      <name>The Apache Software License, Version 2.0</name>
+      <url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
+      <distribution>repo</distribution>
+    </license>
+  </licenses>
+  <inceptionYear>2008</inceptionYear>
+
+  <url>https://github.com/FasterXML/jackson-core</url>
+  <scm>
+    <connection>scm:git:git@github.com:FasterXML/jackson-core.git</connection>
+    <developerConnection>scm:git:git@github.com:FasterXML/jackson-core.git</developerConnection>
+    <url>http://github.com/FasterXML/jackson-core</url>    
+    <tag>jackson-core-2.13.3</tag>
+  </scm>
+
+  <properties>
+    <!-- 04-Mar-2019, tatu: Retain Java6/JDK1.6 compatibility for annotations for Jackson 2.x,
+             but use Moditect to get JDK9+ module info support; need newer bundle plugin as well
+      -->
+    <javac.src.version>1.6</javac.src.version>
+    <javac.target.version>1.6</javac.target.version>
+
+    <maven.compiler.source>1.6</maven.compiler.source>
+    <maven.compiler.target>1.6</maven.compiler.target>
+
+    <osgi.export>com.fasterxml.jackson.core;version=${project.version},
+com.fasterxml.jackson.core.*;version=${project.version}
+    </osgi.export>
+
+    <!-- Generate PackageVersion.java into this directory. -->
+    <packageVersion.dir>com/fasterxml/jackson/core/json</packageVersion.dir>
+    <packageVersion.package>${project.groupId}.json</packageVersion.package>
+  </properties>
+
+  <!-- Alas, need to include snapshot reference since otherwise can not find
+       snapshot of parent... -->
+  <repositories>
+    <repository>
+      <id>sonatype-nexus-snapshots</id>
+      <name>Sonatype Nexus Snapshots</name>
+      <url>https://oss.sonatype.org/content/repositories/snapshots</url>
+      <releases><enabled>false</enabled></releases>
+      <snapshots><enabled>true</enabled></snapshots>
+    </repository>
+  </repositories>
+
+  <build>
+    <plugins>
+
+      <!-- 26-Aug-2019, tatu: JaCoCo for code coverage -->
+      <plugin>
+	<groupId>org.jacoco</groupId>
+	<artifactId>jacoco-maven-plugin</artifactId>
+	<executions>
+          <execution>
+            <goals>
+              <goal>prepare-agent</goal>
+            </goals>
+          </execution>
+          <execution>
+            <id>report</id>
+            <phase>test</phase>
+            <goals>
+              <goal>report</goal>
+            </goals>
+          </execution>
+        </executions>
+      </plugin>
+
+      <!-- Important: enable enforcer plug-in: -->
+      <plugin>
+        <artifactId>maven-enforcer-plugin</artifactId>
+	<executions> <!-- or?  combine.children="merge"> -->
+          <execution>
+            <id>enforce-properties</id>
+	        <phase>validate</phase>
+            <goals><goal>enforce</goal></goals>
+          </execution>
+        </executions>
+      </plugin>
+
+      <plugin>
+        <groupId>org.apache.maven.plugins</groupId>
+        <artifactId>maven-site-plugin</artifactId>
+      </plugin>
+      <plugin>
+        <groupId>org.apache.maven.plugins</groupId>
+        <artifactId>maven-surefire-plugin</artifactId>
+        <version>${version.plugin.surefire}</version>
+        <configuration>
+          <redirectTestOutputToFile>${surefire.redirectTestOutputToFile}</redirectTestOutputToFile>
+          <excludes>
+            <exclude>**/failing/**/*.java</exclude>
+          </excludes>
+<!-- 13-Apr-2018, tatu: for debugging [core#400]
+          <systemPropertyVariables>
+<com.fasterxml.jackson.core.util.BufferRecyclers.trackReusableBuffers>true</com.fasterxml.jackson.core.util.BufferRecyclers.trackReusableBuffers>
+          </systemPropertyVariables>
+-->
+        </configuration>
+      </plugin>
+      <!-- settings are fine, but needed to trigger execution! -->
+      <plugin>
+        <groupId>com.google.code.maven-replacer-plugin</groupId>
+        <artifactId>replacer</artifactId>
+      </plugin>
+
+      <!-- 04-Mar-2019, tatu: Add rudimentary JDK9+ module info. To build with JDK 8
+             will have to use `moduleInfoFile` as anything else requires JDK 9+
+        -->
+      <plugin>
+        <groupId>org.moditect</groupId>
+        <artifactId>moditect-maven-plugin</artifactId>
+      </plugin>
+      <!-- 03-Nov-2020, tatu: Add LICENSE from main level -->
+      <plugin>
+        <groupId>org.codehaus.mojo</groupId>
+        <artifactId>build-helper-maven-plugin</artifactId>
+      </plugin>
+      
+      <plugin>
+        <groupId>de.jjohannes</groupId>
+        <artifactId>gradle-module-metadata-maven-plugin</artifactId>
+      </plugin>
+    </plugins>
+  </build>
+
+</project>

+ 434 - 0
temp_knife4j/lib/jackson-databind-2.14.0.pom

@@ -0,0 +1,434 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+  <!-- This module was also published with a richer model, Gradle metadata,  -->
+  <!-- which should be used instead. Do not delete the following line which  -->
+  <!-- is to indicate to Gradle or any Gradle module metadata file consumer  -->
+  <!-- that they should prefer consuming it instead. -->
+  <!-- do_not_remove: published-with-gradle-metadata -->
+  <modelVersion>4.0.0</modelVersion>
+  <parent>
+    <groupId>com.fasterxml.jackson</groupId>
+    <artifactId>jackson-base</artifactId>
+    <version>2.14.0</version>
+  </parent>
+  <groupId>com.fasterxml.jackson.core</groupId>
+  <artifactId>jackson-databind</artifactId>
+  <version>2.14.0</version>
+  <name>jackson-databind</name>
+  <packaging>bundle</packaging>
+  <description>General data-binding functionality for Jackson: works on core streaming API</description>
+  <url>https://github.com/FasterXML/jackson</url>
+  <inceptionYear>2008</inceptionYear>
+  <licenses>
+    <license>
+      <name>The Apache Software License, Version 2.0</name>
+      <url>https://www.apache.org/licenses/LICENSE-2.0.txt</url>
+      <distribution>repo</distribution>
+    </license>
+  </licenses>
+  
+  <scm>
+    <connection>scm:git:git@github.com:FasterXML/jackson-databind.git</connection>
+    <developerConnection>scm:git:git@github.com:FasterXML/jackson-databind.git</developerConnection>
+    <url>https://github.com/FasterXML/jackson-databind</url>
+    <tag>jackson-databind-2.14.0</tag>
+  </scm>
+
+  <properties>
+    <!-- Until Jackson 2.11 (inclusive) baseline was JDK 7 (except for annotations/streaming),
+         with 2.12 baseline became JDK8
+      -->
+    <javac.src.version>1.8</javac.src.version>
+    <javac.target.version>1.8</javac.target.version>
+
+    <!-- Can not use default, since group id != Java package name here -->
+    <osgi.export>com.fasterxml.jackson.databind.*;version=${project.version}</osgi.export>
+    <!-- fix for databind#2299: using jackson-databind in an OSGi environment under Android --> 
+    <osgi.import>
+        org.w3c.dom.bootstrap;resolution:=optional,
+        *
+    </osgi.import>
+
+    <!-- Generate PackageVersion.java into this directory. -->
+    <packageVersion.dir>com/fasterxml/jackson/databind/cfg</packageVersion.dir>
+    <packageVersion.package>com.fasterxml.jackson.databind.cfg</packageVersion.package>
+
+    <version.powermock>2.0.9</version.powermock>
+
+    <!-- for Reproducible Builds -->
+    <project.build.outputTimestamp>2022-11-05T20:38:26Z</project.build.outputTimestamp>
+  </properties>
+
+  <dependencies>
+    <!-- Builds on core streaming API; also needs core annotations -->
+    <dependency>
+      <groupId>com.fasterxml.jackson.core</groupId>
+      <artifactId>jackson-annotations</artifactId>
+      <!-- 06-Mar-2017, tatu: Although bom provides for dependencies, some legacy
+             usage seems to benefit from actually specifying version here in case
+             it is dependent on transitively
+        -->
+      <version>${jackson.version.annotations}</version>
+    </dependency>
+    <dependency>
+      <groupId>com.fasterxml.jackson.core</groupId>
+      <artifactId>jackson-core</artifactId>
+      <version>${jackson.version.core}</version>
+    </dependency>
+
+    <!-- and for testing we need a few libraries
+         libs for which we use reflection for code, but direct dep for testing
+      -->
+
+    <dependency>
+      <groupId>org.powermock</groupId>
+      <artifactId>powermock-core</artifactId>
+      <version>${version.powermock}</version>
+      <scope>test</scope>
+    </dependency>
+    <dependency>
+      <groupId>org.powermock</groupId>
+      <artifactId>powermock-module-junit4</artifactId>
+      <version>${version.powermock}</version>
+      <scope>test</scope>
+    </dependency>
+    <dependency>
+      <groupId>org.powermock</groupId>
+      <artifactId>powermock-api-mockito2</artifactId>
+      <version>${version.powermock}</version>
+      <scope>test</scope>
+    </dependency>
+    <dependency>
+      <groupId>com.google.guava</groupId>
+      <artifactId>guava-testlib</artifactId>
+      <version>31.1-jre</version>
+      <scope>test</scope>
+    </dependency>
+    <!-- For testing TestNoClassDefFoundDeserializer -->
+    <dependency>
+      <groupId>javax.measure</groupId>
+      <artifactId>jsr-275</artifactId>
+      <version>0.9.1</version>
+      <scope>test</scope>
+    </dependency>
+  </dependencies>
+
+  <!-- Alas, need to include snapshot reference since otherwise can not find
+       snapshot of parent... -->
+  <repositories>
+    <repository>
+      <id>sonatype-nexus-snapshots</id>
+      <name>Sonatype Nexus Snapshots</name>
+      <url>https://oss.sonatype.org/content/repositories/snapshots</url>
+      <releases><enabled>false</enabled></releases>
+      <snapshots><enabled>true</enabled></snapshots>
+    </repository>
+  </repositories>
+
+  <build>
+     <plugins>
+
+    <plugin>
+      <groupId>org.jacoco</groupId>
+      <artifactId>jacoco-maven-plugin</artifactId>
+      <executions>
+	<execution>
+	  <goals>
+	    <goal>prepare-agent</goal>
+	    </goals>
+	  </execution>
+	<!-- attached to Maven test phase -->
+	<execution>
+	  <id>report</id>
+	  <phase>test</phase>
+	  <goals>
+	    <goal>report</goal>
+	    </goals>
+	  </execution>
+	</executions>
+      </plugin>
+
+      <!-- Important: enable enforcer plug-in: -->
+      <plugin>
+        <artifactId>maven-enforcer-plugin</artifactId>
+        <executions> <!-- or?  combine.children="merge"> -->
+          <execution>
+            <id>enforce-properties</id>
+	    <phase>validate</phase>
+            <goals><goal>enforce</goal></goals>
+          </execution>
+        </executions>
+      </plugin>
+
+      <plugin>
+        <groupId>org.apache.maven.plugins</groupId>
+        <version>${version.plugin.surefire}</version>
+        <artifactId>maven-surefire-plugin</artifactId>
+        <configuration>
+          <classpathDependencyExcludes>
+            <exclude>javax.measure:jsr-275</exclude>
+          </classpathDependencyExcludes>
+          <excludes>
+            <exclude>**/failing/**/*.java</exclude>
+          </excludes>
+          <!-- 26-Nov-2019, tatu: moar parallelism! Per-class basis, safe, efficient enough
+                  ... although not 100% sure this makes much difference TBH
+            -->
+          <threadCount>4</threadCount>
+          <parallel>classes</parallel>
+        </configuration>
+      </plugin>
+
+      <!-- parent definitions should be ok, but need to add more links -->
+      <plugin>
+        <groupId>org.apache.maven.plugins</groupId>
+        <artifactId>maven-javadoc-plugin</artifactId>
+        <configuration>
+          <links combine.children="append">
+            <link>https://fasterxml.github.io/jackson-annotations/javadoc/2.14</link>
+            <link>https://fasterxml.github.io/jackson-core/javadoc/2.14</link>
+          </links>
+        </configuration>
+      </plugin>
+
+      <!-- settings are fine, but needed to trigger execution! -->
+      <plugin>
+        <groupId>com.google.code.maven-replacer-plugin</groupId>
+        <artifactId>replacer</artifactId>
+      </plugin>
+
+      <!--  04-Mar-2019, tatu: Add rudimentary JDK9+ module info. To build with JDK 8
+             will have to use `moduleInfoFile` as anything else requires JDK 9+
+        -->
+      <plugin>
+        <groupId>org.moditect</groupId>
+        <artifactId>moditect-maven-plugin</artifactId>
+      </plugin>
+      <!-- 03-Nov-2020, tatu: Add LICENSE from main level -->
+      <plugin>
+        <groupId>org.codehaus.mojo</groupId>
+        <artifactId>build-helper-maven-plugin</artifactId>
+      </plugin>
+
+      <plugin>
+        <groupId>de.jjohannes</groupId>
+        <artifactId>gradle-module-metadata-maven-plugin</artifactId>
+      </plugin>
+     </plugins>
+  </build>
+
+  <profiles>
+    <profile>
+      <id>release</id>
+      <properties>
+        <maven.test.skip>true</maven.test.skip>
+        <skipTests>true</skipTests>
+      </properties>
+    </profile>
+    <!-- 07-Dec-2021, tatu: This is a huge mess, sorry folks... -->
+    <profile>
+      <id>java14</id>
+      <activation>
+        <jdk>14</jdk>
+      </activation>
+      <build>
+        <plugins>
+          <plugin>
+            <groupId>org.codehaus.mojo</groupId>
+            <artifactId>build-helper-maven-plugin</artifactId>
+            <executions>
+              <execution>
+                <id>add-test-source</id>
+                <phase>generate-test-sources</phase>
+                <goals>
+                  <goal>add-test-source</goal>
+                </goals>
+                <configuration>
+                  <sources>
+                    <source>src/test-jdk14/java</source>
+                  </sources>
+                </configuration>
+              </execution>
+            </executions>
+          </plugin>
+          <plugin>
+            <groupId>org.apache.maven.plugins</groupId>
+            <artifactId>maven-compiler-plugin</artifactId>
+            <inherited>true</inherited>
+            <configuration>
+              <optimize>true</optimize>
+              <!-- Enable Java 14+ for all sources so that Intellij picks the right language level -->
+              <source>14</source>
+              <release>14</release>
+              <compilerArgs>
+                <arg>-parameters</arg>
+                <arg>--enable-preview</arg>
+              </compilerArgs>
+            	<fork>true</fork>
+            	<useIncrementalCompilation>true</useIncrementalCompilation>
+            </configuration>
+          </plugin>
+          <plugin>
+            <groupId>org.apache.maven.plugins</groupId>
+            <artifactId>maven-surefire-plugin</artifactId>
+            <configuration>
+              <argLine>--enable-preview</argLine>
+            </configuration>
+          </plugin>
+        </plugins>
+      </build>
+    </profile>
+    <profile>
+      <!-- And different set up for JDK 17 -->
+      <id>java17</id>
+      <activation>
+        <jdk>17</jdk>
+      </activation>
+      <build>
+        <plugins>
+          <plugin>
+            <groupId>org.codehaus.mojo</groupId>
+            <artifactId>build-helper-maven-plugin</artifactId>
+            <executions>
+              <execution>
+                <id>add-test-source</id>
+                <phase>generate-test-sources</phase>
+                <goals>
+                  <goal>add-test-source</goal>
+                </goals>
+                <configuration>
+                  <sources>
+                    <source>src/test-jdk14/java</source>
+                  </sources>
+                </configuration>
+              </execution>
+            </executions>
+          </plugin>
+          <plugin>
+            <groupId>org.apache.maven.plugins</groupId>
+            <artifactId>maven-compiler-plugin</artifactId>
+            <inherited>true</inherited>
+            <configuration>
+              <optimize>true</optimize>
+              <!-- Enable Java 17 for all sources so that Intellij picks the right language level -->
+              <source>17</source>
+              <release>17</release>
+              <compilerArgs>
+                <arg>-parameters</arg>
+                <arg>--add-opens=java.base/java.lang=ALL-UNNAMED</arg>
+                <arg>--add-opens=java.base/java.util=ALL-UNNAMED</arg>
+              </compilerArgs>
+            </configuration>
+          </plugin>
+          <plugin>
+            <groupId>org.apache.maven.plugins</groupId>
+            <artifactId>maven-surefire-plugin</artifactId>
+            <configuration>
+              <argLine>--add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.util=ALL-UNNAMED</argLine>
+            </configuration>
+          </plugin>
+        </plugins>
+      </build>
+    </profile>
+    <profile>
+      <id>errorprone</id>
+      <build>
+        <plugins>
+          <plugin>
+            <groupId>org.apache.maven.plugins</groupId>
+            <artifactId>maven-compiler-plugin</artifactId>
+            <configuration>
+              <compilerArgs>
+                <arg>-XDcompilePolicy=simple</arg>
+                <arg>
+                  -Xplugin:ErrorProne
+                  <!--
+                  Disable all checks in test code. Bugs in tests can hide runtime failures,
+                  however these can be enabled later on. Many issues may require sub-optional
+                  code to reproduce failures.
+                  -->
+                  -XepExcludedPaths:.*/src/test/java/.*
+
+                  <!-- ############### -->
+                  <!-- UPGRADED CHECKS -->
+                  <!-- ############### -->
+
+                  <!-- Boxed primitive equality checks can be dangerous when presented with unexpected inputs -->
+                  -Xep:BoxedPrimitiveEquality:ERROR
+
+                  <!-- ############### -->
+                  <!-- DISABLED CHECKS -->
+                  <!-- ############### -->
+
+                  <!-- UnusedVariable is great at catching mistakes quickly, but
+                  requires a few suppressions to avoid noise. Deferring to avoid noise
+                  with the introduction of ErrorProne. -->
+                  -Xep:UnusedVariable:OFF
+                  <!--
+                  Disabled to avoid potential API changes. It's not clear if custom JsonNode types
+                  exist, and if any do implement equals without hashCode, it's likely they cause bugs.
+                  I plan to try fixing this separately.
+                  -->
+                  -Xep:EqualsHashCode:OFF
+                  <!-- Style: javadoc tag validation -->
+                  -Xep:MissingSummary:OFF
+                  -Xep:InvalidInlineTag:OFF
+                  -Xep:EmptyBlockTag:OFF
+                  -Xep:AlmostJavadoc:OFF
+                  -Xep:InvalidLink:OFF
+                  <!-- Style: low reward for enabling. -->
+                  -Xep:UnnecessaryParentheses:OFF
+                  <!-- Style: low signal -->
+                  -Xep:InconsistentCapitalization:OFF
+                  <!-- Style: requires specific comments when switch branches neither break nor return -->
+                  -Xep:FallThrough:OFF
+                  <!-- Style: disable noisy check for importing common names from nested classes -->
+                  -Xep:BadImport:OFF
+                  <!-- Style: requires a default case when not all cases are handled -->
+                  -Xep:MissingCasesInEnumSwitch:OFF
+                  <!-- Style: avoid clashes with java.lang. Possibly worth enabling, but this can be done later -->
+                  -Xep:JavaLangClash:OFF
+                  <!-- These can likely be updated from protected to private, but it's relatively low signal -->
+                  -Xep:ProtectedMembersInFinalClass:OFF
+                  <!-- These can likely be updated from public to protected, but it's relatively low signal -->
+                  -Xep:PublicConstructorForAbstractClass:OFF
+                  <!-- jackson-databind doesn't have a logger, in many cases there's no way to pre-validate inputs -->
+                  -Xep:EmptyCatch:OFF
+                  -Xep:EqualsGetClass:OFF
+                  <!-- Noisy check that's largely unnecessary unless the result is mutated.
+                  Returning only immutable collections requires additional overhead and
+                  impact must be carefully considered. -->
+                  -Xep:MixedMutabilityReturnType:OFF
+                  <!-- Noisy in jackson and libraries which must interact with generics -->
+                  -Xep:TypeParameterUnusedInFormals:OFF
+                  <!-- Check is noisy around code that's meant to handle types that are considered obsolete -->
+                  -Xep:JdkObsolete:OFF
+                  <!-- Avoid noise from tests -->
+                  -Xep:JUnit3FloatingPointComparisonWithoutDelta:OFF
+                  <!-- Disable the StringSplitter check because it requires a guava dependency -->
+                  -Xep:StringSplitter:OFF
+                  <!-- Disable checks which require custom annotations -->
+                  -Xep:AnnotateFormatMethod:OFF
+                  -Xep:GuardedBy:OFF
+                  <!-- This check is generally high signal, however it is noisy in
+                  low level projects which implement caches and interning. -->
+                  -Xep:ReferenceEquality:OFF
+                </arg>
+              </compilerArgs>
+              <annotationProcessorPaths>
+                <path>
+                  <groupId>com.google.errorprone</groupId>
+                  <artifactId>error_prone_core</artifactId>
+                  <version>2.4.0</version>
+                </path>
+              </annotationProcessorPaths>
+            	<fork>true</fork>
+            	<useIncrementalCompilation>true</useIncrementalCompilation>
+            </configuration>
+          </plugin>
+        </plugins>
+      </build>
+    </profile>
+  </profiles>
+
+</project>

+ 66 - 0
temp_knife4j/lib/jackson-dataformat-yaml-2.14.0.pom

@@ -0,0 +1,66 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+  <!-- This module was also published with a richer model, Gradle metadata,  -->
+  <!-- which should be used instead. Do not delete the following line which  -->
+  <!-- is to indicate to Gradle or any Gradle module metadata file consumer  -->
+  <!-- that they should prefer consuming it instead. -->
+  <!-- do_not_remove: published-with-gradle-metadata -->
+  <modelVersion>4.0.0</modelVersion> 
+  <parent>
+    <groupId>com.fasterxml.jackson.dataformat</groupId>
+    <artifactId>jackson-dataformats-text</artifactId>
+    <version>2.14.0</version>
+  </parent>
+  <artifactId>jackson-dataformat-yaml</artifactId>
+  <packaging>bundle</packaging>
+  <name>Jackson-dataformat-YAML</name>
+  <description>Support for reading and writing YAML-encoded data via Jackson abstractions.
+  </description>
+  <url>https://github.com/FasterXML/jackson-dataformats-text</url>
+
+  <properties>
+    <packageVersion.dir>com/fasterxml/jackson/dataformat/yaml</packageVersion.dir>
+    <packageVersion.package>${project.groupId}.yaml</packageVersion.package>
+  </properties>
+
+  <dependencies>
+    <!-- Extends Jackson core, databind (optional); uses SnakeYAML for parsing, generation -->
+    <dependency>
+      <groupId>com.fasterxml.jackson.core</groupId>
+      <artifactId>jackson-databind</artifactId>
+      <!-- starting with 2.10(.4 patch), not optional but fully required -->
+    </dependency>
+
+    <dependency>
+      <groupId>org.yaml</groupId>
+      <artifactId>snakeyaml</artifactId>
+      <version>1.33</version>
+    </dependency>
+
+     <!-- and for testing need annotations; but should be available via `jackson-databind` above
+       -->
+  </dependencies>
+
+  <build>
+    <plugins>
+      <plugin>
+        <!-- Inherited from oss-base. Generate PackageVersion.java.-->
+        <groupId>com.google.code.maven-replacer-plugin</groupId>
+        <artifactId>replacer</artifactId>
+        <executions>
+          <execution>
+            <id>process-packageVersion</id>
+            <phase>generate-sources</phase>
+          </execution>
+        </executions>
+      </plugin>
+      <!--  19-Mar-2019, tatu: Add rudimentary JDK9+ module info. To build with JDK 8
+             will have to use `moduleInfoFile` as anything else requires JDK 9+
+        -->
+      <plugin>
+        <groupId>org.moditect</groupId>
+        <artifactId>moditect-maven-plugin</artifactId>
+      </plugin>
+    </plugins>
+  </build>
+</project>

+ 123 - 0
temp_knife4j/lib/jackson-datatype-jsr310-2.14.0.pom

@@ -0,0 +1,123 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+  <!-- This module was also published with a richer model, Gradle metadata,  -->
+  <!-- which should be used instead. Do not delete the following line which  -->
+  <!-- is to indicate to Gradle or any Gradle module metadata file consumer  -->
+  <!-- that they should prefer consuming it instead. -->
+  <!-- do_not_remove: published-with-gradle-metadata -->
+  <modelVersion>4.0.0</modelVersion>
+  <parent>
+    <groupId>com.fasterxml.jackson.module</groupId>
+    <artifactId>jackson-modules-java8</artifactId>
+    <version>2.14.0</version>
+  </parent>
+  <groupId>com.fasterxml.jackson.datatype</groupId>
+  <artifactId>jackson-datatype-jsr310</artifactId>
+  <name>Jackson datatype: JSR310</name>
+  <packaging>bundle</packaging>
+  <description>Add-on module to support JSR-310 (Java 8 Date &amp; Time API) data types.</description>
+  <developers>
+    <developer>
+      <id>beamerblvd</id>
+      <name>Nick Williams</name>
+      <email>nicholas@nicholaswilliams.net</email>
+      <timezone>-6</timezone>
+    </developer>
+  </developers>
+
+  <properties>
+    <!-- Java8 takes Javadoc-Nazi attitude, insert some sanity here --> 
+    <additionalparam>-Xdoclint:none</additionalparam>
+
+    <!-- Generate PackageVersion.java into this directory. -->
+    <packageVersion.dir>com/fasterxml/jackson/datatype/jsr310</packageVersion.dir>
+    <packageVersion.package>${project.groupId}.jsr310</packageVersion.package>
+    <javac.src.version>1.8</javac.src.version>
+    <javac.target.version>1.8</javac.target.version>
+    <!-- Configuration properties for the OSGi maven-bundle-plugin -->
+    <!-- import should be generated automatically from needed deps; export from simple package (include all) -->
+<!--
+    <osgi.export>${project.groupId}.jsr310.*;version=${project.version}</osgi.export>
+-->
+  </properties>
+
+  <dependencies>
+    <dependency>
+      <groupId>com.fasterxml.jackson.core</groupId>
+      <artifactId>jackson-annotations</artifactId>
+    </dependency>
+  </dependencies>
+
+  <build>
+    <plugins>
+      <plugin>
+        <groupId>org.apache.maven.plugins</groupId>
+        <artifactId>maven-enforcer-plugin</artifactId>
+        <executions>
+          <execution>
+            <id>enforce-java</id>
+            <phase>validate</phase>
+            <goals>
+              <goal>enforce</goal>
+            </goals>
+            <configuration>
+              <rules>
+                <requireJavaVersion>
+                  <version>[1.8,)</version>
+                  <message>[ERROR] The currently supported version of Java is 1.8 or higher</message>
+                </requireJavaVersion>
+                <requireMavenVersion>
+                  <version>[3.0,)</version>
+                  <message>[ERROR] The currently supported version of Maven is 3.0 or higher</message>
+                </requireMavenVersion>
+                <requirePluginVersions>
+                  <banLatest>true</banLatest>
+                  <banRelease>true</banRelease>
+                  <banSnapshots>true</banSnapshots>
+                  <phases>clean,deploy,site</phases>
+                  <message>[ERROR] Best Practice is to always define plugin versions!</message>
+                </requirePluginVersions>
+              </rules>
+            </configuration>
+          </execution>
+        </executions>
+      </plugin>
+      <plugin>
+        <!-- Inherited from oss-base. Generate PackageVersion.java.-->
+        <groupId>com.google.code.maven-replacer-plugin</groupId>
+        <artifactId>replacer</artifactId>
+        <executions>
+          <execution>
+            <id>process-packageVersion</id>
+            <phase>generate-sources</phase>
+          </execution>
+        </executions>
+      </plugin>
+      <plugin>
+        <groupId>org.apache.maven.plugins</groupId>
+        <artifactId>maven-compiler-plugin</artifactId>
+        <version>3.0</version>
+        <inherited>true</inherited>
+        <configuration>
+          <source>${javac.src.version}</source>
+          <target>${javac.target.version}</target>
+          <showDeprecation>true</showDeprecation>
+          <showWarnings>true</showWarnings>
+          <optimize>true</optimize>
+          <compilerArguments>
+            <Xmaxerrs>10000</Xmaxerrs>
+            <Xmaxwarns>10000</Xmaxwarns>
+            <Xlint />
+          </compilerArguments>
+        </configuration>
+      </plugin>
+      <!--  28-Mar-2019, tatu: Add rudimentary JDK9+ module info. To build with JDK 8
+             will have to use `moduleInfoFile` as anything else requires JDK 9+
+        -->
+      <plugin>
+        <groupId>org.moditect</groupId>
+        <artifactId>moditect-maven-plugin</artifactId>
+      </plugin>
+    </plugins>
+  </build>
+</project>

+ 111 - 0
temp_knife4j/lib/jakarta.activation-api-1.2.1.pom

@@ -0,0 +1,111 @@
+<?xml version="1.0" encoding="iso-8859-1"?>
+<!--
+
+    Copyright (c) 1997, 2018 Oracle and/or its affiliates. All rights reserved.
+
+    This program and the accompanying materials are made available under the
+    terms of the Eclipse Distribution License v. 1.0, which is available at
+    http://www.eclipse.org/org/documents/edl-v10.php.
+
+    SPDX-License-Identifier: BSD-3-Clause
+
+-->
+<!--
+    This project builds the JAF API jar file, which contains only
+    the javax.activation.* API definitions and is *only* intended to be used
+    for programs to compile against.  Note that it includes none of the
+    implementation-specific classes that the javax.activation.* classes rely on.
+-->
+<project xmlns="http://maven.apache.org/POM/4.0.0" 
+    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
+                http://maven.apache.org/maven-v4_0_0.xsd">
+    <parent>
+        <groupId>com.sun.activation</groupId>
+        <artifactId>all</artifactId>
+        <version>1.2.1</version>
+    </parent>
+    <modelVersion>4.0.0</modelVersion>
+    <groupId>jakarta.activation</groupId>
+    <artifactId>jakarta.activation-api</artifactId>
+    <packaging>jar</packaging>
+    <name>JavaBeans Activation Framework API jar</name>
+    <properties>
+        <activation.extensionName>
+            jakarta.activation
+        </activation.extensionName>
+        <activation.moduleName>
+            jakarta.activation
+        </activation.moduleName>
+        <activation.packages.export>
+            javax.activation.*; version=${activation.spec.version}
+        </activation.packages.export>
+        <activation.bundle.symbolicName>
+            jakarta.activation-api
+        </activation.bundle.symbolicName>
+    </properties>
+    <build>
+        <plugins>
+            <plugin>
+                <artifactId>maven-dependency-plugin</artifactId>
+                <executions>
+                    <execution>
+                        <!-- download the binaries -->
+                        <id>get-binaries</id>
+                        <phase>process-sources</phase>
+                        <goals>
+                            <goal>unpack</goal>
+                        </goals>
+                    </execution>
+                    <execution>
+                        <!-- download the sources -->
+                        <id>get-sources</id>
+                        <phase>process-sources</phase>
+                        <goals>
+                            <goal>unpack</goal>
+                        </goals>
+                        <configuration>
+                            <artifactItems>
+                                <artifactItem>
+                                    <groupId>com.sun.activation</groupId>
+                                    <artifactId>jakarta.activation</artifactId>
+                                    <version>${project.version}</version>
+                                    <classifier>sources</classifier>
+                                    <outputDirectory>
+                                        ${project.build.directory}/sources
+                                    </outputDirectory>
+                                </artifactItem>
+                            </artifactItems>
+                        </configuration>
+                    </execution>
+                </executions>
+                <configuration>
+                    <artifactItems>
+                        <artifactItem>
+                            <groupId>com.sun.activation</groupId>
+                            <artifactId>jakarta.activation</artifactId>
+                            <version>${project.version}</version>
+                        </artifactItem>
+                    </artifactItems>
+                    <outputDirectory>
+                        ${project.build.outputDirectory}
+                    </outputDirectory>
+                    <includes>
+                        javax/**,
+                        META-INF/LICENSE.txt
+                    </includes>
+                </configuration>
+            </plugin>
+            <plugin>
+                <artifactId>maven-jar-plugin</artifactId>
+                <configuration>
+                    <finalName>${project.artifactId}</finalName>
+                    <archive>
+                        <manifestFile>
+                            ${project.build.outputDirectory}/META-INF/MANIFEST.MF
+                        </manifestFile>
+                    </archive>
+                </configuration>
+            </plugin>
+        </plugins>
+    </build>
+</project>

+ 283 - 0
temp_knife4j/lib/jakarta.validation-api-2.0.2.pom

@@ -0,0 +1,283 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+  ~ Jakarta Bean Validation API
+  ~
+  ~ License: Apache License, Version 2.0
+  ~ See the license.txt file in the root directory or <http://www.apache.org/licenses/LICENSE-2.0>.
+  -->
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
+    <modelVersion>4.0.0</modelVersion>
+    <parent>
+        <groupId>org.eclipse.ee4j</groupId>
+        <artifactId>project</artifactId>
+        <version>1.0.5</version>
+    </parent>
+
+    <groupId>jakarta.validation</groupId>
+    <artifactId>jakarta.validation-api</artifactId>
+    <version>2.0.2</version>
+    <packaging>jar</packaging>
+    <name>Jakarta Bean Validation API</name>
+    <url>https://beanvalidation.org</url>
+
+    <description>
+        Jakarta Bean Validation API
+    </description>
+
+    <developers>
+        <developer>
+            <id>epbernard</id>
+            <name>Emmanuel Bernard</name>
+            <email>emmanuel@hibernate.org</email>
+            <organization>Red Hat, Inc.</organization>
+            <url>http://in.relation.to/emmanuel-bernard/</url>
+        </developer>
+        <developer>
+            <id>emmanuelbernard</id>
+            <name>Emmanuel Bernard</name>
+            <email>emmanuel@hibernate.org</email>
+            <organization>Red Hat, Inc.</organization>
+            <url>http://in.relation.to/emmanuel-bernard/</url>
+        </developer>
+        <developer>
+            <id>hardy.ferentschik</id>
+            <name>Hardy Ferentschik</name>
+            <email>hferents@redhat.com</email>
+            <organization>Red Hat, Inc.</organization>
+            <url>http://in.relation.to/hardy-ferentschik/</url>
+        </developer>
+        <developer>
+            <id>gunnar.morling</id>
+            <name>Gunnar Morling</name>
+            <email>gunnar@hibernate.org</email>
+            <organization>Red Hat, Inc.</organization>
+            <url>http://in.relation.to/gunnar-morling/</url>
+        </developer>
+        <developer>
+            <id>guillaume.smet</id>
+            <name>Guillaume Smet</name>
+            <email>guillaume.smet@hibernate.org</email>
+            <organization>Red Hat, Inc.</organization>
+            <url>http://in.relation.to/guillaume-smet/</url>
+        </developer>
+    </developers>
+
+    <issueManagement>
+        <system>JIRA</system>
+        <url>https://hibernate.atlassian.net/projects/BVAL/</url>
+    </issueManagement>
+
+    <inceptionYear>2007</inceptionYear>
+
+    <licenses>
+        <license>
+            <name>Apache License 2.0</name>
+            <url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
+        </license>
+    </licenses>
+
+    <scm>
+        <connection>scm:git:git://github.com/eclipse-ee4j/beanvalidation-api.git</connection>
+        <developerConnection>scm:git:git@github.com:eclipse-ee4j/beanvalidation-api.git</developerConnection>
+        <url>https://github.com/eclipse-ee4j/beanvalidation-api</url>
+        <tag>HEAD</tag>
+    </scm>
+
+    <properties>
+        <maven.compiler.target>1.8</maven.compiler.target>
+        <maven.compiler.source>1.8</maven.compiler.source>
+        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
+    </properties>
+
+    <dependencies>
+        <dependency>
+            <groupId>org.testng</groupId>
+            <artifactId>testng</artifactId>
+            <version>6.11</version>
+            <scope>test</scope>
+        </dependency>
+    </dependencies>
+
+    <build>
+        <pluginManagement>
+            <plugins>
+                <plugin>
+                    <!--
+                        Creates a report by running "mvn japicmp:cmp"
+                        Note: you need to install the jars before running the japicmp command.
+                    -->
+                    <groupId>com.github.siom79.japicmp</groupId>
+                    <artifactId>japicmp-maven-plugin</artifactId>
+                    <version>0.9.3</version>
+                    <configuration>
+                        <oldVersion>
+                            <dependency>
+                                <groupId>javax.validation</groupId>
+                                <artifactId>validation-api</artifactId>
+                                <version>1.1.0.Final</version>
+                            </dependency>
+                        </oldVersion>
+                        <newVersion>
+                            <file>
+                                <path>${project.build.directory}/${project.artifactId}-${project.version}.${project.packaging}</path>
+                            </file>
+                        </newVersion>
+                        <parameter>
+                            <onlyModified>true</onlyModified>
+                        </parameter>
+                    </configuration>
+                </plugin>
+            </plugins>
+        </pluginManagement>
+        <plugins>
+            <plugin>
+                <groupId>org.apache.felix</groupId>
+                <artifactId>maven-bundle-plugin</artifactId>
+                <version>3.2.0</version>
+                <configuration>
+                    <instructions>
+                        <Export-Package>
+                            javax.validation.*;version="${project.version}",
+                        </Export-Package>
+                        <Automatic-Module-Name>java.validation</Automatic-Module-Name>
+                    </instructions>
+                </configuration>
+                <executions>
+                    <execution>
+                        <id>bundle-manifest</id>
+                        <phase>process-classes</phase>
+                        <goals>
+                            <goal>manifest</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-compiler-plugin</artifactId>
+                <version>3.5.1</version>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-surefire-plugin</artifactId>
+                <version>2.19.1</version>
+                <configuration>
+                    <forkMode>once</forkMode>
+                    <redirectTestOutputToFile>true</redirectTestOutputToFile>
+                    <includes>
+                        <include>**/*Test.java</include>
+                    </includes>
+                </configuration>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-jar-plugin</artifactId>
+                <version>3.0.2</version>
+                <configuration>
+                    <archive>
+                        <manifestFile>${basedir}/target/classes/META-INF/MANIFEST.MF</manifestFile>
+                    </archive>
+                </configuration>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-source-plugin</artifactId>
+                <version>3.0.1</version>
+                <executions>
+                    <execution>
+                        <id>attach-sources</id>
+                        <goals>
+                            <goal>jar</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-javadoc-plugin</artifactId>
+                <version>2.10.4</version>
+                <executions>
+                    <execution>
+                        <id>attach-javadocs</id>
+                        <goals>
+                            <goal>jar</goal>
+                        </goals>
+                    </execution>
+                </executions>
+                <configuration>
+                    <links>
+                        <link>http://docs.oracle.com/javase/8/docs/api/</link>
+                    </links>
+                    <packagesheader>Jakarta Bean Validation API Packages</packagesheader>
+                    <doctitle>Jakarta Bean Validation API ${project.version}</doctitle>
+                    <windowtitle>Jakarta Bean Validation API ${project.version}</windowtitle>
+                    <bottom><![CDATA[
+Comments to: <a href="mailto:bean-validation-dev@eclipse.org">bean-validation-dev@eclipse.org</a>.<br>
+Copyright &#169; 2019 Eclipse Foundation.<br>
+Use is subject to <a href="{@docRoot}/doc-files/speclicense.html" target="_top">EFSL</a>; this spec is based on material that is licensed under the Apache License, version 2.0.]]>
+                    </bottom>
+                </configuration>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-install-plugin</artifactId>
+                <version>2.5.2</version>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-release-plugin</artifactId>
+                <version>2.5.3</version>
+                <configuration>
+                    <allowTimestampedSnapshots>true</allowTimestampedSnapshots>
+                    <remoteTagging>true</remoteTagging>
+                    <goals>deploy</goals>
+                </configuration>
+            </plugin>
+            <plugin>
+                <artifactId>maven-deploy-plugin</artifactId>
+                <version>2.8.2</version>
+            </plugin>
+            <plugin>
+                <groupId>com.mycila</groupId>
+                <artifactId>license-maven-plugin</artifactId>
+                <version>3.0</version>
+                <configuration>
+                    <header>${project.basedir}/license/license.header</header>
+                    <strictCheck>true</strictCheck>
+                    <headerDefinitions>
+                        <headerDefinition>${project.basedir}/license/java-header-style.xml</headerDefinition>
+                        <headerDefinition>${project.basedir}/license/xml-header-style.xml</headerDefinition>
+                    </headerDefinitions>
+                    <mapping>
+                        <java>JAVA_CLASS_STYLE</java>
+                        <xml>XML_FILE_STYLE</xml>
+                        <xsd>XML_FILE_STYLE</xsd>
+                    </mapping>
+                    <includes>
+                        <include>**/*.java</include>
+                        <include>**/*.xml</include>
+                        <include>**/*.xsd</include>
+                    </includes>
+                </configuration>
+                <executions>
+                    <execution>
+                        <id>license-headers</id>
+                        <goals>
+                            <goal>check</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+        </plugins>
+    </build>
+
+    <profiles>
+        <profile>
+            <id>release</id>
+            <properties>
+                <createChecksum>true</createChecksum>
+            </properties>
+        </profile>
+    </profiles>
+
+</project>

+ 341 - 0
temp_knife4j/lib/jakarta.xml.bind-api-2.3.2.pom

@@ -0,0 +1,341 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+
+    Copyright (c) 2018 Oracle and/or its affiliates. All rights reserved.
+
+    This program and the accompanying materials are made available under the
+    terms of the Eclipse Distribution License v. 1.0, which is available at
+    http://www.eclipse.org/org/documents/edl-v10.php.
+
+    SPDX-License-Identifier: BSD-3-Clause
+
+-->
+
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+    <parent>
+        <artifactId>jakarta.xml.bind-api-parent</artifactId>
+        <groupId>jakarta.xml.bind</groupId>
+        <version>2.3.2</version>
+    </parent>
+    <modelVersion>4.0.0</modelVersion>
+
+    <artifactId>jakarta.xml.bind-api</artifactId>
+    <packaging>jar</packaging>
+
+    <properties>
+        <config.dir>${project.basedir}/../etc/config</config.dir>
+        <legal.doc.source>${project.basedir}/..</legal.doc.source>
+    </properties>
+
+    <dependencies>
+        <dependency>
+            <groupId>jakarta.activation</groupId>
+            <artifactId>jakarta.activation-api</artifactId>
+        </dependency>
+    </dependencies>
+
+    <build>
+
+        <pluginManagement>
+            <plugins>
+                <plugin>
+                    <artifactId>maven-enforcer-plugin</artifactId>
+                    <configuration>
+                        <rules>
+                            <requireJavaVersion>
+                                <version>[1.8,)</version>
+                            </requireJavaVersion>
+                            <requireMavenVersion>
+                                <version>[3.0.3,)</version>
+                            </requireMavenVersion>
+                            <DependencyConvergence />
+                        </rules>
+                    </configuration>
+                </plugin>
+                <plugin>
+                    <groupId>org.codehaus.mojo</groupId>
+                    <artifactId>cobertura-maven-plugin</artifactId>
+                    <version>2.7</version>
+                    <configuration>
+                        <formats>
+                            <format>xml</format>
+                        </formats>
+                        <check>
+                            <totalLineRate>45</totalLineRate>
+                            <packageLineRate>45</packageLineRate>
+                            <haltOnFailure>true</haltOnFailure>
+                        </check>
+                    </configuration>
+                </plugin>
+                <plugin>
+                    <groupId>org.glassfish.copyright</groupId>
+                    <artifactId>glassfish-copyright-maven-plugin</artifactId>
+                    <configuration>
+                        <templateFile>${project.basedir}/copyright.txt</templateFile>
+                        <excludeFile>${project.basedir}/copyright-exclude</excludeFile>
+                        <!-- skip files not under SCM-->
+                        <scmOnly>true</scmOnly>
+                        <!-- turn off warnings -->
+                        <warn>true</warn>
+                        <!-- for use with repair -->
+                        <update>false</update>
+                        <!-- check that year is correct -->
+                        <ignoreYear>false</ignoreYear>
+                    </configuration>
+                </plugin>
+                <plugin>
+                    <artifactId>maven-jar-plugin</artifactId>
+                    <version>3.1.0</version>
+                    <configuration>
+                        <archive>
+                            <manifestFile>${project.build.outputDirectory}/META-INF/MANIFEST.MF</manifestFile>
+                        </archive>
+                    </configuration>
+                </plugin>
+                <plugin>
+                    <groupId>org.codehaus.mojo</groupId>
+                    <artifactId>buildnumber-maven-plugin</artifactId>
+                    <version>1.4</version>
+                    <configuration>
+                        <getRevisionOnlyOnce>true</getRevisionOnlyOnce>
+                        <timestampFormat>{0,date,yyyy-MM-dd'T'HH:mm:ssZ}</timestampFormat>
+                        <shortRevisionLength>7</shortRevisionLength>
+                        <revisionOnScmFailure>false</revisionOnScmFailure>
+                    </configuration>
+                </plugin>
+                <plugin>
+                    <groupId>org.apache.felix</groupId>
+                    <artifactId>maven-bundle-plugin</artifactId>
+                    <version>3.5.1</version>
+                    <configuration>
+                        <archive>
+                            <manifestFile>${project.build.outputDirectory}/META-INF/MANIFEST.MF</manifestFile>
+                        </archive>
+                        <instructions>
+                            <_noee>true</_noee>
+                            <Bundle-Version>${project.version}</Bundle-Version>  <!-- 2.2.99.bnull -->
+                            <Extension-Name>${extension.name}</Extension-Name>
+                            <Implementation-Version>${spec.version}.${impl.version}</Implementation-Version>
+                            <Specification-Version>${spec.version}</Specification-Version>
+                            <Export-Package>${api.package}.*; version=${spec.version}.${impl.version}</Export-Package>
+                            <Import-Package>
+                                javax.activation;version=!,
+                                javax.xml.bind;version="[${spec.version},3)",
+                                javax.xml.bind.annotation;version="[${spec.version},3)",
+                                javax.xml.bind.annotation.adapters;version="[${spec.version},3)",
+                                javax.xml.bind.attachment;version="[${spec.version},3)",
+                                javax.xml.bind.helpers;version="[${spec.version},3)",
+                                javax.xml.bind.util;version="[${spec.version},3)",
+                                javax.xml.datatype,
+                                javax.xml.namespace,
+                                javax.xml.parsers,
+                                javax.xml.stream,
+                                javax.xml.transform,
+                                javax.xml.transform.dom,
+                                javax.xml.transform.sax,
+                                javax.xml.transform.stream,
+                                javax.xml.validation,
+                                org.w3c.dom,
+                                org.xml.sax,
+                                org.xml.sax.ext,
+                                org.xml.sax.helpers
+                            </Import-Package>
+                            <Bundle-SymbolicName>${extension.name}-api</Bundle-SymbolicName>
+                            <DynamicImport-Package>org.glassfish.hk2.osgiresourcelocator</DynamicImport-Package>
+                            <Specification-Vendor>${vendor.name}</Specification-Vendor>
+                            <Implementation-Build-Id>${scmBranch}-${buildNumber}, ${timestamp}</Implementation-Build-Id>
+                            <Multi-Release>true</Multi-Release>
+                        </instructions>
+                    </configuration>
+                </plugin>
+                <plugin>
+                    <groupId>org.codehaus.mojo</groupId>
+                    <artifactId>findbugs-maven-plugin</artifactId>
+                    <version>3.0.5</version>
+                    <configuration>
+                        <skip>${findbugs.skip}</skip>
+                        <threshold>${findbugs.threshold}</threshold>
+                        <findbugsXmlWithMessages>true</findbugsXmlWithMessages>
+                        <excludeFilterFile>
+                            ${findbugs.exclude}
+                        </excludeFilterFile>
+                        <fork>true</fork>
+                        <jvmArgs>-Xms64m -Xmx256m</jvmArgs>
+                    </configuration>
+                    <dependencies>
+                        <dependency>
+                            <groupId>org.glassfish.findbugs</groupId>
+                            <artifactId>findbugs</artifactId>
+                            <version>1.0</version>
+                        </dependency>
+                    </dependencies>
+                </plugin>
+                <plugin>
+                    <artifactId>maven-javadoc-plugin</artifactId>
+                    <configuration>
+                        <doclint>none</doclint>
+                        <nodeprecated>false</nodeprecated>
+                        <use>false</use>
+                        <author>true</author>
+                        <version>true</version>
+                        <doctitle><![CDATA[<br>
+JAXB ${project.version} API Library</h2>
+${project.name} specification, ${release.spec.date}<br>
+Comments to: <i><a href='mailto:${release.spec.feedback}'>${release.spec.feedback}</a></i><br>
+More information at: <i><a target='_top'
+href='https://projects.eclipse.org/projects/ee4j.jaxb'>https://projects.eclipse.org/projects/ee4j.jaxb</a></i><br>
+&nbsp;<br>&nbsp;<br><hr width='65%'><h1>${project.name}</h1><hr width='75%'>
+<br>&nbsp;<br>]]>
+                        </doctitle>
+                        <header><![CDATA[JAXB<br>v${project.version}]]>
+                        </header>
+                        <bottom>
+                        <![CDATA[<br>Copyright &#169; {inceptionYear}&#x2013;{currentYear} Oracle and/or its affiliates.
+                        All rights reserved.<br>Comments to : <a href="mailto:${release.spec.feedback}">${release.spec.feedback}</a>.]]>
+                        </bottom>
+                        <detectJavaApiLink>false</detectJavaApiLink>
+                        <tags>
+                            <tag>
+                                <name>apiNote</name>
+                                <!-- todo tag for all places -->
+                                <placement>a</placement>
+                                <head>API Note:</head>
+                            </tag>
+                            <tag>
+                                <name>implSpec</name>
+                                <!-- todo tag for all places -->
+                                <placement>a</placement>
+                                <head>Implementation Requirements:</head>
+                            </tag>
+                            <tag>
+                                <name>implNote</name>
+                                <!-- todo tag for all places -->
+                                <placement>a</placement>
+                                <head>Implementation Note:</head>
+                            </tag>
+                        </tags>
+                    </configuration>
+                </plugin>
+            </plugins>
+        </pluginManagement>
+
+        <plugins>
+            <plugin>
+                <groupId>org.codehaus.mojo</groupId>
+                <artifactId>build-helper-maven-plugin</artifactId>
+                <executions>
+                    <execution>
+                        <id>add-legal-resource</id>
+                        <phase>generate-resources</phase>
+                        <goals>
+                            <goal>add-resource</goal>
+                        </goals>
+                        <configuration>
+                            <resources>
+                                <resource>
+                                    <directory>${legal.doc.source}</directory>
+                                    <includes>
+                                        <include>NOTICE.md</include>
+                                        <include>LICENSE.md</include>
+                                    </includes>
+                                    <targetPath>META-INF</targetPath>
+                                </resource>
+                            </resources>
+                        </configuration>
+                    </execution>
+                    <execution>
+                        <id>add-mr-resource</id>
+                        <phase>prepare-package</phase>
+                        <goals>
+                            <goal>add-resource</goal>
+                        </goals>
+                        <configuration>
+                            <resources>
+                                <resource>
+                                    <directory>${project.basedir}/src/main/mr-jar</directory>
+                                    <targetPath>META-INF/versions/9</targetPath>
+                                </resource>
+                            </resources>
+                        </configuration>
+                    </execution>
+                </executions>
+            </plugin>
+            <plugin>
+                <artifactId>maven-enforcer-plugin</artifactId>
+                <executions>
+                    <execution>
+                        <id>enforce-versions</id>
+                        <goals>
+                            <goal>enforce</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+            <plugin>
+                <groupId>org.codehaus.mojo</groupId>
+                <artifactId>buildnumber-maven-plugin</artifactId>
+                <executions>
+                    <execution>
+                        <id>validate</id>
+                        <phase>validate</phase>
+                        <goals>
+                            <goal>create</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+            <plugin>
+                <artifactId>maven-compiler-plugin</artifactId>
+                <executions>
+                    <execution>
+                        <id>default-compile</id>
+                        <configuration>
+                            <release>8</release>
+                            <excludes>
+                                <exclude>module-info.java</exclude>
+                            </excludes>
+                        </configuration>
+                    </execution>
+                    <execution>
+                        <id>module-info-compile</id>
+                        <goals>
+                            <goal>compile</goal>
+                        </goals>
+                        <configuration>
+                            <release>9</release>
+                            <includes>
+                                <include>module-info.java</include>
+                            </includes>
+                        </configuration>
+                    </execution>
+                    <execution>
+                        <id>default-compile-mr</id>
+                        <goals>
+                            <goal>compile</goal>
+                        </goals>
+                        <configuration>
+                            <release>9</release>
+                            <compileSourceRoots>
+                                <compileSourceRoot>${project.basedir}/src/main/mr-jar</compileSourceRoot>
+                            </compileSourceRoots>
+                            <outputDirectory>${project.build.outputDirectory}/META-INF/versions/9</outputDirectory>
+                        </configuration>
+                    </execution>
+                </executions>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.felix</groupId>
+                <artifactId>maven-bundle-plugin</artifactId>
+                <executions>
+                    <execution>
+                        <id>bundle-manifest</id>
+                        <phase>process-classes</phase>
+                        <goals>
+                            <goal>manifest</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+        </plugins>
+    </build>
+</project>

+ 49 - 0
temp_knife4j/lib/knife4j-core-4.1.0.pom

@@ -0,0 +1,49 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
+    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
+  <modelVersion>4.0.0</modelVersion>
+  <parent>
+    <groupId>com.github.xiaoymin</groupId>
+    <artifactId>knife4j</artifactId>
+    <version>4.1.0</version>
+  </parent>
+  <groupId>com.github.xiaoymin</groupId>
+  <artifactId>knife4j-core</artifactId>
+  <version>4.1.0</version>
+  <name>knife4j-core</name>
+  <description>knife4j核心层</description>
+  <licenses>
+    <license>
+      <name>The Apache Software License, Version 2.0</name>
+      <url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
+    </license>
+  </licenses>
+  <dependencies>
+    <dependency>
+      <groupId>org.slf4j</groupId>
+      <artifactId>slf4j-api</artifactId>
+    </dependency>
+    <dependency>
+      <groupId>org.projectlombok</groupId>
+      <artifactId>lombok</artifactId>
+      <scope>compile</scope>
+    </dependency>
+    <dependency>
+      <groupId>javax.servlet</groupId>
+      <artifactId>javax.servlet-api</artifactId>
+      <scope>provided</scope>
+    </dependency>
+    <dependency>
+      <groupId>jakarta.servlet</groupId>
+      <artifactId>jakarta.servlet-api</artifactId>
+      <version>${knife4j-servlet-jakarta.version}</version>
+      <scope>provided</scope>
+    </dependency>
+    <dependency>
+      <groupId>junit</groupId>
+      <artifactId>junit</artifactId>
+      <version>4.13.2</version>
+      <scope>test</scope>
+    </dependency>
+  </dependencies>
+</project>

+ 84 - 0
temp_knife4j/lib/knife4j-openapi3-spring-boot-starter-4.1.0.pom

@@ -0,0 +1,84 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
+    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
+  <modelVersion>4.0.0</modelVersion>
+  <parent>
+    <groupId>com.github.xiaoymin</groupId>
+    <artifactId>knife4j</artifactId>
+    <version>4.1.0</version>
+  </parent>
+  <groupId>com.github.xiaoymin</groupId>
+  <artifactId>knife4j-openapi3-spring-boot-starter</artifactId>
+  <version>4.1.0</version>
+  <name>knife4j-openapi3-spring-boot-starter</name>
+  <description>Spring Boot autoconfigure</description>
+  <licenses>
+    <license>
+      <name>The Apache Software License, Version 2.0</name>
+      <url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
+    </license>
+  </licenses>
+  <dependencies>
+    <dependency>
+      <groupId>org.springframework.boot</groupId>
+      <artifactId>spring-boot-autoconfigure</artifactId>
+      <version>${knife4j-spring-boot.version}</version>
+      <scope>provided</scope>
+    </dependency>
+    <dependency>
+      <groupId>org.springframework.boot</groupId>
+      <artifactId>spring-boot-configuration-processor</artifactId>
+      <version>${knife4j-spring-boot.version}</version>
+      <optional>true</optional>
+    </dependency>
+    <dependency>
+      <groupId>com.github.xiaoymin</groupId>
+      <artifactId>knife4j-core</artifactId>
+    </dependency>
+    <dependency>
+      <groupId>com.github.xiaoymin</groupId>
+      <artifactId>knife4j-openapi3-ui</artifactId>
+    </dependency>
+    <dependency>
+      <groupId>org.springframework</groupId>
+      <artifactId>spring-web</artifactId>
+      <version>${knife4j-spring.version}</version>
+      <scope>provided</scope>
+    </dependency>
+    <dependency>
+      <groupId>org.springframework</groupId>
+      <artifactId>spring-webmvc</artifactId>
+      <version>${knife4j-spring.version}</version>
+      <scope>provided</scope>
+    </dependency>
+    <dependency>
+      <groupId>org.springdoc</groupId>
+      <artifactId>springdoc-openapi-common</artifactId>
+    </dependency>
+    <dependency>
+      <groupId>org.springdoc</groupId>
+      <artifactId>springdoc-openapi-webflux-core</artifactId>
+    </dependency>
+    <dependency>
+      <groupId>org.springdoc</groupId>
+      <artifactId>springdoc-openapi-webmvc-core</artifactId>
+    </dependency>
+    <dependency>
+      <groupId>org.springdoc</groupId>
+      <artifactId>springdoc-openapi-ui</artifactId>
+    </dependency>
+    <dependency>
+      <groupId>io.swagger.core.v3</groupId>
+      <artifactId>swagger-annotations</artifactId>
+    </dependency>
+    <dependency>
+      <groupId>io.swagger.core.v3</groupId>
+      <artifactId>swagger-models</artifactId>
+    </dependency>
+    <dependency>
+      <groupId>javax.servlet</groupId>
+      <artifactId>javax.servlet-api</artifactId>
+      <scope>provided</scope>
+    </dependency>
+  </dependencies>
+</project>

+ 31 - 0
temp_knife4j/lib/knife4j-openapi3-ui-4.1.0.pom

@@ -0,0 +1,31 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
+    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
+  <modelVersion>4.0.0</modelVersion>
+  <parent>
+    <groupId>com.github.xiaoymin</groupId>
+    <artifactId>knife4j</artifactId>
+    <version>4.1.0</version>
+  </parent>
+  <groupId>com.github.xiaoymin</groupId>
+  <artifactId>knife4j-openapi3-ui</artifactId>
+  <version>4.1.0</version>
+  <description>springdoc-openapi的Ui模块</description>
+  <licenses>
+    <license>
+      <name>The Apache Software License, Version 2.0</name>
+      <url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
+    </license>
+  </licenses>
+  <properties>
+    <destDir>${project.build.outputDirectory}/META-INF/resources/</destDir>
+  </properties>
+  <build>
+    <resources>
+      <resource>
+        <targetPath>META-INF/resources/</targetPath>
+        <directory>${project.basedir}/src/main/resources</directory>
+      </resource>
+    </resources>
+  </build>
+</project>

+ 120 - 0
temp_knife4j/lib/slf4j-api-1.7.28.pom

@@ -0,0 +1,120 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+
+  <modelVersion>4.0.0</modelVersion>
+
+  <parent>
+    <groupId>org.slf4j</groupId>
+    <artifactId>slf4j-parent</artifactId>
+    <version>1.7.28</version>
+  </parent>
+
+  <artifactId>slf4j-api</artifactId>
+
+  <packaging>jar</packaging>
+  <name>SLF4J API Module</name>
+  <description>The slf4j API</description>
+
+  <url>http://www.slf4j.org</url>
+
+  <build>
+    <plugins>
+      <plugin>
+        <groupId>org.codehaus.mojo</groupId>
+        <artifactId>animal-sniffer-maven-plugin</artifactId>
+        <configuration>
+          <!-- Signatures cannot be determined and will error unless excluded.  This is isolated to
+               code otherwise already marked for removal in the module artifact. -->
+          <ignores>
+            <ignore>org.slf4j.impl.StaticMDCBinder</ignore>
+            <ignore>org.slf4j.impl.StaticLoggerBinder</ignore>
+            <ignore>org.slf4j.impl.StaticMarkerBinder</ignore>
+          </ignores>
+        </configuration>
+      </plugin>
+      <plugin>
+        <groupId>org.apache.maven.plugins</groupId>
+        <artifactId>maven-surefire-plugin</artifactId>
+        <configuration>
+          <forkMode>once</forkMode>
+          <reportFormat>plain</reportFormat>
+          <trimStackTrace>false</trimStackTrace>
+          <excludes>
+            <exclude>**/AllTest.java</exclude>
+            <exclude>**/PackageTest.java</exclude>
+          </excludes>
+        </configuration>
+      </plugin>
+
+      <plugin>
+        <groupId>org.apache.maven.plugins</groupId>
+        <artifactId>maven-jar-plugin</artifactId>
+        <executions>
+          <execution>
+            <id>bundle-test-jar</id>
+            <phase>package</phase>
+            <goals>
+              <goal>jar</goal>
+              <goal>test-jar</goal>
+            </goals>
+          </execution>
+        </executions>
+      </plugin>
+
+      <plugin>
+        <groupId>org.apache.maven.plugins</groupId>
+        <artifactId>maven-antrun-plugin</artifactId>
+        <executions>
+          <execution>
+            <phase>process-classes</phase>
+            <goals>
+             <goal>run</goal>
+            </goals>
+          </execution>
+        </executions>
+        <configuration>
+          <tasks>
+            <echo>Removing slf4j-api's dummy StaticLoggerBinder and StaticMarkerBinder</echo>
+            <delete dir="target/classes/org/slf4j/impl"/>
+          </tasks>
+        </configuration>
+      </plugin>
+    </plugins>
+
+    <pluginManagement>
+    	<plugins>
+    		<!--This plugin's configuration is used to store Eclipse m2e settings only. It has no influence on the Maven build itself.-->
+    		<plugin>
+    			<groupId>org.eclipse.m2e</groupId>
+    			<artifactId>lifecycle-mapping</artifactId>
+    			<version>1.0.0</version>
+    			<configuration>
+    				<lifecycleMappingMetadata>
+    					<pluginExecutions>
+    						<pluginExecution>
+    							<pluginExecutionFilter>
+    								<groupId>
+    									org.apache.maven.plugins
+    								</groupId>
+    								<artifactId>
+    									maven-antrun-plugin
+    								</artifactId>
+    								<versionRange>[1.3,)</versionRange>
+    								<goals>
+    									<goal>run</goal>
+    								</goals>
+    							</pluginExecutionFilter>
+    							<action>
+    								<ignore></ignore>
+    							</action>
+    						</pluginExecution>
+    					</pluginExecutions>
+    				</lifecycleMappingMetadata>
+    			</configuration>
+    		</plugin>
+    	</plugins>
+    </pluginManagement>
+  </build>
+
+</project>

+ 825 - 0
temp_knife4j/lib/snakeyaml-1.33.pom

@@ -0,0 +1,825 @@
+<?xml version="1.0" encoding="utf-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
+    <modelVersion>4.0.0</modelVersion>
+    <groupId>org.yaml</groupId>
+    <artifactId>snakeyaml</artifactId>
+    <version>1.33</version>
+    <packaging>bundle</packaging>
+    <properties>
+        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
+        <project.scm.id>bitbucket</project.scm.id>
+        <release.repo.url>https://oss.sonatype.org/service/local/staging/deploy/maven2/</release.repo.url>
+        <snapshot.repo.url>https://oss.sonatype.org/content/repositories/snapshots/</snapshot.repo.url>
+        <maven.compiler.source>7</maven.compiler.source>
+        <maven.compiler.target>7</maven.compiler.target>
+        <maven.compiler.testSource>8</maven.compiler.testSource>
+        <maven.compiler.testTarget>8</maven.compiler.testTarget>
+        <maven.javadoc.failOnError>false</maven.javadoc.failOnError>
+        <maven-bundle-plugin.version>5.1.8</maven-bundle-plugin.version>
+        <maven-resources-plugin.version>3.1.0</maven-resources-plugin.version><!-- for Github CI -->
+        <cobertura-maven-plugin.version>2.7</cobertura-maven-plugin.version>
+        <maven-site-plugin.version>3.12.1</maven-site-plugin.version>
+        <maven-surefire-plugin.version>3.0.0-M7</maven-surefire-plugin.version>
+        <jdk9-illegal-access-level>deny</jdk9-illegal-access-level>
+    </properties>
+    <name>SnakeYAML</name>
+    <description>YAML 1.1 parser and emitter for Java</description>
+    <inceptionYear>2008</inceptionYear>
+    <url>https://bitbucket.org/snakeyaml/snakeyaml</url>
+    <issueManagement>
+        <system>Bitbucket</system>
+        <url>https://bitbucket.org/snakeyaml/snakeyaml/issues</url>
+    </issueManagement>
+    <mailingLists>
+        <mailingList>
+            <name>SnakeYAML developers and users List</name>
+            <post>snakeyaml-core@googlegroups.com</post>
+        </mailingList>
+    </mailingLists>
+    <scm>
+        <connection>scm:git:http://bitbucket.org/snakeyaml/snakeyaml</connection>
+        <developerConnection>scm:git:ssh://git@bitbucket.org/snakeyaml/snakeyaml</developerConnection>
+        <url>https://bitbucket.org/snakeyaml/snakeyaml/src</url>
+        <tag>snakeyaml-1.33</tag>
+    </scm>
+    <licenses>
+        <license>
+            <name>Apache License, Version 2.0</name>
+            <url>http://www.apache.org/licenses/LICENSE-2.0.txt</url>
+            <distribution>repo</distribution>
+        </license>
+    </licenses>
+    <developers>
+        <developer>
+            <id>asomov</id>
+            <name>Andrey Somov</name>
+            <email>public.somov@gmail.com</email>
+        </developer>
+        <developer>
+            <id>maslovalex</id>
+            <name>Alexander Maslov</name>
+            <email>alexander.maslov@gmail.com</email>
+        </developer>
+    </developers>
+    <dependencies>
+        <dependency>
+            <groupId>junit</groupId>
+            <artifactId>junit</artifactId>
+            <version>4.13.2</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.apache.velocity</groupId>
+            <artifactId>velocity-engine-core</artifactId>
+            <version>2.3</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>joda-time</groupId>
+            <artifactId>joda-time</artifactId>
+            <version>2.11.1</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.projectlombok</groupId>
+            <artifactId>lombok</artifactId>
+            <version>1.18.24</version>
+            <scope>test</scope>
+        </dependency>
+    </dependencies>
+    <distributionManagement>
+        <repository>
+            <id>sonatype-nexus-staging</id>
+            <name>Nexus Release Repository</name>
+            <url>${release.repo.url}</url>
+        </repository>
+        <snapshotRepository>
+            <id>sonatype-nexus-staging</id>
+            <name>Sonatype Nexus Snapshots</name>
+            <url>${snapshot.repo.url}</url>
+            <uniqueVersion>false</uniqueVersion>
+        </snapshotRepository>
+    </distributionManagement>
+    <build>
+        <testResources>
+            <testResource>
+                <directory>${basedir}/src/test/resources</directory>
+                <filtering>true</filtering>
+            </testResource>
+        </testResources>
+        <pluginManagement>
+            <plugins>
+                <plugin>
+                    <groupId>org.apache.maven.plugins</groupId>
+                    <artifactId>maven-resources-plugin</artifactId>
+                    <version>${maven-resources-plugin.version}</version>
+                </plugin>
+                <plugin>
+                    <groupId>org.apache.maven.plugins</groupId>
+                    <artifactId>maven-javadoc-plugin</artifactId>
+                    <version>3.4.1</version>
+                    <configuration>
+                        <excludePackageNames>org.yaml.snakeyaml.external.*</excludePackageNames>
+                    </configuration>
+                </plugin>
+                <plugin>
+                    <groupId>org.apache.maven.plugins</groupId>
+                    <artifactId>maven-site-plugin</artifactId>
+                    <version>${maven-site-plugin.version}</version>
+                </plugin>
+                <plugin>
+                    <groupId>org.apache.maven.plugins</groupId>
+                    <artifactId>maven-jar-plugin</artifactId>
+                    <version>3.2.2</version>
+                </plugin>
+                <plugin>
+                    <groupId>org.codehaus.mojo</groupId>
+                    <artifactId>cobertura-maven-plugin</artifactId>
+                    <version>${cobertura-maven-plugin.version}</version>
+                </plugin>
+                <plugin>
+                    <groupId>org.apache.maven.plugins</groupId>
+                    <artifactId>maven-compiler-plugin</artifactId>
+                    <version>3.10.1</version>
+                </plugin>
+                <plugin>
+                    <groupId>org.codehaus.mojo</groupId>
+                    <artifactId>build-helper-maven-plugin</artifactId>
+                    <version>3.3.0</version>
+                </plugin>
+                <plugin>
+                    <groupId>org.apache.maven.plugins</groupId>
+                    <artifactId>maven-surefire-plugin</artifactId>
+                    <version>${maven-surefire-plugin.version}</version>
+                    <configuration>
+                        <environmentVariables>
+                            <EnvironmentKey1>EnvironmentValue1</EnvironmentKey1>
+                            <EnvironmentEmpty />
+                        </environmentVariables>
+                    </configuration>
+                </plugin>
+            </plugins>
+        </pluginManagement>
+        <plugins>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-enforcer-plugin</artifactId>
+                <version>3.1.0</version>
+                <executions>
+                    <execution>
+                        <id>enforce-maven</id>
+                        <goals>
+                            <goal>enforce</goal>
+                        </goals>
+                        <configuration>
+                            <rules>
+                                <requireMavenVersion>
+                                    <version>3.3.0</version>
+                                </requireMavenVersion>
+                            </rules>
+                        </configuration>
+                    </execution>
+                </executions>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-compiler-plugin</artifactId>
+                <configuration>
+                    <source>${maven.compiler.source}</source>
+                    <target>${maven.compiler.target}</target>
+                    <encoding>${project.build.sourceEncoding}</encoding>
+                </configuration>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-surefire-plugin</artifactId>
+                <configuration>
+                    <argLine>-Xmx512m</argLine>
+                    <includes>
+                        <include>**/*Test.java</include>
+                    </includes>
+                    <excludes>
+                        <exclude>**/StressTest.java</exclude>
+                        <exclude>**/ParallelTest.java</exclude>
+                    </excludes>
+                </configuration>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-eclipse-plugin</artifactId>
+                <version>2.10</version>
+                <configuration>
+                    <buildOutputDirectory>bin</buildOutputDirectory>
+                </configuration>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-changes-plugin</artifactId>
+                <version>2.12.1</version>
+                <executions>
+                    <execution>
+                        <id>validate-changes</id>
+                        <phase>pre-site</phase>
+                        <goals>
+                            <goal>changes-validate</goal>
+                        </goals>
+                        <configuration>
+                            <failOnError>true</failOnError>
+                        </configuration>
+                    </execution>
+                </executions>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-source-plugin</artifactId>
+                <version>3.2.1</version>
+                <executions>
+                    <execution>
+                        <goals>
+                            <goal>jar-no-fork</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-javadoc-plugin</artifactId>
+                <version>3.4.1</version>
+                <executions>
+                    <execution>
+                        <id>attach-javadocs</id>
+                        <goals>
+                            <goal>jar</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+            <plugin>
+                <groupId>com.mycila.maven-license-plugin</groupId>
+                <artifactId>maven-license-plugin</artifactId>
+                <version>1.10.b1</version>
+                <configuration>
+                    <header>src/etc/header.txt</header>
+                    <quiet>false</quiet>
+                    <failIfMissing>true</failIfMissing>
+                    <aggregate>false</aggregate>
+                    <includes>
+                        <include>src/**/*.java</include>
+                    </includes>
+                    <excludes>
+                        <exclude>src/main/java/org/yaml/snakeyaml/external/**</exclude>
+                    </excludes>
+                    <useDefaultExcludes>true</useDefaultExcludes>
+                    <useDefaultMapping>true</useDefaultMapping>
+                    <strictCheck>true</strictCheck>
+                    <encoding>UTF-8</encoding>
+                </configuration>
+                <executions>
+                    <execution>
+                        <phase>site</phase>
+                        <goals>
+                            <goal>format</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.felix</groupId>
+                <artifactId>maven-bundle-plugin</artifactId>
+                <version>${maven-bundle-plugin.version}</version>
+                <extensions>true</extensions>
+                <configuration>
+                    <instructions>
+                        <_nouses>true</_nouses>
+                        <Export-Package>
+                            !org.yaml.snakeyaml.external*,
+                            org.yaml.snakeyaml.*;version=${project.version}
+                        </Export-Package>
+                        <Automatic-Module-Name>org.yaml.snakeyaml</Automatic-Module-Name>
+                    </instructions>
+                </configuration>
+            </plugin>
+            <plugin>
+                <artifactId>maven-site-plugin</artifactId>
+                <version>${maven-site-plugin.version}</version>
+                <executions>
+                    <execution>
+                        <id>attach-descriptor</id>
+                        <goals>
+                            <goal>attach-descriptor</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-release-plugin</artifactId>
+                <version>2.5.3</version>
+                <configuration>
+                    <autoVersionSubmodules>true</autoVersionSubmodules>
+                    <useReleaseProfile>false</useReleaseProfile>
+                    <releaseProfiles>android,release</releaseProfiles>
+                    <goals>deploy nexus-staging:release</goals>
+                </configuration>
+            </plugin>
+            <plugin>
+                <groupId>org.sonatype.plugins</groupId>
+                <artifactId>nexus-staging-maven-plugin</artifactId>
+                <!-- the version is compatible with Nexus, do not change -->
+                <version>1.6.8</version>
+                <extensions>true</extensions>
+                <configuration>
+                    <serverId>sonatype-nexus-staging</serverId>
+                    <nexusUrl>https://oss.sonatype.org/</nexusUrl>
+                    <autoReleaseAfterClose>false</autoReleaseAfterClose>
+                    <keepStagingRepositoryOnFailure>true</keepStagingRepositoryOnFailure>
+                    <keepStagingRepositoryOnCloseRuleFailure>true</keepStagingRepositoryOnCloseRuleFailure>
+                </configuration>
+            </plugin>
+        </plugins>
+    </build>
+    <reporting>
+        <plugins>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-changes-plugin</artifactId>
+                <version>2.12.1</version>
+                <configuration>
+                    <issueLinkTemplate>https://bitbucket.org/snakeyaml/snakeyaml/issues/%ISSUE%</issueLinkTemplate>
+                </configuration>
+                <reportSets>
+                    <reportSet>
+                        <reports>
+                            <report>changes-report</report>
+                        </reports>
+                    </reportSet>
+                </reportSets>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-surefire-report-plugin</artifactId>
+                <version>${maven-surefire-plugin.version}</version>
+                <configuration>
+                    <showSuccess>true</showSuccess>
+                </configuration>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-javadoc-plugin</artifactId>
+                <reportSets>
+                    <reportSet>
+                        <id>html</id>
+                        <configuration>
+                            <doctitle>API for ${project.name} ${project.version}</doctitle>
+                            <windowtitle>API for ${project.name} ${project.version}</windowtitle>
+                            <testDoctitle>Test API for ${project.name} ${project.version}</testDoctitle>
+                            <testWindowtitle>Test API for ${project.name} ${project.version}</testWindowtitle>
+                        </configuration>
+                        <reports>
+                            <report>javadoc</report>
+                        </reports>
+                    </reportSet>
+                </reportSets>
+            </plugin>
+        </plugins>
+    </reporting>
+    <profiles>
+        <profile>
+            <id>toolchain</id>
+            <activation>
+                <file>
+                    <exists>${user.home}/.m2/toolchains.xml</exists>
+                </file>
+            </activation>
+            <build>
+                <plugins>
+                    <plugin>
+                        <groupId>org.apache.maven.plugins</groupId>
+                        <artifactId>maven-toolchains-plugin</artifactId>
+                        <version>3.1.0</version>
+                        <executions>
+                            <execution>
+                                <phase>validate</phase>
+                                <goals>
+                                    <goal>toolchain</goal>
+                                </goals>
+                            </execution>
+                        </executions>
+                        <configuration>
+                            <toolchains>
+                                <jdk>
+                                    <version>${maven.compiler.testTarget}</version>
+                                </jdk>
+                            </toolchains>
+                        </configuration>
+                    </plugin>
+                </plugins>
+            </build>
+        </profile>
+        <profile>
+            <id>with-coverage</id>
+            <build>
+                <plugins>
+                    <plugin>
+                        <groupId>org.codehaus.mojo</groupId>
+                        <artifactId>cobertura-maven-plugin</artifactId>
+                        <configuration>
+                            <check>
+                                <totalBranchRate>80</totalBranchRate>
+                                <totalLineRate>95</totalLineRate>
+                            </check>
+                            <formats>
+                                <format>html</format>
+                                <format>xml</format>
+                            </formats>
+                            <instrumentation>
+                                <excludes>
+                                    <exclude>org/yaml/snakeyaml/external/**</exclude>
+                                </excludes>
+                            </instrumentation>
+                        </configuration>
+                        <executions>
+                            <execution>
+                                <goals>
+                                    <goal>clean</goal>
+                                    <goal>check</goal>
+                                </goals>
+                            </execution>
+                        </executions>
+                    </plugin>
+                </plugins>
+            </build>
+            <reporting>
+                <plugins>
+                    <plugin>
+                        <groupId>org.codehaus.mojo</groupId>
+                        <artifactId>cobertura-maven-plugin</artifactId>
+                        <configuration>
+                            <check>
+                                <branchRate>85</branchRate>
+                                <lineRate>85</lineRate>
+                                <haltOnFailure>true</haltOnFailure>
+                            </check>
+                            <formats>
+                                <format>html</format>
+                                <format>xml</format>
+                            </formats>
+                        </configuration>
+                        <reportSets>
+                            <reportSet>
+                                <reports>
+                                    <report>cobertura</report>
+                                </reports>
+                            </reportSet>
+                        </reportSets>
+                    </plugin>
+                </plugins>
+            </reporting>
+        </profile>
+        <profile>
+            <id>with-java8-tests</id>
+            <properties>
+                <maven.compiler.testSource>1.8</maven.compiler.testSource>
+                <maven.compiler.testTarget>1.8</maven.compiler.testTarget>
+            </properties>
+            <build>
+                <plugins>
+                    <plugin>
+                        <groupId>org.codehaus.mojo</groupId>
+                        <artifactId>build-helper-maven-plugin</artifactId>
+                        <executions>
+                            <execution>
+                                <id>add-java8-test-source</id>
+                                <phase>generate-test-sources</phase>
+                                <goals>
+                                    <goal>add-test-source</goal>
+                                </goals>
+                                <configuration>
+                                    <sources>
+                                        <source>${basedir}/src/test/java8/</source>
+                                    </sources>
+                                </configuration>
+                            </execution>
+                        </executions>
+                    </plugin>
+                </plugins>
+            </build>
+        </profile>
+        <profile>
+            <id>with-java11-tests</id>
+            <properties>
+                <maven.compiler.testSource>11</maven.compiler.testSource>
+                <maven.compiler.testTarget>11</maven.compiler.testTarget>
+            </properties>
+            <build>
+                <plugins>
+                    <plugin>
+                        <groupId>org.apache.maven.plugins</groupId>
+                        <artifactId>maven-surefire-plugin</artifactId>
+                        <configuration>
+                            <argLine>--illegal-access=${jdk9-illegal-access-level} -Xmx512m</argLine>
+                        </configuration>
+                    </plugin>
+                    <plugin>
+                        <groupId>org.apache.maven.plugins</groupId>
+                        <artifactId>maven-compiler-plugin</artifactId>
+                        <configuration>
+                            <compilerArgs>
+                                <!-- arg>-Xlint:unchecked</arg -->
+                                <arg>-Xlint:deprecation</arg>
+                            </compilerArgs>
+                        </configuration>
+                    </plugin>
+                    <plugin>
+                        <groupId>org.codehaus.mojo</groupId>
+                        <artifactId>build-helper-maven-plugin</artifactId>
+                        <executions>
+                            <execution>
+                                <id>add-java11-test-source</id>
+                                <phase>generate-test-sources</phase>
+                                <goals>
+                                    <goal>add-test-source</goal>
+                                </goals>
+                                <configuration>
+                                    <sources>
+                                        <source>${basedir}/src/test/java8/</source>
+                                        <source>${basedir}/src/test/java11/</source>
+                                    </sources>
+                                </configuration>
+                            </execution>
+                        </executions>
+                    </plugin>
+                </plugins>
+            </build>
+        </profile>
+        <profile>
+            <id>release</id>
+            <activation>
+                <property>
+                    <name>performRelease</name>
+                    <value>true</value>
+                </property>
+            </activation>
+            <build>
+                <plugins>
+                    <plugin>
+                        <groupId>org.apache.maven.plugins</groupId>
+                        <artifactId>maven-gpg-plugin</artifactId>
+                        <version>3.0.1</version>
+                        <executions>
+                            <execution>
+                                <id>sign-artifacts</id>
+                                <phase>verify</phase>
+                                <goals>
+                                    <goal>sign</goal>
+                                </goals>
+                            </execution>
+                        </executions>
+                    </plugin>
+                </plugins>
+            </build>
+        </profile>
+        <profile>
+            <id>findbugs</id>
+            <build>
+                <plugins>
+                    <plugin>
+                        <groupId>org.codehaus.mojo</groupId>
+                        <artifactId>findbugs-maven-plugin</artifactId>
+                        <version>3.0.5</version>
+                    </plugin>
+                    <plugin>
+                        <groupId>org.apache.maven.plugins</groupId>
+                        <artifactId>maven-pmd-plugin</artifactId>
+                        <version>3.19.0</version>
+                    </plugin>
+                </plugins>
+            </build>
+            <reporting>
+                <plugins>
+                    <plugin>
+                        <groupId>org.apache.maven.plugins</groupId>
+                        <artifactId>maven-jxr-plugin</artifactId>
+                        <version>3.3.0</version>
+                    </plugin>
+                    <plugin>
+                        <groupId>org.codehaus.mojo</groupId>
+                        <artifactId>findbugs-maven-plugin</artifactId>
+                        <version>3.0.5</version>
+                    </plugin>
+                    <plugin>
+                        <groupId>org.apache.maven.plugins</groupId>
+                        <artifactId>maven-pmd-plugin</artifactId>
+                        <version>3.19.0</version>
+                        <configuration>
+                            <linkXref>true</linkXref>
+                            <sourceEncoding>utf-8</sourceEncoding>
+                            <minimumTokens>100</minimumTokens>
+                            <targetJdk>1.8</targetJdk>
+                            <excludes>
+                                <exclude>**/external/*.java</exclude>
+                            </excludes>
+                        </configuration>
+                    </plugin>
+                </plugins>
+            </reporting>
+        </profile>
+        <profile>
+            <id>android</id>
+            <properties>
+                <android.src>${project.build.directory}/android/src</android.src>
+                <android.src.main>${android.src}/main/java</android.src.main>
+                <android.src.test>${android.src}/test/java</android.src.test>
+                <android.classes>${project.build.directory}/android/classes/</android.classes>
+                <android.test.classes>${project.build.directory}/android/test-classes/</android.test.classes>
+            </properties>
+            <build>
+                <plugins>
+                    <plugin>
+                        <groupId>org.apache.maven.plugins</groupId>
+                        <artifactId>maven-resources-plugin</artifactId>
+                        <version>${maven-resources-plugin.version}</version>
+                        <executions>
+                            <execution>
+                                <id>copy-src-for-android</id>
+                                <phase>generate-sources</phase>
+                                <goals>
+                                    <goal>copy-resources</goal>
+                                </goals>
+                                <configuration>
+                                    <outputDirectory>${android.src.main}</outputDirectory>
+                                    <resources>
+                                        <resource>
+                                            <directory>${basedir}/src/main/java</directory>
+                                            <filtering>false</filtering>
+                                            <excludes>
+                                                <exclude>org/yaml/snakeyaml/introspector/MethodProperty.java</exclude>
+                                            </excludes>
+                                        </resource>
+                                    </resources>
+                                </configuration>
+                            </execution>
+                            <execution>
+                                <id>copy-test-src-for-android</id>
+                                <phase>generate-sources</phase>
+                                <goals>
+                                    <goal>copy-resources</goal>
+                                </goals>
+                                <configuration>
+                                    <outputDirectory>${android.src.test}</outputDirectory>
+                                    <resources>
+                                        <resource>
+                                            <directory>${basedir}/src/test/java</directory>
+                                            <filtering>false</filtering>
+                                            <excludes>
+                                                <exclude>org/yaml/snakeyaml/introspector/MethodProperty.java</exclude>
+                                            </excludes>
+                                        </resource>
+                                    </resources>
+                                </configuration>
+                            </execution>
+                            <execution>
+                                <id>copy-test-resources-for-android</id>
+                                <phase>process-test-resources</phase>
+                                <goals>
+                                    <goal>copy-resources</goal>
+                                </goals>
+                                <configuration>
+                                    <outputDirectory>${android.test.classes}</outputDirectory>
+                                    <resources>
+                                        <resource>
+                                            <directory>${basedir}/src/test/resources</directory>
+                                            <filtering>true</filtering>
+                                        </resource>
+                                    </resources>
+                                </configuration>
+                            </execution>
+                        </executions>
+                    </plugin>
+
+                    <plugin>
+                        <groupId>org.apache.maven.plugins</groupId>
+                        <artifactId>maven-patch-plugin</artifactId>
+                        <version>1.2</version>
+                        <configuration>
+                            <patchDirectory>${basedir}/src/patches/android/</patchDirectory>
+                            <targetDirectory>${android.src}</targetDirectory>
+                            <skipApplication>false</skipApplication>
+                            <strip>2</strip>
+                        </configuration>
+                        <executions>
+                            <execution>
+                                <id>android-patches</id>
+                                <phase>process-sources</phase>
+                                <goals>
+                                    <goal>apply</goal>
+                                </goals>
+                                <configuration>
+                                    <patchTrackingFile>${project.build.directory}/android/patches-applied.txt</patchTrackingFile>
+                                    <naturalOrderProcessing>true</naturalOrderProcessing>
+                                </configuration>
+                            </execution>
+                        </executions>
+                    </plugin>
+                    <plugin>
+                        <groupId>org.apache.maven.plugins</groupId>
+                        <artifactId>maven-antrun-plugin</artifactId>
+                        <version>3.1.0</version>
+                        <executions>
+                            <execution>
+                                <id>build-for-android</id>
+                                <phase>compile</phase>
+                                <goals>
+                                    <goal>run</goal>
+                                </goals>
+                                <configuration>
+                                    <target>
+                                        <mkdir dir="${android.classes}" />
+                                        <mkdir dir="${android.test.classes}" />
+
+                                        <!-- compile patched sources -->
+                                        <javac srcdir="${android.src.main}" destdir="${android.classes}" classpath="${android.classes}" encoding="${project.build.sourceEncoding}" target="1.7" source="1.7" debug="true" includeantruntime="true" fork="true" />
+
+                                        <!-- compile test classes. Exclude some - not for BeanAccess.FIELD -->
+                                        <javac srcdir="${android.src.test}:${basedir}/src/test/resources" destdir="${android.test.classes}" classpath="${android.classes}:${android.test.classes}:${junit:junit:jar}:${org.apache.velocity:velocity:jar}:${joda-time:joda-time:jar}:${commons-io:commons-io:jar}:${commons-lang:commons-lang:jar}:${org.hamcrest:hamcrest-core:jar}:${org.projectlombok:lombok:jar}" encoding="${project.build.sourceEncoding}" target="1.7" source="1.7" debug="true" includeantruntime="true" fork="true">
+
+                                            <exclude name="org/yaml/snakeyaml/introspector/MethodPropertyTest.java" />
+                                            <exclude name="org/yaml/snakeyaml/representer/FilterPropertyToDumpTest.java" />
+                                            <exclude name="org/yaml/snakeyaml/issues/issue60/CustomOrderTest.java" />
+                                            <exclude name="org/yaml/snakeyaml/issues/issue29/FlexibleScalarStylesInJavaBeanTest.java" />
+                                            <!-- uses filtered resources. Additional tricks needed to be able to run under current build -->
+                                            <exclude name="org/yaml/snakeyaml/issues/issue318/ContextClassLoaderTest.java" />
+                                            <exclude name="org/yaml/snakeyaml/emitter/template/VelocityTest.java" />
+                                        </javac>
+                                    </target>
+
+                                </configuration>
+                            </execution>
+                        </executions>
+                    </plugin>
+                    <plugin>
+                        <artifactId>maven-surefire-plugin</artifactId>
+                        <executions>
+                            <execution>
+                                <id>test-android</id>
+                                <phase>test</phase>
+                                <goals>
+                                    <goal>test</goal>
+                                </goals>
+                                <configuration>
+                                    <classesDirectory>${android.classes}</classesDirectory>
+                                    <reportsDirectory>${project.build.directory}/android/surefire-reports</reportsDirectory>
+                                    <testClassesDirectory>${android.test.classes}</testClassesDirectory>
+                                    <!--
+                                    We ignore test failures for android build at the moment.
+                                    Most of the FAILs are because of testing with "property" not "field" access.
+                                    But we still fail whole build if there are test errors.
+                                    -->
+                                    <testFailureIgnore>true</testFailureIgnore>
+                                </configuration>
+                            </execution>
+                        </executions>
+                    </plugin>
+                    <plugin>
+                        <artifactId>maven-jar-plugin</artifactId>
+                        <executions>
+                            <execution>
+                                <id>package-android-jar</id>
+                                <phase>package</phase>
+                                <goals>
+                                    <goal>jar</goal>
+                                </goals>
+                                <configuration>
+                                    <classesDirectory>${android.classes}</classesDirectory>
+                                    <classifier>android</classifier>
+                                </configuration>
+                            </execution>
+                        </executions>
+                    </plugin>
+                </plugins>
+            </build>
+        </profile>
+        <profile>
+            <id>reformat</id>
+            <build>
+                <plugins>
+                    <plugin>
+                        <groupId>net.revelc.code.formatter</groupId>
+                        <artifactId>formatter-maven-plugin</artifactId>
+                        <executions>
+                            <execution>
+                                <goals>
+                                    <goal>format</goal>
+                                </goals>
+                                <configuration>
+                                    <configFile>src/etc/eclipse-java-google-style.xml</configFile>
+                                    <encoding>UTF-8</encoding>
+                                </configuration>
+                            </execution>
+                        </executions>
+                    </plugin>
+                </plugins>
+            </build>
+        </profile>
+    </profiles>
+</project>

+ 62 - 0
temp_knife4j/lib/springdoc-openapi-common-1.6.15.pom

@@ -0,0 +1,62 @@
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+	<modelVersion>4.0.0</modelVersion>
+	<parent>
+		<groupId>org.springdoc</groupId>
+		<artifactId>springdoc-openapi</artifactId>
+		<version>1.6.15</version>
+	</parent>
+	<artifactId>springdoc-openapi-common</artifactId>
+	<dependencies>
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-autoconfigure</artifactId>
+		</dependency>
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-configuration-processor</artifactId>
+			<optional>true</optional>
+		</dependency>
+		<dependency>
+			<groupId>org.springframework</groupId>
+			<artifactId>spring-web</artifactId>
+		</dependency>
+		<dependency>
+			<groupId>io.swagger.core.v3</groupId>
+			<artifactId>swagger-core</artifactId>
+		</dependency>
+		<!-- Actuator dependencies -->
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-starter-actuator</artifactId>
+			<optional>true</optional>
+		</dependency>
+		<!-- For Enhanced Pageable Support -->
+		<dependency>
+			<groupId>org.springframework.data</groupId>
+			<artifactId>spring-data-rest-core</artifactId>
+			<optional>true</optional>
+		</dependency>
+		<!-- For Spring Cloud Function Support -->
+		<dependency>
+			<groupId>org.springframework.cloud</groupId>
+			<artifactId>spring-cloud-function-web</artifactId>
+			<optional>true</optional>
+		</dependency>
+	</dependencies>
+	<build>
+		<plugins>
+			<plugin>
+				<groupId>org.apache.maven.plugins</groupId>
+				<artifactId>maven-jar-plugin</artifactId>
+				<configuration>
+					<archive>
+						<manifestEntries>
+							<Automatic-Module-Name>org.springdoc.openapi.common
+							</Automatic-Module-Name>
+						</manifestEntries>
+					</archive>
+				</configuration>
+			</plugin>
+		</plugins>
+	</build>
+</project>

+ 67 - 0
temp_knife4j/lib/springdoc-openapi-ui-1.6.15.pom

@@ -0,0 +1,67 @@
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+	<modelVersion>4.0.0</modelVersion>
+	<parent>
+		<groupId>org.springdoc</groupId>
+		<artifactId>springdoc-openapi</artifactId>
+		<version>1.6.15</version>
+	</parent>
+	<artifactId>springdoc-openapi-ui</artifactId>
+	<dependencies>
+		<!-- springdoc-core -->
+		<dependency>
+			<groupId>org.springdoc</groupId>
+			<artifactId>springdoc-openapi-webmvc-core</artifactId>
+			<version>${project.version}</version>
+		</dependency>
+		<dependency>
+			<groupId>jakarta.servlet</groupId>
+			<artifactId>jakarta.servlet-api</artifactId>
+			<scope>provided</scope>
+		</dependency>
+		<!-- swagger-ui dependencies -->
+		<dependency>
+			<groupId>org.webjars</groupId>
+			<artifactId>swagger-ui</artifactId>
+		</dependency>
+		<dependency>
+			<groupId>org.webjars</groupId>
+			<artifactId>webjars-locator-core</artifactId>
+		</dependency>
+		<dependency>
+			<groupId>io.github.classgraph</groupId>
+			<artifactId>classgraph</artifactId>
+		</dependency>
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-starter-security</artifactId>
+			<scope>test</scope>
+		</dependency>
+		<!-- Actuator dependencies -->
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-starter-actuator</artifactId>
+			<optional>true</optional>
+		</dependency>
+		<dependency>
+			<groupId>org.apache.tomcat.embed</groupId>
+			<artifactId>tomcat-embed-core</artifactId>
+			<scope>test</scope>
+		</dependency>
+	</dependencies>
+	<build>
+		<plugins>
+			<plugin>
+				<groupId>org.apache.maven.plugins</groupId>
+				<artifactId>maven-jar-plugin</artifactId>
+				<configuration>
+					<archive>
+						<manifestEntries>
+							<Automatic-Module-Name>org.springdoc.openapi.ui
+							</Automatic-Module-Name>
+						</manifestEntries>
+					</archive>
+				</configuration>
+			</plugin>
+		</plugins>
+	</build>
+</project>

+ 59 - 0
temp_knife4j/lib/springdoc-openapi-webflux-core-1.6.15.pom

@@ -0,0 +1,59 @@
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+	<modelVersion>4.0.0</modelVersion>
+	<parent>
+		<groupId>org.springdoc</groupId>
+		<artifactId>springdoc-openapi</artifactId>
+		<version>1.6.15</version>
+	</parent>
+	<artifactId>springdoc-openapi-webflux-core</artifactId>
+	<dependencies>
+		<!-- springdoc-common -->
+		<dependency>
+			<groupId>org.springdoc</groupId>
+			<artifactId>springdoc-openapi-common</artifactId>
+			<version>${project.version}</version>
+		</dependency>
+		<dependency>
+			<groupId>org.springframework</groupId>
+			<artifactId>spring-webflux</artifactId>
+		</dependency>
+		<!-- Actuator dependencies -->
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-starter-actuator</artifactId>
+			<optional>true</optional>
+		</dependency>
+		<dependency>
+			<groupId>io.projectreactor.netty</groupId>
+			<artifactId>reactor-netty-http</artifactId>
+			<scope>test</scope>
+		</dependency>
+		<dependency>
+			<groupId>org.springframework.cloud</groupId>
+			<artifactId>spring-cloud-starter-function-webflux</artifactId>
+			<scope>test</scope>
+		</dependency>
+		<dependency>
+			<groupId>io.netty</groupId>
+			<artifactId>netty-resolver-dns-native-macos</artifactId>
+			<classifier>osx-aarch_64</classifier>
+			<scope>test</scope>
+		</dependency>
+	</dependencies>
+	<build>
+		<plugins>
+			<plugin>
+				<groupId>org.apache.maven.plugins</groupId>
+				<artifactId>maven-jar-plugin</artifactId>
+				<configuration>
+					<archive>
+						<manifestEntries>
+							<Automatic-Module-Name>org.springdoc.openapi.webflux.core
+							</Automatic-Module-Name>
+						</manifestEntries>
+					</archive>
+				</configuration>
+			</plugin>
+		</plugins>
+	</build>
+</project>

+ 74 - 0
temp_knife4j/lib/springdoc-openapi-webmvc-core-1.6.15.pom

@@ -0,0 +1,74 @@
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+	<modelVersion>4.0.0</modelVersion>
+	<parent>
+		<groupId>org.springdoc</groupId>
+		<artifactId>springdoc-openapi</artifactId>
+		<version>1.6.15</version>
+	</parent>
+	<artifactId>springdoc-openapi-webmvc-core</artifactId>
+	<dependencies>
+		<!-- springdoc-common -->
+		<dependency>
+			<groupId>org.springdoc</groupId>
+			<artifactId>springdoc-openapi-common</artifactId>
+			<version>${project.version}</version>
+		</dependency>
+		<dependency>
+			<groupId>org.springframework</groupId>
+			<artifactId>spring-webmvc</artifactId>
+		</dependency>
+		<!-- Actuator dependencies -->
+		<dependency>
+			<groupId>org.springframework.boot</groupId>
+			<artifactId>spring-boot-starter-actuator</artifactId>
+			<optional>true</optional>
+		</dependency>
+		<dependency>
+			<groupId>jakarta.servlet</groupId>
+			<artifactId>jakarta.servlet-api</artifactId>
+			<scope>provided</scope>
+		</dependency>
+		<dependency>
+			<groupId>javax.money</groupId>
+			<artifactId>money-api</artifactId>
+			<scope>test</scope>
+		</dependency>
+		<dependency>
+			<groupId>org.hibernate.validator</groupId>
+			<artifactId>hibernate-validator</artifactId>
+			<scope>test</scope>
+		</dependency>
+		<dependency>
+			<groupId>org.apache.tomcat.embed</groupId>
+			<artifactId>tomcat-embed-core</artifactId>
+			<scope>test</scope>
+		</dependency>
+		<!-- For Enhanced Pageable Support -->
+		<dependency>
+			<groupId>org.springframework.data</groupId>
+			<artifactId>spring-data-rest-core</artifactId>
+			<scope>test</scope>
+		</dependency>
+		<dependency>
+			<groupId>org.springframework.cloud</groupId>
+			<artifactId>spring-cloud-starter-function-web</artifactId>
+			<scope>test</scope>
+		</dependency>
+	</dependencies>
+	<build>
+		<plugins>
+			<plugin>
+				<groupId>org.apache.maven.plugins</groupId>
+				<artifactId>maven-jar-plugin</artifactId>
+				<configuration>
+					<archive>
+						<manifestEntries>
+							<Automatic-Module-Name>org.springdoc.openapi.webmvc.core
+							</Automatic-Module-Name>
+						</manifestEntries>
+					</archive>
+				</configuration>
+			</plugin>
+		</plugins>
+	</build>
+</project>

+ 119 - 0
temp_knife4j/lib/swagger-annotations-2.2.8.pom

@@ -0,0 +1,119 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+    <parent>
+        <groupId>io.swagger.core.v3</groupId>
+        <artifactId>swagger-project</artifactId>
+        <version>2.2.8</version>
+        <relativePath>../..</relativePath>
+    </parent>
+    <modelVersion>4.0.0</modelVersion>
+    <artifactId>swagger-annotations</artifactId>
+    <name>swagger-annotations</name>
+    <description>swagger-annotations</description>
+    <build>
+        <sourceDirectory>src/main/java</sourceDirectory>
+        <defaultGoal>install</defaultGoal>
+        <plugins>
+            <plugin>
+                <groupId>biz.aQute.bnd</groupId>
+                <artifactId>bnd-maven-plugin</artifactId>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-jar-plugin</artifactId>
+                <configuration>
+                    <archive>
+                        <manifestFile>${project.build.outputDirectory}/META-INF/MANIFEST.MF</manifestFile>
+                        <manifestEntries>
+                            <Automatic-Module-Name>io.swagger.v3.oas.annotations</Automatic-Module-Name>
+                        </manifestEntries>
+                    </archive>
+                </configuration>
+            </plugin>
+            <plugin>
+                <groupId>io.swagger.core.v3</groupId>
+                <artifactId>swagger-eclipse-transformer-maven-plugin</artifactId>
+                <version>${project.version}</version>
+                <configuration>
+                    <attach>false</attach>
+                    <classifier>jakarta</classifier>
+                    <outputDirectory>${project.basedir}/../swagger-project-jakarta/modules/${project.artifactId}-jakarta/transformed</outputDirectory>
+                </configuration>
+                <executions>
+                    <execution>
+                        <id>transform-jakarta</id>
+                        <goals>
+                            <goal>run</goal>
+                        </goals>
+                        <phase>package</phase>
+                    </execution>
+                </executions>
+            </plugin>
+        </plugins>
+    </build>
+    <profiles>
+        <profile>
+            <!-- this is used during release (see CI/CI.md file for details) to prepare javadocs for publishing to gh-pages -->
+            <id>release</id>
+            <build>
+                <plugins>
+                    <plugin>
+                        <groupId>org.apache.maven.plugins</groupId>
+                        <artifactId>maven-enforcer-plugin</artifactId>
+                        <version>${enforcer-plugin-version}</version>
+                        <executions>
+                            <execution>
+                                <id>enforce-no-snapshots</id>
+                                <goals>
+                                    <goal>enforce</goal>
+                                </goals>
+                                <configuration>
+                                    <rules>
+                                        <requireReleaseVersion>
+                                            <message>Publish javadocs for a SNAPSHOT is not allowed.</message>
+                                        </requireReleaseVersion>
+                                    </rules>
+                                    <fail>true</fail>
+                                </configuration>
+                            </execution>
+                        </executions>
+                    </plugin>
+                    <plugin>
+                        <artifactId>maven-resources-plugin</artifactId>
+                        <version>3.1.0</version>
+                        <executions>
+                            <execution>
+                                <id>copy-resources</id>
+                                <phase>deploy</phase>
+                                <goals>
+                                    <goal>copy-resources</goal>
+                                </goals>
+                                <configuration>
+                                    <outputDirectory>${project.build.directory}/javadocprep/swagger-core/${project.version}/apidocs</outputDirectory>
+                                    <resources>
+                                        <resource>
+                                            <directory>${project.build.directory}/apidocs</directory>
+                                            <filtering>true</filtering>
+                                        </resource>
+                                    </resources>
+                                </configuration>
+                            </execution>
+                        </executions>
+                    </plugin>
+                </plugins>
+            </build>
+        </profile>
+    </profiles>
+    <dependencies>
+        <dependency>
+            <groupId>jakarta.ws.rs</groupId>
+            <artifactId>jakarta.ws.rs-api</artifactId>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.testng</groupId>
+            <artifactId>testng</artifactId>
+            <scope>test</scope>
+        </dependency>
+    </dependencies>
+</project>

+ 175 - 0
temp_knife4j/lib/swagger-core-2.2.8.pom

@@ -0,0 +1,175 @@
+<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://maven.apache.org/POM/4.0.0"
+         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
+    <parent>
+        <groupId>io.swagger.core.v3</groupId>
+        <artifactId>swagger-project</artifactId>
+        <version>2.2.8</version>
+        <relativePath>../..</relativePath>
+    </parent>
+    <modelVersion>4.0.0</modelVersion>
+    <artifactId>swagger-core</artifactId>
+    <name>swagger-core</name>
+    <description>swagger-core</description>
+    <build>
+        <sourceDirectory>src/main/java</sourceDirectory>
+        <defaultGoal>install</defaultGoal>
+        <plugins>
+            <plugin>
+                <groupId>biz.aQute.bnd</groupId>
+                <artifactId>bnd-maven-plugin</artifactId>
+                <configuration>
+                    <bnd>
+                        Import-Package: javax.validation.constraints;version="[1.1,3)",*
+                    </bnd>
+                </configuration>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-jar-plugin</artifactId>
+                <version>3.2.0</version>
+                <executions>
+                    <execution>
+                        <id>default-jar</id>
+                        <configuration>
+                            <archive>
+                                <manifestFile>${project.build.outputDirectory}/META-INF/MANIFEST.MF</manifestFile>
+                                <manifestEntries>
+                                    <Automatic-Module-Name>io.swagger.v3.core</Automatic-Module-Name>
+                                </manifestEntries>
+                            </archive>
+                        </configuration>
+                    </execution>
+                    <execution>
+                        <goals>
+                            <goal>test-jar</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+            <plugin>
+                <groupId>io.swagger.core.v3</groupId>
+                <artifactId>swagger-eclipse-transformer-maven-plugin</artifactId>
+                <version>${project.version}</version>
+                <configuration>
+                    <attach>false</attach>
+                    <classifier>jakarta</classifier>
+                    <outputDirectory>${project.basedir}/../swagger-project-jakarta/modules/${project.artifactId}-jakarta/transformed</outputDirectory>
+                </configuration>
+                <executions>
+                    <execution>
+                        <id>transform-jakarta</id>
+                        <goals>
+                            <goal>run</goal>
+                        </goals>
+                        <phase>package</phase>
+                    </execution>
+                </executions>
+            </plugin>
+        </plugins>
+    </build>
+    <dependencies>
+        <dependency>
+            <groupId>jakarta.xml.bind</groupId>
+            <artifactId>jakarta.xml.bind-api</artifactId>
+            <version>2.3.2</version>
+        </dependency>
+        <dependency>
+            <groupId>org.apache.commons</groupId>
+            <artifactId>commons-lang3</artifactId>
+        </dependency>
+        <dependency>
+            <groupId>org.slf4j</groupId>
+            <artifactId>slf4j-api</artifactId>
+        </dependency>
+        <dependency>
+            <groupId>com.fasterxml.jackson.core</groupId>
+            <artifactId>jackson-annotations</artifactId>
+        </dependency>
+        <dependency>
+            <groupId>com.fasterxml.jackson.core</groupId>
+            <artifactId>jackson-databind</artifactId>
+        </dependency>
+        <dependency>
+            <groupId>com.fasterxml.jackson.dataformat</groupId>
+            <artifactId>jackson-dataformat-yaml</artifactId>
+        </dependency>
+        <dependency>
+            <groupId>com.fasterxml.jackson.datatype</groupId>
+            <artifactId>jackson-datatype-jsr310</artifactId>
+        </dependency>
+        <dependency>
+            <groupId>io.swagger.core.v3</groupId>
+            <artifactId>swagger-annotations</artifactId>
+            <version>${project.parent.version}</version>
+        </dependency>
+        <dependency>
+            <groupId>org.yaml</groupId>
+            <artifactId>snakeyaml</artifactId>
+            <version>${snakeyaml-version}</version>
+        </dependency>
+        <dependency>
+            <groupId>io.swagger.core.v3</groupId>
+            <artifactId>swagger-models</artifactId>
+            <version>${project.parent.version}</version>
+        </dependency>
+        <dependency>
+            <groupId>joda-time</groupId>
+            <artifactId>joda-time</artifactId>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>com.google.guava</groupId>
+            <artifactId>guava</artifactId>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.joda</groupId>
+            <artifactId>joda-convert</artifactId>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>ch.qos.logback</groupId>
+            <artifactId>logback-classic</artifactId>
+            <scope>provided</scope>
+        </dependency>
+        <dependency>
+            <groupId>ch.qos.logback</groupId>
+            <artifactId>logback-core</artifactId>
+            <scope>provided</scope>
+        </dependency>
+        <dependency>
+            <groupId>jakarta.validation</groupId>
+            <artifactId>jakarta.validation-api</artifactId>
+            <version>${validation-api-version}</version>
+        </dependency>
+        <dependency>
+            <groupId>org.testng</groupId>
+            <artifactId>testng</artifactId>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>commons-io</groupId>
+            <artifactId>commons-io</artifactId>
+        </dependency>
+        <dependency>
+            <groupId>jakarta.ws.rs</groupId>
+            <artifactId>jakarta.ws.rs-api</artifactId>
+            <version>${jakarta-ws-rs-api-version}</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>jakarta.inject</groupId>
+            <artifactId>jakarta.inject-api</artifactId>
+            <version>1.0</version>
+            <scope>test</scope>
+        </dependency>
+    </dependencies>
+    <properties>
+        <!-- TODO increase coverage -->
+        <validation-api-version>2.0.2</validation-api-version>
+        <jakarta-ws-rs-api-version>2.1.6</jakarta-ws-rs-api-version>
+        <coverage.complexity.minimum>0.60</coverage.complexity.minimum>
+        <coverage.line.minimum>0.0</coverage.line.minimum>
+        <coverage.missed.classes>3</coverage.missed.classes>
+    </properties>
+</project>

+ 103 - 0
temp_knife4j/lib/swagger-models-2.2.8.pom

@@ -0,0 +1,103 @@
+<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+	xmlns="http://maven.apache.org/POM/4.0.0"
+	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
+    <parent>
+        <groupId>io.swagger.core.v3</groupId>
+        <artifactId>swagger-project</artifactId>
+        <version>2.2.8</version>
+        <relativePath>../..</relativePath>
+    </parent>
+    <modelVersion>4.0.0</modelVersion>
+    <artifactId>swagger-models</artifactId>
+    <name>swagger-models</name>
+    <description>swagger-models</description>
+    <build>
+        <sourceDirectory>src/main/java</sourceDirectory>
+        <defaultGoal>install</defaultGoal>
+        <testResources>
+            <testResource>
+                <directory>src/test/resources</directory>
+            </testResource>
+        </testResources>
+        <plugins>
+            <plugin>
+                <groupId>biz.aQute.bnd</groupId>
+                <artifactId>bnd-maven-plugin</artifactId>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-jar-plugin</artifactId>
+                <configuration>
+                    <archive>
+                        <manifestFile>${project.build.outputDirectory}/META-INF/MANIFEST.MF</manifestFile>
+                        <manifestEntries>
+                            <Automatic-Module-Name>io.swagger.v3.oas.models</Automatic-Module-Name>
+                        </manifestEntries>
+                    </archive>
+                </configuration>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-surefire-plugin</artifactId>
+                <version>2.22.2</version>
+                <configuration>
+                    <argLine>-Djdk.attach.allowAttachSelf</argLine>
+                </configuration>
+            </plugin>
+            <plugin>
+                <groupId>io.swagger.core.v3</groupId>
+                <artifactId>swagger-eclipse-transformer-maven-plugin</artifactId>
+                <version>${project.version}</version>
+                <configuration>
+                    <attach>false</attach>
+                    <classifier>jakarta</classifier>
+                    <outputDirectory>${project.basedir}/../swagger-project-jakarta/modules/${project.artifactId}-jakarta/transformed</outputDirectory>
+                </configuration>
+                <executions>
+                    <execution>
+                        <id>transform-jakarta</id>
+                        <goals>
+                            <goal>run</goal>
+                        </goals>
+                        <phase>package</phase>
+                    </execution>
+                </executions>
+            </plugin>
+        </plugins>
+    </build>
+    <dependencies>
+        <dependency>
+            <groupId>com.fasterxml.jackson.core</groupId>
+            <artifactId>jackson-core</artifactId>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>com.fasterxml.jackson.core</groupId>
+            <artifactId>jackson-databind</artifactId>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.testng</groupId>
+            <artifactId>testng</artifactId>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.jmockit</groupId>
+            <artifactId>jmockit</artifactId>
+            <version>${jmockit-version}</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>com.fasterxml.jackson.core</groupId>
+            <artifactId>jackson-annotations</artifactId>
+        </dependency>
+    </dependencies>
+
+
+    <properties>
+        <coverage.complexity.minimum>0.07</coverage.complexity.minimum>
+        <coverage.line.minimum>0.0</coverage.line.minimum>
+        <jmockit-version>1.39</jmockit-version>
+        <mockito-version>2.16.0</mockito-version>
+    </properties>
+</project>

+ 154 - 0
temp_knife4j/lib/swagger-ui-4.17.1.pom

@@ -0,0 +1,154 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
+    <modelVersion>4.0.0</modelVersion>
+
+    <parent>
+        <groupId>org.sonatype.oss</groupId>
+        <artifactId>oss-parent</artifactId>
+        <version>9</version>
+    </parent>
+    
+    <packaging>jar</packaging>
+    <groupId>org.webjars</groupId>
+    <artifactId>swagger-ui</artifactId>
+    <version>4.17.1</version>
+    <name>Swagger UI</name>
+    <description>WebJar for Swagger UI</description>
+    <url>http://webjars.org</url>
+
+    <properties>
+        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
+        <project.build.outputTimestamp>1678121547</project.build.outputTimestamp>
+        <upstream.url>https://github.com/swagger-api/swagger-ui/archive/v${version.unsnapshot}.zip</upstream.url>
+        <destDir>${project.build.outputDirectory}/META-INF/resources/webjars/${project.artifactId}/${project.version}</destDir>
+        <requirejs>
+            {
+                "paths": { "swagger-ui": "swagger-ui" }
+            }
+        </requirejs>
+    </properties>
+
+    <developers>
+        <developer>
+            <id>jamesward</id>
+            <name>James Ward</name>
+            <email>james@jamesward.com</email>
+        </developer>
+    </developers>
+
+    <licenses>
+        <license>
+            <name>Apache 2.0</name>
+            <url>https://github.com/swagger-api/swagger-ui</url>
+            <distribution>repo</distribution>
+        </license>
+    </licenses>
+
+    <scm>
+        <url>http://github.com/webjars/swagger-ui</url>
+        <connection>scm:git:https://github.com/webjars/swagger-ui.git</connection>
+        <developerConnection>scm:git:https://github.com/webjars/swagger-ui.git</developerConnection>
+        <tag>swagger-ui-4.17.1</tag>
+    </scm>
+    
+    <build>
+        <plugins>
+            <plugin>
+                <groupId>com.jamesward</groupId>
+                <artifactId>unsnapshot-maven-plugin</artifactId>
+                <version>0.2</version>
+                <executions>
+                    <execution>
+                        <phase>initialize</phase>
+                        <goals>
+                            <goal>unsnapshot</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+
+            <plugin>
+                <artifactId>maven-jar-plugin</artifactId>
+                <version>3.2.2</version>
+                <configuration>
+                    <archive>  
+                        <manifestFile>${project.build.outputDirectory}/META-INF/MANIFEST.MF</manifestFile>
+                    </archive> 
+                </configuration>
+            </plugin>  
+
+            <plugin>
+                <groupId>org.apache.felix</groupId>
+                <artifactId>maven-bundle-plugin</artifactId>
+                <version>5.1.4</version>
+                <extensions>true</extensions>
+                <executions>
+                    <execution>
+                        <id>bundle-manifest</id>
+                        <phase>process-classes</phase>
+                        <goals>    
+                            <goal>manifest</goal>
+                        </goals>   
+                    </execution>
+                </executions>                
+            </plugin>
+
+            <plugin>
+                <artifactId>maven-antrun-plugin</artifactId>
+                <version>1.8</version>
+                <executions>
+                    <execution>
+                        <phase>process-resources</phase>
+                        <goals><goal>run</goal></goals>
+                        <configuration>
+                            <target>
+                                <echo message="download archive" />
+                                <get src="${upstream.url}" dest="${project.build.directory}/${project.artifactId}.zip" />
+                                <echo message="unzip archive" />
+                                <unzip src="${project.build.directory}/${project.artifactId}.zip" dest="${project.build.directory}" />
+                                <echo message="moving resources" />
+                                <move todir="${destDir}">
+                                    <fileset dir="${project.build.directory}/swagger-ui-${version.unsnapshot}/dist" />
+                                </move>
+                            </target>
+                        </configuration>
+                    </execution>
+                </executions>
+            </plugin>
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-release-plugin</artifactId>
+                <version>3.0.0-M7</version>
+            </plugin>
+            <plugin>
+                <groupId>com.googlecode.todomap</groupId>
+                <artifactId>maven-jettygzip-plugin</artifactId>
+                <version>0.0.4</version>
+                <configuration>
+                    <webappDirectory>target/classes</webappDirectory>
+                    <outputDirectory>target/classes</outputDirectory>
+                </configuration>
+                <executions>
+                    <execution>
+                        <phase>prepare-package</phase>
+                        <goals>
+                            <goal>process</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+            <plugin>
+                <groupId>org.sonatype.plugins</groupId>
+                <artifactId>nexus-staging-maven-plugin</artifactId>
+                <version>1.6.13</version>
+                <extensions>true</extensions>
+                <configuration>
+                    <serverId>sonatype-nexus-staging</serverId>
+                    <nexusUrl>https://oss.sonatype.org/</nexusUrl>
+                    <autoReleaseAfterClose>true</autoReleaseAfterClose>
+                </configuration>
+            </plugin>
+        </plugins>
+    </build>
+
+</project>

+ 349 - 0
temp_knife4j/lib/webjars-locator-core-0.52.pom

@@ -0,0 +1,349 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+    <modelVersion>4.0.0</modelVersion>
+
+    <parent>
+        <groupId>org.sonatype.oss</groupId>
+        <artifactId>oss-parent</artifactId>
+        <version>9</version>
+    </parent>
+
+    <packaging>jar</packaging>
+    <groupId>org.webjars</groupId>
+    <artifactId>webjars-locator-core</artifactId>
+    <version>0.52</version>
+    <name>webjars-locator-core</name>
+    <description>WebJar Locator Core functionality</description>
+    <inceptionYear>2012</inceptionYear>
+    <url>http://webjars.org</url>
+
+    <licenses>
+        <license>
+            <name>MIT</name>
+            <url>https://github.com/webjars/webjars-locator-core/blob/master/LICENSE.md</url>
+            <distribution>repo</distribution>
+        </license>
+    </licenses>
+
+    <scm>
+        <url>http://github.com/webjars/webjars-locator-core</url>
+        <connection>scm:git:https://github.com/webjars/webjars-locator-core.git</connection>
+        <developerConnection>scm:git:https://github.com/webjars/webjars-locator-core.git</developerConnection>
+        <tag>webjars-locator-core-0.52</tag>
+    </scm>
+
+    <developers>
+        <developer>
+            <id>jamesward</id>
+            <name>James Ward</name>
+            <email>james@jamesward.org</email>
+        </developer>
+    </developers>
+
+    <properties>
+        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
+        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
+        <project.build.outputTimestamp>1656438961</project.build.outputTimestamp>
+        <slf4j.version>1.7.36</slf4j.version>
+        <springboot.version>2.6.3</springboot.version>
+    </properties>
+
+    <issueManagement>
+        <system>GitHub Issues</system>
+        <url>https://github.com/webjars/webjars-locator-core/issues</url>
+    </issueManagement>
+
+    <ciManagement>
+        <system>GitHub Actions</system>
+        <url>https://github.com/webjars/webjars-locator-core/actions</url>
+    </ciManagement>
+
+    <dependencies>
+        <dependency>
+            <groupId>org.slf4j</groupId>
+            <artifactId>slf4j-api</artifactId>
+            <version>${slf4j.version}</version>
+        </dependency>
+        <dependency>
+            <groupId>io.github.classgraph</groupId>
+            <artifactId>classgraph</artifactId>
+            <version>4.8.147</version>
+        </dependency>
+        <dependency>
+            <groupId>com.fasterxml.jackson.core</groupId>
+            <artifactId>jackson-core</artifactId>
+            <version>2.13.3</version>
+        </dependency>
+        <dependency>
+            <groupId>com.google.code.findbugs</groupId>
+            <artifactId>jsr305</artifactId>
+            <version>3.0.2</version>
+            <scope>provided</scope>
+        </dependency>
+
+        <dependency>
+            <groupId>org.slf4j</groupId>
+            <artifactId>slf4j-simple</artifactId>
+            <version>${slf4j.version}</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars</groupId>
+            <artifactId>bootstrap</artifactId>
+            <version>3.1.1-1</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars</groupId>
+            <artifactId>bootswatch-yeti</artifactId>
+            <version>3.1.1</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars</groupId>
+            <artifactId>less-node</artifactId>
+            <version>1.6.0-1</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>junit</groupId>
+            <artifactId>junit</artifactId>
+            <version>4.13.2</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.mockito</groupId>
+            <artifactId>mockito-core</artifactId>
+            <version>3.1.0</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars</groupId>
+            <artifactId>jquery</artifactId>
+            <version>2.1.0-3</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars</groupId>
+            <artifactId>angularjs</artifactId>
+            <version>1.2.11</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars</groupId>
+            <artifactId>angular-translate</artifactId>
+            <version>2.1.0</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars</groupId>
+            <artifactId>angular-tree-control</artifactId>
+            <version>0.1.5-1</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars.npm</groupId>
+            <artifactId>angular-ui-router</artifactId>
+            <version>0.2.15</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars</groupId>
+            <artifactId>requirejs</artifactId>
+            <version>2.3.6</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars</groupId>
+            <artifactId>when-node</artifactId>
+            <version>3.5.2-2</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars</groupId>
+            <artifactId>select2</artifactId>
+            <version>3.5.2-1</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars.npm</groupId>
+            <artifactId>babel-core</artifactId>
+            <version>6.0.16</version>
+            <scope>test</scope>
+            <exclusions>
+                <exclusion>
+                    <groupId>org.webjars.npm</groupId>
+                    <artifactId>*</artifactId>
+                </exclusion>
+            </exclusions>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars.npm</groupId>
+            <artifactId>util</artifactId>
+            <version>0.10.3</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars.npm</groupId>
+            <artifactId>virtual-keyboard</artifactId>
+            <version>1.30.1</version>
+            <scope>test</scope>
+            <exclusions>
+                <exclusion>
+                    <groupId>org.webjars.npm</groupId>
+                    <artifactId>*</artifactId>
+                </exclusion>
+            </exclusions>
+        </dependency>
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot-loader</artifactId>
+            <version>${springboot.version}</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot-loader-tools</artifactId>
+            <version>${springboot.version}</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars.npm</groupId>
+            <artifactId>rxjs</artifactId>
+            <version>5.0.0-beta.12</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot</artifactId>
+            <version>${springboot.version}</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.springframework.boot</groupId>
+            <artifactId>spring-boot-starter-tomcat</artifactId>
+            <version>${springboot.version}</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars.bowergithub.vaadin</groupId>
+            <artifactId>vaadin-form-layout</artifactId>
+            <version>2.1.5</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars.npm</groupId>
+            <artifactId>angular__http</artifactId>
+            <version>2.4.10</version>
+            <scope>test</scope>
+        </dependency>
+        <dependency>
+            <groupId>org.webjars.npm</groupId>
+            <artifactId>swagger-ui-dist</artifactId>
+            <version>3.25.0</version>
+            <scope>test</scope>
+        </dependency>
+    </dependencies>
+
+    <build>
+        <plugins>
+
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-resources-plugin</artifactId>
+                <version>3.2.0</version>
+            </plugin>
+
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-surefire-plugin</artifactId>
+                <version>3.0.0-M7</version>
+            </plugin>
+
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-javadoc-plugin</artifactId>
+                <version>3.4.0</version>
+                <executions>
+                    <execution>
+                        <id>attach-javadocs</id>
+                        <goals>
+                            <goal>jar</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-source-plugin</artifactId>
+                <version>3.2.1</version>
+                <executions>
+                    <execution>
+                        <id>attach-sources</id>
+                        <goals>
+                            <goal>jar-no-fork</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+
+            <plugin>
+                <groupId>org.codehaus.mojo</groupId>
+                <artifactId>animal-sniffer-maven-plugin</artifactId>
+                <version>1.21</version>
+                <configuration>
+                    <checkTestClasses>true</checkTestClasses>
+                    <signature>
+                        <groupId>org.codehaus.mojo.signature</groupId>
+                        <artifactId>java18</artifactId>
+                        <version>1.0</version>
+                    </signature>
+                </configuration>
+                <executions>
+                    <execution>
+                        <id>check-java-version-compatibility</id>
+                        <phase>test</phase>
+                        <goals>
+                            <goal>check</goal>
+                        </goals>
+                    </execution>
+                </executions>
+            </plugin>
+
+            <plugin>
+                <artifactId>maven-jar-plugin</artifactId>
+                <version>3.2.2</version>
+            </plugin>
+
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-compiler-plugin</artifactId>
+                <version>3.10.1</version>
+                <configuration>
+                    <source>1.8</source>
+                    <target>1.8</target>
+                </configuration>
+            </plugin>
+
+            <plugin>
+                <groupId>org.apache.maven.plugins</groupId>
+                <artifactId>maven-release-plugin</artifactId>
+                <version>3.0.0-M6</version>
+            </plugin>
+
+            <plugin>
+                <groupId>org.sonatype.plugins</groupId>
+                <artifactId>nexus-staging-maven-plugin</artifactId>
+                <version>1.6.8</version>
+                <extensions>true</extensions>
+                <configuration>
+                    <serverId>sonatype-nexus-staging</serverId>
+                    <nexusUrl>https://oss.sonatype.org/</nexusUrl>
+                    <autoReleaseAfterClose>true</autoReleaseAfterClose>
+                </configuration>
+            </plugin>
+        </plugins>
+    </build>
+
+</project>

+ 30 - 0
temp_knife4j/pom.xml

@@ -0,0 +1,30 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://maven.apache.org/POM/4.0.0"
+         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+    <modelVersion>4.0.0</modelVersion>
+
+    <groupId>temp.download</groupId>
+    <artifactId>knife4j-download</artifactId>
+    <version>1.0-SNAPSHOT</version>
+
+    <properties>
+        <knife4j.version>4.1.0</knife4j.version>
+    </properties>
+
+    <dependencies>
+        <dependency>
+            <groupId>com.github.xiaoymin</groupId>
+            <artifactId>knife4j-openapi3-spring-boot-starter</artifactId>
+            <version>${knife4j.version}</version>
+        </dependency>
+    </dependencies>
+
+    <repositories>
+        <repository>
+            <id>central</id>
+            <name>Maven Central</name>
+            <url>https://repo1.maven.org/maven2/</url>
+        </repository>
+    </repositories>
+</project>