后端校验的实现代码

本文介绍了一个用于实体类、数据传输对象等参数校验的方法,支持级联对象验证,并详细列举了多种注解如@NotNull、@Size等的使用场景。



import org.springframework.util.Assert;
import org.springframework.validation.BeanPropertyBindingResult;
import org.springframework.validation.Errors;
import org.springframework.validation.ValidationUtils;
import org.springframework.validation.beanvalidation.LocalValidatorFactoryBean;

import com.suning.gcms.gcapi.utils.ErrorsUtil;
import com.suning.gcms.gcapi.utils.JsonUtil;

/**
 * 用于entity/dto/vo等参数校验,支持级联对象<br>
 * 
 * @Null 被注释的元素必须为 null
 * @NotNull 被注释的元素必须不为 null
 * @AssertTrue 被注释的元素必须为 true
 * @AssertFalse 被注释的元素必须为 false
 * @Min(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
 * @Max(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
 * @DecimalMin(value) 被注释的元素必须是一个数字,其值必须大于等于指定的最小值
 * @DecimalMax(value) 被注释的元素必须是一个数字,其值必须小于等于指定的最大值
 * @Size(max=, min=) 被注释的元素的大小必须在指定的范围内
 * @Digits (integer, fraction) 被注释的元素必须是一个数字,其值必须在可接受的范围内
 * @Past 被注释的元素必须是一个过去的日期
 * @Future 被注释的元素必须是一个将来的日期
 * @Pattern(regex=,flag=) 被注释的元素必须符合指定的正则表达式
 * @Valid 级联对象,<b>注:</b>使用此注解之前,请先使用NotNull,否则当级联对象为null时,不能校验。<br>
 * 
 * Hibernate Validator 附加的 constraint<br>
 * @NotBlank 验证字符串非null,且长度必须大于0
 * @Email 被注释的元素必须是电子邮箱地址
 * @Length(min=,max=) 被注释的字符串的大小必须在指定的范围内
 * @NotEmpty 被注释的字符串的必须非空
 * @Range(min=,max=,message=) 被注释的元素必须在合适的范围内
 * 
 * @author 13073457
 */
public class ParamsValidation{
    private LocalValidatorFactoryBean validationFactory;
    /**
     * 功能描述: 校验参数<br>
     *
     * @param json  需转为对象的json数据
     * @param targetClass 所有需要的对象类型
     * @return 所有错误信息
     */
    public <T> Errors validate(String json, Class<T> targetClass){
        Assert.notNull(json, "json参数不能为空");
        Assert.notNull(targetClass, "targetClass不能为空");
        
        T t = JsonUtil.fromJson(json, targetClass);
        
        return this.validate(t);
    }

    /**
     * 功能描述: 校验参数<br>
     *
     * @param obj 需校验数据的对象,不可为空
     * @return 所有错误信息
     */
    public <T> Errors validate(T obj){
        Assert.notNull(obj);
        
        Errors errors = new BeanPropertyBindingResult(obj, obj.getClass().getName());
        ValidationUtils.invokeValidator(validationFactory, obj, errors);
        
        return errors;
    }
    
    public void setValidationFactory(LocalValidatorFactoryBean validationFactory) {
        this.validationFactory = validationFactory;
    }
    
    public <T> String validateParams(T reqDTO){
        String errMsg;
        if(reqDTO == null){
            return "请求为空";
        }
        // 校验参数
        Errors errors = validate(reqDTO);
        errMsg = ErrorsUtil.getErrorMsg(errors);
        return errMsg;
    }
}
后端进行 HTML 格式和内容校验可采用以下几种方法: - **正则表达式**:利用正则表达式来匹配 HTML 标签和内容,以验证格式是否符合预期。例如,可编写正则表达式来检查标签是否正确闭合、属性是否符合规定等。不过,由于 HTML 语法较为复杂,正则表达式难以处理所有情况,尤其是嵌套标签和特殊字符。示例代码如下: ```java import java.util.regex.Pattern; public class HtmlValidator { private static final String HTML_TAG_PATTERN = "<([a-z]+)([^<]+)*(?:>(.*)<\\/\\1>| *\\/>)"; private static final Pattern pattern = Pattern.compile(HTML_TAG_PATTERN); public static boolean isValidHtml(String html) { return pattern.matcher(html).find(); } } ``` - **HTML 解析器**:使用专业的 HTML 解析器,如 Jsoup(Java 语言),它能将 HTML 文档解析成树形结构,方便检查标签、属性和内容。解析器可以处理复杂的 HTML 语法,包括嵌套标签和特殊字符。示例代码如下: ```java import org.jsoup.Jsoup; import org.jsoup.nodes.Document; import org.jsoup.nodes.Element; import org.jsoup.select.Elements; public class HtmlParserValidator { public static boolean isValidHtml(String html) { try { Document doc = Jsoup.parse(html); // 可以进一步检查文档结构、标签等 Elements elements = doc.getAllElements(); for (Element element : elements) { // 进行具体的检查逻辑 } return true; } catch (Exception e) { return false; } } } ``` - **自定义规则校验**:根据具体业务需求,编写自定义的校验逻辑。例如,检查 HTML 中是否包含特定的标签、属性或内容。可以结合正则表达式和 HTML 解析器,实现更复杂的校验规则。 - **使用后端框架的校验机制**:许多后端框架提供了数据校验功能,可利用这些功能对 HTML 数据进行校验。如在 Java 后端使用 Hibernate Validator 注解,在实体类的属性上添加校验规则。示例代码如下: ```java import javax.validation.constraints.Size; public class HtmlContent { @Size(max = 1000, message = "HTML 内容长度不能超过 1000 字符") private String html; public String getHtml() { return html; } public void setHtml(String html) { this.html = html; } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值