JSR303介绍和使用

关于JSR

JSR是Java Specification Requests的缩写,意思是Java 规范提案。是指向JCP(Java Community Process)提出新增一个标准化技术规范的正式请求。任何人都可以提交JSR,以向Java平台增添新的API和服务。JSR已成为Java界的一个重要标准。

关于 JSR-303

JSR-303 是JAVA EE 6 中的一项子规范,叫做Bean Validation,Hibernate Validator 是 Bean Validation 的参考实现 . Hibernate Validator 提供了 JSR 303 规范中所有内置 constraint 的实现,除此之外还有一些附加的 constraint。

Hibernate 对其实现

Hibernate Validator 是 Bean Validation 的参考实现 . Hibernate Validator 提供了 JSR 303 规范中所有内置 constraint 的实现,除此之外还有一些附加的 constraint。

简单介绍

在这里插入图片描述

补充

Hibernate 中填充一部分
在这里插入图片描述

代码实现

依赖

<!-- https://mvnrepository.com/artifact/org.hibernate.validator/hibernate-validator -->
<dependency>
    <groupId>org.hibernate.validator</groupId>
    <artifactId>hibernate-validator</artifactId>
    <version>6.0.16.Final</version>
</dependency>


(1)给要校验的javaBean上标注校验注解

@ToString
@Getter
@Setter
public class UmsAdminParam {
    //规定长度
    @Length(min = 6, max = 19, message = "用户名长度是6-18位")
    @ApiModelProperty(value = "用户名", required = true)
    private String username;
    @ApiModelProperty(value = "密码", required = true)
    private String password;
    //不能是空的
    @NotEmpty
    @ApiModelProperty(value = "用户头像")
    private String icon;
    @Email(message = "邮箱格式错误")
    @ApiModelProperty(value = "邮箱")
    private String email;
    @NotNull
    @ApiModelProperty(value = "用户昵称")
    private String nickName;
    @ApiModelProperty(value = "备注")
    private String note;
}

(2)告诉spring这个数据需要校验@Valid

(3)感知校验成功/失败

public Stringregister(@Valid @RequestBody UmsAdminParam user,BindingResult result) {
        //得到所有错误信息计数
        int errorCount = result.getErrorCount();
        //错误数大于0
        if (errorCount>0){
            //得到所有错误
            List<FieldError> fieldErrors = result.getFieldErrors();
            //迭代错误
            fieldErrors.forEach((fieldError)->{
            	//错误信息
                String field = fieldError.getField();
                log.debug("属性:{},传来的值是:{},出错的提示消息:{}",
                        field,fieldError.getRejectedValue(),fieldError.getDefaultMessage());
            });
            return fieldError.getRejectedValue()+"出错:"+fieldError.getDefaultMessage();
        }else{
			return "登录成功";
        }
    }
### 解决 Mac 上 GitHub 客户端无法打开的问题 对于 Mac 用户遇到的 GitHub 客户端无法启动的情况,可能由多种因素引起。通常可以从以下几个方面排查并解决问题: #### 1. 更新应用程序 确保使用的 GitHub Desktop 版本是最新的。旧版本可能存在兼容性问题或是已知漏洞,更新到最新版可以修复这些问题。 ```bash # 打开终端执行命令来检查是否有可用更新 sudo softwareupdate -l ``` 如果通过应用商店安装,则前往 App Store 查看是否存在待更新项[^1]。 #### 2. 清除缓存数据 有时本地存储的数据可能导致程序运行异常。尝试清除 GitHub Desktop 的偏好设置文件夹以重置其状态。 - 关闭所有正在运行的应用实例。 - 使用 Finder 或者 Terminal 导航至 `~/Library/Application Support/GitHub Desktop` 并删除该目录下的内容。 请注意备份重要信息后再操作此步骤[^2]。 #### 3. 检查依赖服务的状态 确认计算机上的 Git 和其他关联工具正常工作。可以通过命令行测试基本功能是否完好无损。 ```bash git --version ssh -T git@github.com ``` 上述指令用于验证 Git 是否正确安装以及 SSH 连接能否成功建立[^3]。 #### 4. 日志分析 当常规方法未能奏效时,查阅日志记录有助于发现潜在错误原因。GitHub Desktop 存储的日志位于用户的库副本路径下 `.git/github-desktop.log` 文件内;也可以利用 macOS 自带控制台应用查看更详细的系统级消息[^4]。 #### 5. 卸载重装软件包 作为最后手段,在完全移除现有安装之后再重新下载官方发布的稳定版本进行全新部署不失为一种有效方式。记得提前导出必要的配置和个人资料以免丢失[^5]。
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值