实体对象判空处理

对象使用注解判空处理:@NotNull、@RequestBody、@Valid和全局异常捕获反馈操作字段判空信息

实体类使用@NotNull注解进行判空处理在这里插入图片描述
ClazzController添加@RequestBody 和 @Valid注解进行注释,实现实体对象自动校验。在这里插入图片描述
最后在配置包下添加全局异常捕获处理:

import com.network.school.common.core.vo.RespResult;
import org.springframework.validation.BindingResult;
import org.springframework.validation.FieldError;
import org.springframework.web.bind.MethodArgumentNotValidException;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ResponseBody;

import java.util.List;

/**
 * @description:全局Controller错误拦截处理
 * @author: YangYang
 * @time: 2021/11/2 19:31
 */
@ControllerAdvice
public class EntityExceptionHandler {
    /**
     * 处理验证信息返回
     * @param ex
     * @return
     */
    @ExceptionHandler(MethodArgumentNotValidException.class)
    @ResponseBody
    public RespResult EntityBindException(MethodArgumentNotValidException ex) {
        BindingResult bindingResult = ex.getBindingResult();
        List<FieldError> errorList =  bindingResult.getFieldErrors();
        StringBuffer message = new StringBuffer();
        errorList.stream().forEach((error)->{
            message.append(error.getDefaultMessage()+",");
        });
        return RespResult.error(500,message.substring(0,message.length()-1).toString());
    }
}

当请求参数为空的时候,界面就可以如下返回结果:在这里插入图片描述
这样就可以做到@NotNull、@RequestBody、@Valid注解和全局异常捕获,这样就可以减少逻辑代码判空处理

### 如何在 Java 中检查对象属性是否为Java 中,检查对象属性是否为是一个常见的需求。为了实现这一目标并遵循最佳实践,可以利用 `Optional` 类以及其他设计模式来减少指针异常的风险。 #### 使用 `Optional` 进行值检查 自 Java 8 起引入的 `Optional` 容器类提供了一种优雅的方式来处理潜在的值情况[^1]。它可以通过封装对象的方式避免直接访问可能导致指针异常的对象属性。例如: ```java public void checkName(Optional<String> name) { if (name.isPresent()) { System.out.println("名字:" + name.get()); } else { System.out.println("名字未设置"); } } ``` 上述代码展示了如何使用 `isPresent()` 方法断 `Optional` 是否包含实际值。如果存在,则调用 `get()` 获取其内部存储的实际值;否则执行其他逻辑。 #### 对象引用与堆栈关系下的值检测 当创建一个新对象时,在内存模型中会涉及栈和堆两部分交互过程[^2]。因此对于复杂类型的成员变量而言,默认初始化状态可能是 `null`。所以在操作之前应当确认这些字段已经被正确定义赋值后再继续后续流程。 ##### 示例:传统方式 vs Optional 方式对比 假设我们有一个简单的 `Person` 实例,并希望打印该人的姓名。以下是两种不同的做法比较: **传统方法** ```java if(person != null && person.getName() != null){ System.out.println(person.getName()); } else{ System.out.println("未知名称"); } ``` **采用 Optional 的现代写法** ```java Optional.ofNullable(person).map(Person::getName).ifPresentOrElse( name -> System.out.println(name), () -> System.out.println("未知名称") ); ``` 这里不仅简化了多层嵌套条件语句结构,还增强了可读性和安全性[^3]^。 #### 结合 getter 和 setter 自动化校验机制 除了外部显式的外,还可以考虑将此类逻辑内置到实体类本身之中。比如通过重载 Getter 方法或者增加专门用于验证的方法完成此功能[^4]: ```java public class SafePerson extends Person { @Override public String getName(){ return Optional.ofNullable(super.getName()).orElse("默认名"); } public boolean isDataComplete(){ return Objects.nonNull(this.name)&&Objects.nonNull(this.age); } } ``` 以上例子说明即使原始数据源返回的是 NULL 值,经过包装之后也能给出合理替代方案而不会抛出错误消息。 另外值得注意的一点是在某些特殊场景下(如深浅复制),也需要特别注意保持一致性的同时防止意外修改共享资源引发问题[^5]. ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yangyang_VV

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值