Проверка не работает в приложении Java Spring

#java #spring-boot #dto

#java #весенняя загрузка #dto

Вопрос:

Я добавил правильные аннотации проверки в свой DTO и класс API, но когда я ввожу неверные данные через postman, это не приводит к ошибке.

Класс API

 @RestController
@RequestMapping("/laptops")
@Validated
public class LaptopApi
{
    @Autowired
    private LaptopService laptopService;

    @Autowired
    private Environment environment;

    @GetMapping("/{id}")
    public ResponseEntity<LaptopDTO> getLaptop(@PathVariable Integer id)
    {
        LaptopDTO laptop = laptopService.getLaptop(id);
        return new ResponseEntity<>(laptop, HttpStatus.OK);
    }

    @GetMapping("/")
    public ResponseEntity<List<LaptopDTO>> getLaptops()
    {
        List<LaptopDTO> laptops = laptopService.getLaptops();
        return new ResponseEntity<>(laptops, HttpStatus.OK);
    }

    @PostMapping("/")
    public ResponseEntity<LaptopDTO> addLaptop(@RequestBody @Valid LaptopDTO laptopDTO)
    {
        Integer laptopId = laptopService.addLaptop(laptopDTO);
        return new ResponseEntity<>(laptopDTO, HttpStatus.OK);
    }

    @PutMapping("/")
    public ResponseEntity<LaptopDTO> updateSpecs(@RequestBody @Valid LaptopDTO laptopDTO)
    {
        laptopService.updateSpecs(laptopDTO);
        return new ResponseEntity<>(laptopDTO, HttpStatus.OK);
    }

    @DeleteMapping("{id}")
    public ResponseEntity<String> deleteLaptop(@PathVariable Integer id)
    {
        laptopService.deleteLaptop(id);
        return new ResponseEntity<>(environment.getProperty("API.LAPTOP_DELETE_SUCCESS") " " id,
                HttpStatus.OK);
    }
  

Класс DTO (я выполнил проверку регулярных выражений в модульном тесте, который работает правильно)

 public class LaptopDTO
{
    private Integer id;

    @NotNull
    private String name;

    @NotNull
    @Pattern(regexp = "(Intel core i[3579] [0-9]{4,}[A-Za-z]*)"  
                        "|(AMD Ryzen [3579] [0-9]{4,}[A-Za-z]*)",
            message = "microcenter.cpu.invalid")
    private String cpu;

    @NotNull
    @Min(value = 4)
    private Integer ram;

    @NotNull
    private Integer nvme;

    @NotNull
    private Integer ssd;

    @NotNull
    private Integer hdd;

    @NotNull
    @Pattern(regexp = "(Intel U?HD [56][23]0)|"  
                        "([Nn]vidia Geforce [GR]TX [123][06][5678]0)(| super| Ti)",
            message = "microcenter.gpu.invalid")
    private String gpu;
  
   ... //constructors and methods
  }
  

Тело запроса JSON:

 {
    "name": "asegjbofld;bsgj",
    "cpu": "radhtrhsth",
    "ram": 2,
    "nvme": 512,
    "ssd": 1000,
    "hdd": 2000,
    "gpu": "newga"
}
  

На основании недопустимого ввода данных cpu и gpu из тела запроса json предполагается ошибка из-за gpu и cpu, но запрос обрабатывается? Есть идеи о том, как исправить? Спасибо.

POM.xml

 <?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.3.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.microcenter</groupId>
    <artifactId>MicroCenter</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>MicroCenter</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>


        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>javax.validation</groupId>
            <artifactId>validation-api</artifactId>
            <version>1.1.0.Final</version>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>
  

Комментарии:

1. Какую версию Spring Boot вы используете? Это выше 1.4.7, возможно, вам придется добавить spring-boot-starter-validation зависимость. Покажите нам свой pom

2. pom.xml опубликовано, и я использую javax.validation

Ответ №1:

Версия Spring boot,

     <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.3.3.RELEASE</version>
            <relativePath/> <!-- lookup parent from repository -->
    </parent>
  

не поддерживает validator-api ,

     <dependency>
         <groupId>javax.validation</groupId>
         <artifactId>validation-api</artifactId>
         <version>1.1.0.Final</version>
    </dependency>
  

из коробки. До версии Spring boot 1.4.7 у javax.validation была готовая поддержка.

Вам нужно добавить зависимость:

     <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-validation</artifactId>
    </dependency>
  

Это добавит необходимую поддержку.

Комментарии:

1. @Alan принимаю ответ. Если помогает другим, сообщите, что это сработало для вас. Счастливого кодирования!