Mengesahkan Input Pengguna dalam Spring MVC: Panduan Teliti
Mengesahkan input pengguna adalah penting untuk memastikan integriti dan kebolehpercayaan data borang dalam web aplikasi. Spring MVC menyediakan beberapa pendekatan untuk menyelesaikan tugasan ini, setiap satu dengan kelebihan dan kelemahannya.
Kaedah 1: Pengesahan Berasaskan Anotasi
Untuk keperluan pengesahan mudah, Spring 3. x dan kemudiannya memperkenalkan penggunaan anotasi javax.validation.constraints. Anotasi ini digunakan terus pada sifat kacang, menandakannya sebagai diperlukan atau tertakluk kepada kekangan tertentu. Contohnya:
<code class="java">public class User { @NotNull private String name; ... }</code>
Dalam pengawal anda, anda boleh menggunakan @Valid dan @ModelAttribute untuk melaksanakan pengesahan:
<code class="java">@RequestMapping(value="/user", method=RequestMethod.POST) public createUser(Model model, @Valid @ModelAttribute("user") User user, BindingResult result){ if (result.hasErrors()){ // do something } else { // do something else } }</code>
Kaedah 2: Pengesahan Manual
Untuk keperluan pengesahan yang lebih kompleks, laksanakan logik pengesahan secara manual menggunakan antara muka org.springframework.validation.Validator disyorkan.
<code class="java">public class UserValidator implements Validator { @Override public boolean supports(Class clazz) { return User.class.equals(clazz); } @Override public void validate(Object target, Errors errors) { User user = (User) target; if(user.getName() == null) { errors.rejectValue("name", "your_error_code"); } // do "complex" validation here } }</code>
Dalam pengawal anda:
<code class="java">@RequestMapping(value="/user", method=RequestMethod.POST) public createUser(Model model, @ModelAttribute("user") User user, BindingResult result){ UserValidator userValidator = new UserValidator(); userValidator.validate(user, result); if (result.hasErrors()){ // do something } else { // do something else } }</code>
Kaedah 3: Pendekatan Gabungan
Menggabungkan kedua-dua pengesahan berasaskan anotasi dan manual boleh memanfaatkan kelebihan kedua-dua pendekatan.
Amaran:
Pengendalian pengesahan tidak boleh dikelirukan dengan pengendalian pengecualian. Pengesahan berkaitan dengan peraturan perniagaan dan kekangan data aplikasi anda, manakala pengendalian pengecualian menangani ralat sistem.
Rujukan:
Atas ialah kandungan terperinci Bagaimanakah anda mengesahkan input pengguna dalam Spring MVC?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!