欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot關(guān)于List集合的校驗(yàn)方式

 更新時(shí)間:2024年07月02日 16:50:17   作者:為什么要做囚徒  
這篇文章主要介紹了SpringBoot關(guān)于List集合的校驗(yàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

SpringBoot List集合的校驗(yàn)

List集合失效的校驗(yàn)

    @PostMapping("saveBatch")
    @ApiOperation("批量保存")
    @LogOperation("批量保存")
    public Result saveBatch(@RequestBody @Validated List<ResultFieldDTO> list) {
        resultFieldService.saveBatch(list);
        return Result.ok();
    }

針對(duì)List集合的校驗(yàn)有兩種方案

  • 第一種方案

重新定義一個(gè)集合ValidList,需繼承集合List,并且定義一個(gè)List集合屬性,并添加@Valid注解

@Data
public class ValidList<E> implements List<E> {
    @Valid // 這里是關(guān)鍵
    private List<E> list = new ArrayList<>();

    @Override
    public int size() {
        return list.size();
    }

    @Override
    public boolean isEmpty() {
        return list.isEmpty();
    }

    @Override
    public boolean contains(Object o) {
        return list.contains(o);
    }

    @Override
    public Iterator<E> iterator() {
        return list.iterator();
    }

    @Override
    public Object[] toArray() {
        return list.toArray();
    }

    @Override
    public <T> T[] toArray(T[] a) {
        return list.toArray(a);
    }

    @Override
    public boolean add(E e) {
        return list.add(e);
    }

    @Override
    public boolean remove(Object o) {
        return list.remove(o);
    }

    @Override
    public boolean containsAll(Collection<?> c) {
        return list.containsAll(c);
    }

    @Override
    public boolean addAll(Collection<? extends E> c) {
        return list.addAll(c);
    }

    @Override
    public boolean addAll(int index, Collection<? extends E> c) {
        return list.addAll(index, c);
    }

    @Override
    public boolean removeAll(Collection<?> c) {
        return list.removeAll(c);
    }

    @Override
    public boolean retainAll(Collection<?> c) {
        return list.retainAll(c);
    }

    @Override
    public void clear() {
        list.clear();
    }

    @Override
    public E get(int index) {
        return list.get(index);
    }

    @Override
    public E set(int index, E element) {
        return list.set(index, element);
    }

    @Override
    public void add(int index, E element) {
        list.add(index, element);
    }

    @Override
    public E remove(int index) {
        return list.remove(index);
    }

    @Override
    public int indexOf(Object o) {
        return list.indexOf(o);
    }

    @Override
    public int lastIndexOf(Object o) {
        return list.lastIndexOf(o);
    }

    @Override
    public ListIterator<E> listIterator() {
        return list.listIterator();
    }

    @Override
    public ListIterator<E> listIterator(int index) {
        return list.listIterator(index);
    }

    @Override
    public List<E> subList(int fromIndex, int toIndex) {
        return list.subList(fromIndex, toIndex);
    }

}

集合的校驗(yàn)則變成如下方式

	@PostMapping("saveBatch")
    @ApiOperation("批量保存")
    @LogOperation("批量保存")
    public Result saveBatch(@RequestBody @Validated ValidList<ResultFieldDTO> list) {
        resultFieldService.saveBatch(list);
        return Result.ok();
    }
  • 第二種方案

controller上添加@Validated

@RestController
@RequestMapping("search")
@Validated
public class ResultFieldController {
......
}

則集合校驗(yàn)變成如下方式

	@PostMapping("saveBatch")
    @ApiOperation("批量保存")
    @LogOperation("批量保存")
    public Result saveBatch(@RequestBody @Valid List<ResultFieldDTO> list) {
        resultFieldService.saveBatch(list);
        return Result.ok();
    }

@Valid對(duì)List校驗(yàn)失效問(wèn)題

失效原因

@Valid 注解用于驗(yàn)證對(duì)象的屬性值是否滿足指定的約束條件。

然而,@Valid 注解默認(rèn)不會(huì)對(duì)集合(如 List、Set 等)內(nèi)部的元素進(jìn)行驗(yàn)證,這可能導(dǎo)致在集合內(nèi)部存在不符合約束條件的元素時(shí),驗(yàn)證失效的問(wèn)題。

解決方法

如果想要對(duì)集合內(nèi)部的元素進(jìn)行驗(yàn)證,可以結(jié)合使用 @Valid 注解和 @Validated 注解。

@Validated 注解是 Spring 提供的,它會(huì)啟用 Spring 的驗(yàn)證機(jī)制,并且可以在集合上生效。

  • 使用 @Validated 注解: 在需要驗(yàn)證的類上使用 @Validated 注解,以啟用 Spring 的驗(yàn)證機(jī)制。
  • 使用 @Valid 注解: 在需要驗(yàn)證的方法屬性集合上使用 @Valid 注解,以啟用集合內(nèi)部元素的驗(yàn)證。

代碼示例:

import org.springframework.validation.annotation.Validated;

@RestController
@Validated
public class UserController {

    @PostMapping("/users")
    public ResponseEntity<String> createUser(@Valid @RequestBody List<User> users) {
        // 處理用戶列表
        return ResponseEntity.ok("Users created successfully");
    }
}

在上述示例中,@Validated 注解用于啟用 Spring 的驗(yàn)證機(jī)制,而 @Valid 注解用于對(duì)集合內(nèi)部的 User 對(duì)象進(jìn)行驗(yàn)證。

這樣,在請(qǐng)求體中的用戶列表元素會(huì)根據(jù) User 類中的約束條件進(jìn)行驗(yàn)證,從而確保集合內(nèi)部的元素也滿足約束條件。

請(qǐng)注意,如果你正在使用 Spring Boot,通常情況下它會(huì)自動(dòng)啟用驗(yàn)證機(jī)制。

在使用 @Valid 進(jìn)行嵌套驗(yàn)證時(shí),要確保對(duì)內(nèi)部元素的約束條件也得到了正確的定義。

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論