3 回答

TA貢獻1752條經驗 獲得超4個贊
如果可以編輯這些對象,則可以使用驗證組;
class B {
@NotNull(groups = Ignored.class)
String x;
}
class A {
@Valid
B b;
@NotNull
String y;
}
在哪里Ignored;
import javax.validation.groups.Default;
public interface Ignored extends Default {
}
如果你的控制器沒有定義這個組,它下面的任何注釋都將被忽略,因此你的要求將得到滿足,請求中的驗證B.x將被忽略,但其他字段A將被驗證。但我不是 100% 確定驗證將在數據庫端應用,你可以試試嗎?
否則你可以嘗試做;
@RestController
public class Controller {
@PostMapping("/etc")
ResponseEntity<String> addA(@RequestBody A a) { //disabled validation here
B tempB = a.getB();
a.setB(null);
validateA(a);
a.setB(tempB);
// continue logic
}
}
在哪里validateA();
import org.springframework.validation.annotation.Validated;
@Validated
public class Validator {
public void validateA(@Valid A a) {
// nothing here
}
}
這是一個丑陋的解決方案,但仍然是一個解決方案......

TA貢獻1836條經驗 獲得超4個贊
我認為您缺少在將在控制器層中驗證的參數上添加 @Vaild 注釋。
@RestController
public class AController {
@PostMapping("/a")
ResponseEntity<String> addA(@Valid @RequestBody A a) {
// persisting the a entity
return ResponseEntity.ok("A is valid");
}
}

TA貢獻1725條經驗 獲得超8個贊
實際上,如果“@Valid”注釋沒有作為參數前綴,它不會影響,@Jonathan 解釋道。
要在持久化之前啟用驗證,它的工作方式如下:
@Repository
@Validated
public MyDao {
public void insertA(@Valid A a){
//logic here
}
}
@Validated(org.springframework.validation.annotation.Validated) 是啟用參數驗證的關鍵。這個對我有用。
添加回答
舉報