一个代替notNull参数校验工具

本文介绍了一个自定义的表单参数校验工具类,用于替代统一的@NotNull注解进行递归校验。该工具类适用于多个Controller使用同一Bean接收参数的场景,能够更灵活地处理POST和PUT请求中的ID校验问题。

自己写的参数校验工具类,使用场景于多个controller下用了同一个bean去接收,这时候使用@notNull不是很现实,POST下ID理论是为undefined,而PUT则不是。
可根据需要在这工具类上修改

    /**
     * 表单参数校验 代替统一校验@NotNull 递归校验
     * 事务回滚在外部方法处理
     * 这里抛出ParamException丢给全局处理,代替返回结果
     * @author q_y_h
     * @param data
     * @param params 需要校验的参数
     * @return
     */
    public static <T> void allParamValid(T data, String... params) {
        for (int i = 0; i < params.length; i++) {
            String param = params[i];
            if (!paramValid(data.getClass(), data, param))
                throw new ParamException("参数缺失");
        }
    }


    public static<T> boolean paramValid(Class<?> thisClass,T data, String property) {
        boolean hasParam = false;
        Class<?> superclass = thisClass.getSuperclass();
        Field field = null;
        try {
            field = thisClass.getDeclaredField(property);
            field.setAccessible(true);
            Object param = field.get(data);
            hasParam = (param != null);
        } catch (IllegalAccessException e) {
            e.printStackTrace();
        } catch (NoSuchFieldException e) {
            if (superclass != null)
                return paramValid(superclass, data, property);
            else throw new ParamException("未找到校验参数:"+property+"\r\n");
        }finally {
            if (field != null)
                field.setAccessible(false);
        }
        //第一级时返回
        return hasParam;
    }
    
    public static void main(String[] args) {
        allParamValid(new SysUser(),"id","xxx","xxx");
    }
<think>好的,我现在需要回答用户关于在Java中判断字符串是否为空的优雅断言方法的问题。用户希望用断言来实现,并且要优雅的方式。首先,我得理解用户的需求。 用户提到“优雅的断言方法”,可能是指代码简洁、可读性强,同时符合最佳实践。Java中处理字符串空值通常需要考虑null和空字符串两种情况,所以需要同时检查这两种情况。 首先,常见的做法是使用Apache Commons Lang库的StringUtils.isEmpty()方法,它可以同时检查null和空字符串。不过用户可能不想依赖第三方库,所以可能需要纯Java的解决方案。另外,Java 7引入了Objects.requireNonNull(),但主要用于抛出NullPointerException,可能不适用于此场景。 在Java 11及以上版本中,String类新增了isBlank()方法,可以检查字符串是否为空或仅包含空白字符,但同样需要考虑版本兼容性。如果用户的项目使用的是旧版本,这可能不可行。 接下来,断言在Java中通常使用assert关键字,但assert默认是不启用的,需要在JVM参数中启用。这可能不是用户想要的,尤其是在生产环境中,断言通常不被推荐用于参数校验,而是用于调试。因此,用户可能指的是更一般的“断言”方式,比如使用Preconditions类,例如Guava库中的Preconditions.checkArgument(),或者使用自定义的方法。 另外,用户可能希望代码符合Clean Code原则,如单一职责原则,保持简洁。因此,可以封装一个工具方法来处理空字符串的判断,并在需要的地方调用。 考虑到引用[3]提到的“Clean code should be simple and easy to understand. It should follow single responsibility principle (SRP)”,所以建议将判断逻辑封装成一个方法,提高代码的可重用性和可读性。 可能的解决方案包括: 1. 使用Java内置的方法,如str == null || str.isEmpty(),但需要Java 6及以上版本支持isEmpty()方法。 2. 使用Guava库的Strings.isNullOrEmpty(),不过需要引入Guava依赖。 3. 自定义工具类,封装判断逻辑。 同时,用户提到断言,可能需要结合JUnit或其他测试框架中的断言方法,比如JUnit的assertTrue或assertFalse,或者使用AssertJ库的更为流畅的断言方式。 例如,使用JUnit5的话,可以写assertTrue(str == null || str.isEmpty())。但用户可能是在代码逻辑中进行断言,而不是单元测试中的断言,所以需要明确上下文。 另外,引用[1]提到在Java中处理null检查需要遍历对象并处理null,所以用户可能希望减少样板代码,寻找更简洁的方式。 综上所述,优雅的方式可能包括: - 使用Java 8的Optional类:Optional.ofNullable(str).orElse("").isEmpty() - 使用Apache Commons Lang的StringUtils.isEmpty(str) - 使用Guava的Strings.isNullOrEmpty(str) - 自定义辅助方法,如: public static boolean isNullOrEmpty(String str) { return str == null || str.isEmpty(); } 然后在断言中使用该方法,或者结合Preconditions进行参数校验。 此外,引用[2]提到NOT NULL的性能优势,但这里可能不直接相关,不过优化代码时可以考虑减少不必要的null检查。 最终,给出几种不同的解决方案,根据用户的项目环境和依赖库的情况选择最适合的。同时提醒用户注意断言的使用场景,是否启用-ea参数,或者是否应该使用异常处理来代替断言,特别是在公共方法的参数校验中,通常推荐使用IllegalArgumentException等异常。</think>在Java中判断字符串是否为空或null的优雅方法可以通过以下方式实现: ### 方法1:使用内置方法(纯Java) ```java public static boolean isNullOrEmpty(String str) { return str == null || str.isEmpty(); // 需Java 6+ } ``` 调用示例: ```java assert isNullOrEmpty(inputString) : "字符串必须为空或null"; ``` ### 方法2:使用Guava库(推荐) Guava提供更简洁的API: ```java import com.google.common.base.Strings; assert Strings.isNullOrEmpty(inputString) : "字符串必须为空或null"; ``` ### 方法3:使用Apache Commons Lang ```java import org.apache.commons.lang3.StringUtils; assert StringUtils.isEmpty(inputString) : "字符串必须为空或null"; ``` ### 方法4:Java 11+的增强方法 ```java // 检查空或空白字符串 assert inputString == null || inputString.isBlank(); ``` ### 性能与代码规范建议 1. 优先选择`str.isEmpty()`而非`str.length() == 0`,前者可读性更佳[^3] 2. 在公共方法入口处做参数校验时,建议用`IllegalArgumentException`替代断言,因为Java断言默认不启用[^1] 3. 若使用第三方库,Guava的`Strings.isNullOrEmpty()`实现效率与手写代码相同[^2] ### 单元测试中的断言(JUnit5示例) ```java import static org.junit.jupiter.api.Assertions.assertTrue; @Test void testEmptyString() { String str = ""; assertTrue(str == null || str.isEmpty()); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值