データ検証はインタラクティブな Web サイトに不可欠な機能です。フロントエンドの JS 検証は、ユーザー名の一意性、誕生日の形式、電子メール形式の検証などの一般的に使用される検証など、ほとんどの検証責任をカバーできます。等々。ただし、ユーザーがブラウザをバイパスし、http ツールを使用してバックエンドから何らかの不正なデータを直接要求することを防ぐために、ダーティ データがデータベースに落ち込むのを防ぐためにサーバー側のデータ検証も必要です。データベースを削除すると、運用担当者や保守担当者にとっても頭痛の種になります。この記事で説明されている検証を使用して、データを検証できます。
1.JSR303/JSR-349: JSR303 は標準です。仕様のみを提供しますが、実装は提供しません。いくつかの検証仕様、つまり検証アノテーションを規定しています。 @ Null、@NotNull、@Pattern は、javax.validation.constraints パッケージの下にあります。 JSR-349 は、いくつかの新機能を追加したアップグレード バージョンです。
@Pattern(value) アノテーションが付けられた要素は、指定された正規表現に準拠する必要があります。
@Length 注釈付き文字列のサイズは指定された範囲内である必要があります
## @Range 注釈付きの要素は適切な範囲内にある必要があります
3.spring 検証: Spring 検証は Hibernate 検証を再カプセル化し、springmvc モジュールに自動検証を追加します。検証情報は特定のクラスにカプセル化されます
3.1 依存関係の紹介
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies>
<dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-validator</artifactId> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> </dependency>
3.2 スタートアップ クラスをビルドする
@SpringBootApplication public class App { public static void main(String[] args) { SpringApplication.run(App.class, args); System.out.println("Start app success."); } }
3.3 検証が必要なエンティティクラスを作成する
public class Person { @NotEmpty(message = "name不能为空") private String name; @Range(min = 0, max = 100, message = "age不能大于100小于0") private int age; public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } }
@RequestMapping("/test") public String valid(@Validated Person person, BindingResult bindingResult) { if (bindingResult.hasErrors()) { for (FieldError fieldError : bindingResult.getFieldErrors()) { System.out.println(fieldError); } return "fail"; } return "success"; }
@Validated アノテーションをパラメーター Persison の前に追加する必要があります。これは、Spring が検証する必要があることを示し、検証情報が保存されます。後続の BindingResult に渡されます。検証する必要があるパラメータが複数ある場合は、次の形式になります。 valid(@Validated Person person, BindingResult personBindingResult, @Validated Person2 person2, BindingResult person2BindingResult); つまり、1 つの検証クラスが 1 つの検証結果に対応します。
コンテナを起動すると、テスト結果は次のようになります:
統合例外処理クラス:コントローラー クラス:
@RequestMapping(value = "valid", method = RequestMethod.GET) public String valid(@Validated Person person) { System.out.println(person); return "success"; }ログイン後にコピー
@RestControllerAdvice public class BindExceptionHanlder { @ExceptionHandler(BindException.class) public String handleBindException(HttpServletRequest request, BindException exception) { List<FieldError> allErrors = exception.getFieldErrors(); StringBuilder sb = new StringBuilder(); for (FieldError errorMessage : allErrors) { sb.append(errorMessage.getField()).append(": ").append(errorMessage.getDefaultMessage()).append(", "); } System.out.println(sb.toString()); return sb.toString(); } }
输出:age: age不能大于100小于0,
@Documented @Constraint(validatedBy = NameValidationValidator.class) @Target({ElementType.METHOD, ElementType.FIELD}) @Retention(RUNTIME) public @interface NameValidation { String message() default "不是合法的名字"; Class<?>[] groups() default {}; Class<? extends Payload>[] payload() default {}; @Target({PARAMETER, ANNOTATION_TYPE}) @Retention(RUNTIME) @Documented @interface List { NameValidation[] value(); } }
public class NameValidationValidator implements ConstraintValidator<NameValidation, String> { @Override public boolean isValid(String value, ConstraintValidatorContext context) { if ("steven".equalsIgnoreCase(value)) { return true; } String defaultConstraintMessageTemplate = context.getDefaultConstraintMessageTemplate(); System.out.println("default message :" + defaultConstraintMessageTemplate); //禁用默认提示信息 //context.disableDefaultConstraintViolation(); //设置提示语 //context.buildConstraintViolationWithTemplate("can not contains blank").addConstraintViolation(); return false; } }
@NotEmpty(message = "name不能为空") @NameValidation private String name;
测试: http://localhost:8080/valid?age=105&name=lxy
输出:age: age不能大于100小于0, name: 不是合法的名字,
以上がSpringBoot が検証を使用してエレガントな検証パラメーターを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。