From d08d747dc077d960dfb7b96ebe600e8d3c9f4afd Mon Sep 17 00:00:00 2001 From: ZhouXY108 Date: Mon, 9 Jun 2025 11:10:03 +0800 Subject: [PATCH 1/3] =?UTF-8?q?refactor:=20=E9=87=8D=E6=9E=84=20MultiTypes?= =?UTF-8?q?Exception.ExceptionType=20=E6=8E=A5=E5=8F=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - 将 `ExceptionType` 中的工厂方法抽取到 `ExceptionFactory` 中 - 更新相关文档注释 --- .../commons/exception/ExceptionFactory.java | 61 +++++++++++++++++++ .../exception/MultiTypesException.java | 46 +++----------- .../commons/exception/package-info.java | 3 +- 3 files changed, 70 insertions(+), 40 deletions(-) create mode 100644 plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ExceptionFactory.java diff --git a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ExceptionFactory.java b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ExceptionFactory.java new file mode 100644 index 0000000..0f2e8bf --- /dev/null +++ b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ExceptionFactory.java @@ -0,0 +1,61 @@ +/* + * Copyright 2025 the original author or authors. + * + * Licensed 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 + * + * https://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. + */ +package xyz.zhouxy.plusone.commons.exception; + +import javax.annotation.Nonnull; + +/** + * 异常工厂 + * + * @author ZhouXY + */ +public interface ExceptionFactory { + /** + * 创建异常 + * + * @return 异常对象 + */ + @Nonnull + X create(); + + /** + * 使用指定 {@code message} 创建异常 + * + * @param message 异常信息 + * @return 异常对象 + */ + @Nonnull + X create(String message); + + /** + * 使用指定 {@code cause} 创建异常 + * + * @param cause 包装的异常 + * @return 异常对象 + */ + @Nonnull + X create(Throwable cause); + + /** + * 使用指定 {@code message} 和 {@code cause} 创建异常 + * + * @param message 异常信息 + * @param cause 包装的异常 + * @return 异常对象 + */ + @Nonnull + X create(String message, Throwable cause); +} diff --git a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/MultiTypesException.java b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/MultiTypesException.java index 159997b..485ce95 100644 --- a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/MultiTypesException.java +++ b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/MultiTypesException.java @@ -29,7 +29,8 @@ import xyz.zhouxy.plusone.commons.base.IWithCode; * 异常实现 {@link MultiTypesException} 的 {@link #getType} 方法,返回对应的场景类型。 * *

- * 表示场景类型的枚举实现 {@link ExceptionType},其中的工厂方法用于创建对应类型的异常。 + * 表示场景类型的枚举实现 {@link ExceptionType},各个枚举值本身就是该场景的异常的工厂实例, + * 使用其中的工厂方法用于创建对应类型的异常。 * *

  * public final class LoginException
@@ -121,7 +122,9 @@ import xyz.zhouxy.plusone.commons.base.IWithCode;
  * @author ZhouXY
  * @since 1.0.0
  */
-public interface MultiTypesException> {
+public interface MultiTypesException<
+        X extends Exception,
+        T extends MultiTypesException.ExceptionType> {
 
     /**
      * 异常类型
@@ -143,48 +146,13 @@ public interface MultiTypesException extends IWithCode {
+    public static interface ExceptionType
+            extends IWithCode, ExceptionFactory {
 
         /**
          * 默认异常信息
          */
         String getDefaultMessage();
 
-        /**
-         * 创建异常
-         *
-         * @return 异常对象
-         */
-        @Nonnull
-        E create();
-
-        /**
-         * 使用指定 {@code message} 创建异常
-         *
-         * @param message 异常信息
-         * @return 异常对象
-         */
-        @Nonnull
-        E create(String message);
-
-        /**
-         * 使用指定 {@code cause} 创建异常
-         *
-         * @param cause 包装的异常
-         * @return 异常对象
-         */
-        @Nonnull
-        E create(Throwable cause);
-
-        /**
-         * 使用指定 {@code message} 和 {@code cause} 创建异常
-         *
-         * @param message 异常信息
-         * @param cause   包装的异常
-         * @return 异常对象
-         */
-        @Nonnull
-        E create(String message, Throwable cause);
-
     }
 }
diff --git a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/package-info.java b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/package-info.java
index b956736..0baa6b0 100644
--- a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/package-info.java
+++ b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/package-info.java
@@ -25,7 +25,8 @@
  * 异常实现 {@link MultiTypesException} 的 {@link MultiTypesException#getType} 方法,返回对应的场景类型。
  *
  * 

- * 表示场景类型的枚举实现 {@link MultiTypesException.ExceptionType},其中的工厂方法用于创建对应类型的异常。 + * 表示场景类型的枚举实现 {@link MultiTypesException.ExceptionType},各个枚举值本身就是该场景的异常的工厂实例, + * 使用其中的工厂方法用于创建对应类型的异常。 * *

  * public final class LoginException
-- 
2.49.1


From f6ffa628b60f73c2e637befe9bb66d763ac7ca79 Mon Sep 17 00:00:00 2001
From: ZhouXY108 
Date: Mon, 9 Jun 2025 11:37:16 +0800
Subject: [PATCH 2/3] =?UTF-8?q?refactor!:=20=E9=87=8D=E5=91=BD=E5=90=8D?=
 =?UTF-8?q?=E5=A4=9A=E7=B1=BB=E5=9E=8B=E5=BC=82=E5=B8=B8=E7=9B=B8=E5=85=B3?=
 =?UTF-8?q?=E6=8E=A5=E5=8F=A3?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

- 将 MultiTypesException 重命名为 IMultiTypesException
- 将 ExceptionType 重命名为 IExceptionType
- 将 ExceptionFactory 重命名为 IExceptionFactory
---
 README.md                                     | 10 ++++-----
 ...ionFactory.java => IExceptionFactory.java} |  2 +-
 ...ception.java => IMultiTypesException.java} | 22 ++++++++++---------
 .../exception/ParsingFailureException.java    |  6 ++---
 .../business/InvalidInputException.java       |  8 +++----
 .../commons/exception/package-info.java       | 10 ++++-----
 6 files changed, 30 insertions(+), 28 deletions(-)
 rename plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/{ExceptionFactory.java => IExceptionFactory.java} (96%)
 rename plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/{MultiTypesException.java => IMultiTypesException.java} (83%)

diff --git a/README.md b/README.md
index c4981fc..4ccb1b9 100644
--- a/README.md
+++ b/README.md
@@ -68,16 +68,16 @@ System.out.println(result); // Output: Return string
 `RegexConsts` 包含常见正则表达式;`PatternConsts` 包含对应的 `Pattern` 对象
 
 ## 五、exception - 异常
-### 1. MultiTypesException - 多类型异常
+### 1. IMultiTypesException - 多类型异常
 异常在不同场景下被抛出,可以用不同的枚举值,表示不同的场景类型。
 
-异常实现 `MultiTypesException` 的 `MultiTypesException#getType` 方法,返回对应的场景类型。
+异常实现 `IMultiTypesException` 的 `IMultiTypesException#getType` 方法,返回对应的场景类型。
 
-表示场景类型的枚举实现 `MultiTypesException.ExceptionType`,其中的工厂方法用于创建对应类型的异常。
+表示场景类型的枚举实现 `IMultiTypesException.IExceptionType`,其中的工厂方法用于创建对应类型的异常。
 ```java
 public final class LoginException
         extends RuntimeException
-        implements MultiTypesException {
+        implements IMultiTypesException {
     private static final long serialVersionUID = 881293090625085616L;
     private final Type type;
     private LoginException(@Nonnull Type type, @Nonnull String message) {
@@ -104,7 +104,7 @@ public final class LoginException
 
     // ...
 
-    public enum Type implements ExceptionType {
+    public enum Type implements IExceptionType {
         DEFAULT("00", "当前会话未登录"),
         NOT_TOKEN("10", "未提供token"),
         INVALID_TOKEN("20", "token无效"),
diff --git a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ExceptionFactory.java b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/IExceptionFactory.java
similarity index 96%
rename from plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ExceptionFactory.java
rename to plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/IExceptionFactory.java
index 0f2e8bf..655921f 100644
--- a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ExceptionFactory.java
+++ b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/IExceptionFactory.java
@@ -22,7 +22,7 @@ import javax.annotation.Nonnull;
  *
  * @author ZhouXY
  */
-public interface ExceptionFactory {
+public interface IExceptionFactory {
     /**
     * 创建异常
     *
diff --git a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/MultiTypesException.java b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/IMultiTypesException.java
similarity index 83%
rename from plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/MultiTypesException.java
rename to plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/IMultiTypesException.java
index 485ce95..c91c1bf 100644
--- a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/MultiTypesException.java
+++ b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/IMultiTypesException.java
@@ -20,22 +20,22 @@ import javax.annotation.Nonnull;
 import xyz.zhouxy.plusone.commons.base.IWithCode;
 
 /**
- * MultiTypesException
+ * IMultiTypesException
  *
  * 

* 异常在不同场景下被抛出,可以用不同的枚举值,表示不同的场景类型。 * *

- * 异常实现 {@link MultiTypesException} 的 {@link #getType} 方法,返回对应的场景类型。 + * 异常实现 {@link IMultiTypesException} 的 {@link #getType} 方法,返回对应的场景类型。 * *

- * 表示场景类型的枚举实现 {@link ExceptionType},各个枚举值本身就是该场景的异常的工厂实例, + * 表示场景类型的枚举实现 {@link IExceptionType},各个枚举值本身就是该场景的异常的工厂实例, * 使用其中的工厂方法用于创建对应类型的异常。 * *

  * public final class LoginException
  *         extends RuntimeException
- *         implements MultiTypesException<LoginException, LoginException.Type> {
+ *         implements IMultiTypesException<LoginException, LoginException.Type> {
  *     private static final long serialVersionUID = 881293090625085616L;
  *     private final Type type;
  *     private LoginException(@Nonnull Type type, @Nonnull String message) {
@@ -62,7 +62,7 @@ import xyz.zhouxy.plusone.commons.base.IWithCode;
  *
  *     // ...
  *
- *     public enum Type implements ExceptionType<LoginException> {
+ *     public enum Type implements IExceptionType<LoginException> {
  *         DEFAULT("00", "当前会话未登录"),
  *         NOT_TOKEN("10", "未提供token"),
  *         INVALID_TOKEN("20", "token无效"),
@@ -119,17 +119,19 @@ import xyz.zhouxy.plusone.commons.base.IWithCode;
  * throw LoginException.Type.TOKEN_TIMEOUT.create();
  * 
* + * @param 具体异常类 + * @param 异常场景 * @author ZhouXY * @since 1.0.0 */ -public interface MultiTypesException< +public interface IMultiTypesException< X extends Exception, - T extends MultiTypesException.ExceptionType> { + T extends IMultiTypesException.IExceptionType> { /** * 异常类型 * - * @return 异常类型。通常是实现了 {@link ExceptionType} 的枚举。 + * @return 异常类型。通常是实现了 {@link IExceptionType} 的枚举。 */ @Nonnull T getType(); @@ -146,8 +148,8 @@ public interface MultiTypesException< /** * 异常类型 */ - public static interface ExceptionType - extends IWithCode, ExceptionFactory { + public static interface IExceptionType + extends IWithCode, IExceptionFactory { /** * 默认异常信息 diff --git a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ParsingFailureException.java b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ParsingFailureException.java index 3aac49f..e6e695d 100644 --- a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ParsingFailureException.java +++ b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ParsingFailureException.java @@ -21,7 +21,7 @@ import java.time.format.DateTimeParseException; import javax.annotation.Nonnull; import xyz.zhouxy.plusone.commons.exception.business.RequestParamsException; -import xyz.zhouxy.plusone.commons.exception.MultiTypesException.ExceptionType; +import xyz.zhouxy.plusone.commons.exception.IMultiTypesException.IExceptionType; /** * 解析失败异常 @@ -39,7 +39,7 @@ import xyz.zhouxy.plusone.commons.exception.MultiTypesException.ExceptionType; */ public final class ParsingFailureException extends Exception - implements MultiTypesException { + implements IMultiTypesException { private static final long serialVersionUID = 795996090625132616L; private final Type type; @@ -171,7 +171,7 @@ public final class ParsingFailureException /** XML 解析失败 */ public static final Type XML_PARSING_FAILURE = Type.XML_PARSING_FAILURE; - public enum Type implements ExceptionType { + public enum Type implements IExceptionType { DEFAULT("00", "解析失败"), NUMBER_PARSING_FAILURE("10", "数字转换失败"), DATE_TIME_PARSING_FAILURE("20", "时间解析失败"), diff --git a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/business/InvalidInputException.java b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/business/InvalidInputException.java index 301e0ef..917c9d1 100644 --- a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/business/InvalidInputException.java +++ b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/business/InvalidInputException.java @@ -18,8 +18,8 @@ package xyz.zhouxy.plusone.commons.exception.business; import javax.annotation.Nonnull; -import xyz.zhouxy.plusone.commons.exception.MultiTypesException.ExceptionType; -import xyz.zhouxy.plusone.commons.exception.MultiTypesException; +import xyz.zhouxy.plusone.commons.exception.IMultiTypesException.IExceptionType; +import xyz.zhouxy.plusone.commons.exception.IMultiTypesException; /** * InvalidInputException @@ -35,7 +35,7 @@ import xyz.zhouxy.plusone.commons.exception.MultiTypesException; */ public final class InvalidInputException extends RequestParamsException - implements MultiTypesException { + implements IMultiTypesException { private static final long serialVersionUID = -28994090625082516L; private final Type type; @@ -109,7 +109,7 @@ public final class InvalidInputException return this.type; } - public enum Type implements ExceptionType { + public enum Type implements IExceptionType { DEFAULT("00", "用户输入内容非法"), CONTAINS_ILLEGAL_AND_MALICIOUS_LINKS("01", "包含非法恶意跳转链接"), CONTAINS_ILLEGAL_WORDS("02", "包含违禁敏感词"), diff --git a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/package-info.java b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/package-info.java index 0baa6b0..1bc1a3c 100644 --- a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/package-info.java +++ b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/package-info.java @@ -17,21 +17,21 @@ /** *

异常

* - *

1. {@link MultiTypesException} - 多类型异常

+ *

1. {@link IMultiTypesException} - 多类型异常

*

* 异常在不同场景下被抛出,可以用不同的枚举值,表示不同的场景类型。 * *

- * 异常实现 {@link MultiTypesException} 的 {@link MultiTypesException#getType} 方法,返回对应的场景类型。 + * 异常实现 {@link IMultiTypesException} 的 {@link IMultiTypesException#getType} 方法,返回对应的场景类型。 * *

- * 表示场景类型的枚举实现 {@link MultiTypesException.ExceptionType},各个枚举值本身就是该场景的异常的工厂实例, + * 表示场景类型的枚举实现 {@link IMultiTypesException.IExceptionType},各个枚举值本身就是该场景的异常的工厂实例, * 使用其中的工厂方法用于创建对应类型的异常。 * *

  * public final class LoginException
  *         extends RuntimeException
- *         implements MultiTypesException<LoginException, LoginException.Type> {
+ *         implements IMultiTypesException<LoginException, LoginException.Type> {
  *     private static final long serialVersionUID = 881293090625085616L;
  *     private final Type type;
  *     private LoginException(@Nonnull Type type, @Nonnull String message) {
@@ -58,7 +58,7 @@
  *
  *     // ...
  *
- *     public enum Type implements ExceptionType<LoginException> {
+ *     public enum Type implements IExceptionType<LoginException> {
  *         DEFAULT("00", "当前会话未登录"),
  *         NOT_TOKEN("10", "未提供token"),
  *         INVALID_TOKEN("20", "token无效"),
-- 
2.49.1


From 48466f3f2680006f211fddf05152ff84ae7e97e6 Mon Sep 17 00:00:00 2001
From: ZhouXY108 
Date: Tue, 22 Jul 2025 15:06:29 +0800
Subject: [PATCH 3/3] =?UTF-8?q?refactor(exception)!:=20=E9=87=8D=E6=9E=84?=
 =?UTF-8?q?=E5=A4=9A=E7=B1=BB=E5=9E=8B=E5=BC=82=E5=B8=B8=E6=8E=A5=E5=8F=A3?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

- 在 IMultiTypesException 接口中添加泛型参数 TCode,用于指定异常类型代码的类型
- 在 IExceptionType 接口中添加 getDescription 方法,用于获取异常类型的描述信息
---
 README.md                                     |  4 ++--
 .../exception/IMultiTypesException.java       | 21 +++++++++++++------
 .../exception/ParsingFailureException.java    |  4 ++--
 .../business/InvalidInputException.java       |  4 ++--
 .../commons/exception/package-info.java       |  4 ++--
 5 files changed, 23 insertions(+), 14 deletions(-)

diff --git a/README.md b/README.md
index 4ccb1b9..6e03650 100644
--- a/README.md
+++ b/README.md
@@ -77,7 +77,7 @@ System.out.println(result); // Output: Return string
 ```java
 public final class LoginException
         extends RuntimeException
-        implements IMultiTypesException {
+        implements IMultiTypesException {
     private static final long serialVersionUID = 881293090625085616L;
     private final Type type;
     private LoginException(@Nonnull Type type, @Nonnull String message) {
@@ -104,7 +104,7 @@ public final class LoginException
 
     // ...
 
-    public enum Type implements IExceptionType {
+    public enum Type implements IExceptionType {
         DEFAULT("00", "当前会话未登录"),
         NOT_TOKEN("10", "未提供token"),
         INVALID_TOKEN("20", "token无效"),
diff --git a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/IMultiTypesException.java b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/IMultiTypesException.java
index c91c1bf..7ac279c 100644
--- a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/IMultiTypesException.java
+++ b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/IMultiTypesException.java
@@ -15,8 +15,11 @@
  */
 package xyz.zhouxy.plusone.commons.exception;
 
+import java.io.Serializable;
+
 import javax.annotation.Nonnull;
 
+import xyz.zhouxy.plusone.commons.annotation.Virtual;
 import xyz.zhouxy.plusone.commons.base.IWithCode;
 
 /**
@@ -35,7 +38,7 @@ import xyz.zhouxy.plusone.commons.base.IWithCode;
  * 
  * public final class LoginException
  *         extends RuntimeException
- *         implements IMultiTypesException<LoginException, LoginException.Type> {
+ *         implements IMultiTypesException<LoginException, LoginException.Type, String> {
  *     private static final long serialVersionUID = 881293090625085616L;
  *     private final Type type;
  *     private LoginException(@Nonnull Type type, @Nonnull String message) {
@@ -62,7 +65,7 @@ import xyz.zhouxy.plusone.commons.base.IWithCode;
  *
  *     // ...
  *
- *     public enum Type implements IExceptionType<LoginException> {
+ *     public enum Type implements IExceptionType<LoginException, String> {
  *         DEFAULT("00", "当前会话未登录"),
  *         NOT_TOKEN("10", "未提供token"),
  *         INVALID_TOKEN("20", "token无效"),
@@ -126,7 +129,8 @@ import xyz.zhouxy.plusone.commons.base.IWithCode;
  */
 public interface IMultiTypesException<
         X extends Exception,
-        T extends IMultiTypesException.IExceptionType> {
+        T extends IMultiTypesException.IExceptionType,
+        TCode extends Serializable> {
 
     /**
      * 异常类型
@@ -141,20 +145,25 @@ public interface IMultiTypesException<
      *
      * @return 异常类型编码
      */
-    default @Nonnull String getTypeCode() {
+    default @Nonnull TCode getTypeCode() {
         return getType().getCode();
     }
 
     /**
      * 异常类型
      */
-    public static interface IExceptionType
-            extends IWithCode, IExceptionFactory {
+    public static interface IExceptionType
+            extends IWithCode, IExceptionFactory {
 
         /**
          * 默认异常信息
          */
         String getDefaultMessage();
 
+        @Virtual
+        default String getDescription() {
+            return getDefaultMessage();
+        }
+
     }
 }
diff --git a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ParsingFailureException.java b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ParsingFailureException.java
index e6e695d..0f86910 100644
--- a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ParsingFailureException.java
+++ b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/ParsingFailureException.java
@@ -39,7 +39,7 @@ import xyz.zhouxy.plusone.commons.exception.IMultiTypesException.IExceptionType;
  */
 public final class ParsingFailureException
         extends Exception
-        implements IMultiTypesException {
+        implements IMultiTypesException {
     private static final long serialVersionUID = 795996090625132616L;
 
     private final Type type;
@@ -171,7 +171,7 @@ public final class ParsingFailureException
     /** XML 解析失败 */
     public static final Type XML_PARSING_FAILURE = Type.XML_PARSING_FAILURE;
 
-    public enum Type implements IExceptionType {
+    public enum Type implements IExceptionType {
         DEFAULT("00", "解析失败"),
         NUMBER_PARSING_FAILURE("10", "数字转换失败"),
         DATE_TIME_PARSING_FAILURE("20", "时间解析失败"),
diff --git a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/business/InvalidInputException.java b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/business/InvalidInputException.java
index 917c9d1..b739c82 100644
--- a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/business/InvalidInputException.java
+++ b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/business/InvalidInputException.java
@@ -35,7 +35,7 @@ import xyz.zhouxy.plusone.commons.exception.IMultiTypesException;
  */
 public final class InvalidInputException
         extends RequestParamsException
-        implements IMultiTypesException {
+        implements IMultiTypesException {
     private static final long serialVersionUID = -28994090625082516L;
 
     private final Type type;
@@ -109,7 +109,7 @@ public final class InvalidInputException
         return this.type;
     }
 
-    public enum Type implements IExceptionType {
+    public enum Type implements IExceptionType {
         DEFAULT("00", "用户输入内容非法"),
         CONTAINS_ILLEGAL_AND_MALICIOUS_LINKS("01", "包含非法恶意跳转链接"),
         CONTAINS_ILLEGAL_WORDS("02", "包含违禁敏感词"),
diff --git a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/package-info.java b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/package-info.java
index 1bc1a3c..0ba9d8a 100644
--- a/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/package-info.java
+++ b/plusone-commons/src/main/java/xyz/zhouxy/plusone/commons/exception/package-info.java
@@ -31,7 +31,7 @@
  * 
  * public final class LoginException
  *         extends RuntimeException
- *         implements IMultiTypesException<LoginException, LoginException.Type> {
+ *         implements IMultiTypesException<LoginException, LoginException.Type, String> {
  *     private static final long serialVersionUID = 881293090625085616L;
  *     private final Type type;
  *     private LoginException(@Nonnull Type type, @Nonnull String message) {
@@ -58,7 +58,7 @@
  *
  *     // ...
  *
- *     public enum Type implements IExceptionType<LoginException> {
+ *     public enum Type implements IExceptionType<LoginException, String> {
  *         DEFAULT("00", "当前会话未登录"),
  *         NOT_TOKEN("10", "未提供token"),
  *         INVALID_TOKEN("20", "token无效"),
-- 
2.49.1