intTypePromotion=1
zunia.vn Tuyển sinh 2024 dành cho Gen-Z zunia.vn zunia.vn
ADSENSE

CakePHP Framework: Kiểm tra tính hợp lệ của dữ liệu (data validation)

Chia sẻ: Eef Sff | Ngày: | Loại File: PDF | Số trang:26

179
lượt xem
17
download
 
  Download Vui lòng tải xuống để xem tài liệu đầy đủ

CakePHP Framework: Kiểm tra tính hợp lệ của dữ liệu (data validation) .Data Validation là một trong những thành phần không thể thiếu trong hầu hết các ứng dụng web. Nó giúp cho các dữ liệu được đảm bảo được kiểm tra chặt chẽ trước khi chèn vào CSDL. Cũng như CodeIgniter, Zend ,CakePHP cũng có chức năng Data Validation .Bài viết sẽ hướng dẫn cho người dùng cách sử dụng tập luật và ứng dụng chúng trong các trường hợp cụ thể khác nhau với các hàm hổ trợ sẵn của CakePHP. ...

Chủ đề:
Lưu

Nội dung Text: CakePHP Framework: Kiểm tra tính hợp lệ của dữ liệu (data validation)

  1. CakePHP Framework: Kiểm tra tính hợp lệ của dữ liệu (data validation)
  2. Data Validation là một trong những thành phần không thể thiếu trong hầu hết các ứng dụng web. Nó giúp cho các dữ liệu được đảm bảo được kiểm tra chặt chẽ trước khi chèn vào CSDL. Cũng như CodeIgniter, Zend ,CakePHP cũng có chức năng Data Validation .Bài viết sẽ hướng dẫn cho người dùng cách sử dụng tập luật và ứng dụng chúng trong các trường hợp cụ thể khác nhau với các hàm hổ trợ sẵn của CakePHP. A- Cách làm việc của Datavalidation : Để sử dụng Datavalidation thì trong ứng dụng của chúng ta cần có hai thành phần chính : + Thành phần form helper : sử dụng cho việc tạo form 1 + Thành phần namespace validate : sử dụng các tập luật để validation dữ liệu
  3. 1 B.Cài đặt Cakephp và viết ứng dụng datavalidation : Việc thực hiện cài đặt CakePHP là không khó. Nếu bạn vẫn chưa biết làm thì có thể (Xem lại bài CakePHP Framework cho người mới bắt đầu). Các thý mục cần chuẩn bị : - app/controllers/valids_controller.php - app/model/valid.php - app/views/valids/ Chuẩn bị cho Controller Valids : (app/controllers/valids_controller.php) 1
  4. 3 var $name = "Valids"; 4 var $helpers = array ('Html','Form'); var $components = array('Session'); // Use Flash messenger of Session 5 component 6 ?> Chuẩn bị cho Controller Valids : (app/models/valid.php) 1 Trong ví dụ này các ứng dụng không chèn dữ liệu vào database mà chỉ thông báo có hợp lệ hay không và báo lỗi týõng ứng . Nên trong Model tôi dùng namespace là var $useTable = false; để ám chỉ là không sử dụng bảng CSDL
  5. C. Sử dụng 1 tập luật cho 1 field - Yêu cầu tạo 1 form nhập liệu với 2 field với các tập luật được mô tả : - title : không được phép rỗng - info : không được phép rỗng Trong Controller Valid ta thêm hàm demo01 : 01
  6. 10 $this->Session->setFlash("Data is avaliable !"); 11 }else{ 12 $this->Session->setFlash("Data is not avaliable !"); 13 } 14 } 15 ?> Chức năng validation sẽ được kích hoạt khi ta dùng hàm $this->Valid- >set($this->data); Sau đó Model Valid gọi hàm valid_01() để sử dụng tập luật cho các field tương ứng (title,info) Trong thư mục app/views/valids/ tạo file demo01.ctp : 1 Add Post 2
  7. 6 echo $this->Form->end('Register'); 7 ?> + Để validate dữ liệu ta dùng namespace validate ($this->validate) để gán tập luật cho các field + Với rule là từ khóa để chỉ đó là tập luật và notEmpty là từ khóa để nói là không được rỗng + Trong 1 số tài liệu ngýời ta có thể dùng từ khóa VALID_NOT_EMPTY ðể thay cho từ khóa notEmpty + Message là từ khóa để chỉ thông báo lỗi $this->validates($this->validate) //hàm kiểm tra các tập luật Các từ được coi từ khóa thì phải viết đúng tên và giữ nguyên nội dung của từ.
  8. Chạy thử ứng dụng đầu tiên : http://localhost/cakephp/valids/demo01 Một số tập luật thông dụng : § 'rule' => 'alphaNumeric' : chỉ có số hoặc chữ § 'rule' => array('between', 5, 15) : giá trị nằm trong khoản từ 5-15 § 'rule' => array('comparison', '>=', 18) : giá trị phải lớn hõn 18 § 'rule' => array('email', true) : định dạng email
  9. § 'rule' => array('extension', array('gif', 'jpeg', 'png', 'jpg')) : dành cho upload file , kiểm tra extension § 'rule' => array('minLength', 8) : độ dài nhỏ nhất là 8 § 'rule' => array('maxLength', 8) : độ dài tối đa là 8 § 'rule' => 'numeric' : dữ liệu nhập là số § 'rule' => 'notEmpty' : dữ liệu không được bỏ trống § 'rule' => 'url' : định dạng địa chỉ url D. Sử dụng nhiều tập luật cho 1 field Yêu cầu tạo 1 form nhập liệu với 3 field với các tập luật được mô tả : - Username : không được phép rỗng, tối đa là 10 kí tự, ít nhất là 4 kí tự - Email : không được phép rỗng, định dạng là email - website: không được phép rỗng, định dạng là địa chỉ url Trong Controller Valid ta thêm hàm demo02 : 01
  10. 03 var $name = "Valids"; 04 var $helpers = array ('Html','Form'); var $components = array('Session'); // Use Flash messenger of Session 05 component 06 // ---- Valid multi rules 07 function demo02(){ 08 $this->Valid->set($this->data); 09 if($this->Valid->valid_02()==TRUE){ 10 $this->Session->setFlash("Data is avaliable !"); 11 }else{ 12 $this->Session->setFlash("Data is not avaliable !"); 13 } 14 } 15 ?> Trong thý mục app/views/valids/ tạo file demo02.ctp : 1 Add Post 2
  11. 3 echo $this->Form->create('Valid', array('action' => 'demo02')); 4 echo $this->Form->input('username'); 5 echo $this->Form->input('email'); 6 echo $this->Form->input('website'); 7 echo $this->Form->end('Register'); 8 ?> Trong model Valid thêm hàm valid_02() : 01
  12. 11 "message" => "Username can not empty", 12 ), 13 "rule2" => array( 14 "rule" => array('minLength', 4), 15 "message" => "Usernames must be at least 4 characters long", 16 ), 17 "rule3" => array( 18 "rule" => array('maxLength', 10), 19 "message" => "Usernames must be no larger than 10 characters long", 20 ), 21 ), 22 "email" => array( 23 "rule1" => array( 24 "rule" => "notEmpty", 25 "message" => "Please enter email !", 26 ),
  13. 27 "rule2" => array( 28 "rule" => "email", 29 "message" => "Email not avaliable !", 30 ), 31 ), 32 "website" => array( 33 "rule1" => array( 34 "rule" => "notEmpty", 35 "message" => "Please enter website !", 36 ), 37 "rule2" => array( 38 "rule" => "url", 39 "message" => "website is not avaliable", 40 ), 41 ), 42 );
  14. 43 if($this->validates($this->validate)) 44 return TRUE; 45 else 46 return FALSE; 47 } 48 ?> Chạy thử ứng dụng : http://localhost/cakephp/valids/demo02
  15. E. Sử dụng tập luật bằng regular expression - Thông thường các rule có sẵn không đáp ứng được nhu cầu validation dữ liệu của chúng ta , với những ứng dụng phức tạp đòi hỏi khắc khe về việc nhập liệu thì Cakephp cũng có hổ trợ validation với Regular Expression.
  16. - Để sử dụng Regular Expression thì cú pháp như sau : 1 Ví dụ : + 'rule' => '/^[a-z0-9]{4,10}$/i' Dữ liệu chỉ là chữ thường và số, có từ 4-10 kí tự + 'rule' => '/^[a-z A-Z]{1}[a-z A-Z 0-9_]+@[a-z A-Z 0-9]{2,}.[a-z A- Z]{2,}$/i ' Kí tự đầu tiên chỉ là các kí tự chữ hoa hoặc thường
  17. Tiếp theo chỉ là các kí tự chữ hoa hoặc thường, số và dấu "_" , các kí tự này có thể xuất hiện hoặc xuất hiện nhiều lần Tiếp theo là kí tự bắt buộc phải có "@" Tiếp theo chỉ là các kí tự hoa hoặc thường và số , ít nhất là 2 kí tự Tiếp theo là kí tự bắt buộc phải có là "." Tiếp theo là các kí tự hoa hoặc thường , ít nhất là 2 kí tự Bắt đầu viết ứng dụng với 2 Regular Expression trên : - Yêu cầu tạo 1 form nhập liệu với 2 field với các tập luật được mô tả : - username : với Regular Expression thứ 1 - email : với Regular Expression thứ 2
  18. Trong Controller Valid ta thêm hàm demo03 : 01
  19. Trong thý mục app/views/valids/ tạo file demo03.ctp : 1 Add Post 2 Trong model Valid thêm hàm valid_03() : 01
  20. 09 'rule' => '/^[a-z0-9]{4,10}$/i', 'message' => 'Username must be integer and alphabet, between 4-10 10 characters', 11 ), 12 "email" => array( 'rule' => '/^[a-z A-Z]{1}[a-z A-Z 0-9_]+@[a-z A-Z 0-9]{2,}.[a-z A- 13 Z]{2,}$/i', 14 'message' => 'email not avaliable', 15 ), 16 ); 17 if($this->validates($this->validate)) 18 return TRUE; 19 else 20 return FALSE; 21 } 22 ?> Chạy thử ứng dụng : http://localhost/cakephp/valids/demo03
ADSENSE

CÓ THỂ BẠN MUỐN DOWNLOAD

 

Đồng bộ tài khoản
2=>2