PHP
  Home arrow PHP arrow Page 4 - Developing a Form Validation System wi...
Administration  
AJAX  
Apache  
BrainDump  
DHTML  
Flash  
Java  
JavaScript  
Multimedia  
MySQL  
Oracle  
Perl  
PHP  
Practices  
Python  
Reviews  
Security  
Style-Sheets  
Web Services  
XML  
Zend  
Zope  
Forums Sitemap 
IBM® developerWorks 
Sun Developer Network 
E-Commerce Hosting 
Linux Web Hosting 
Managed Hosting 
Small Business Hosting 
Mobile Linux 
App Generation ROI 
VPS Hosting 
Weekly Newsletter

 
Developer Updates  
Free Website Content 
 RSS  Articles
 RSS  Forums
 RSS  All Feeds
Write For Us Get Paid 
Request Media Kit
Contact Us 
Site Map 
Privacy Policy 
Support 
 USERNAME
 
 PASSWORD
 
 
  >>> SIGN UP!  
  Lost Password? 
PHP

Developing a Form Validation System with the Observer Pattern in PHP
By: Alejandro Gervasio
  • Search For More Articles!
  • Disclaimer
  • Author Terms
  • Rating: 5 stars5 stars5 stars5 stars5 stars / 7
    2006-07-24

    Table of Contents:
  • Developing a Form Validation System with the Observer Pattern in PHP
  • Validating input data: constructing some useful data validation classes
  • Extending the scope of data validation: defining some additional data checking classes
  • Getting the whole picture: listing the full source code for the data checking classes

  • Rate this Article: Poor Best 
      ADD THIS ARTICLE TO:
      Del.ici.ous Digg
      Blink Simpy
      Google Spurl
      Y! MyWeb Furl
    Email Me Similar Content When Posted
    Add Developer Shed Article Feed To Your Site
    Email Article To Friend
    Print Version Of Article
    PDF Version Of Article
     
     
    ADVERTISEMENT


    Developing a Form Validation System with the Observer Pattern in PHP - Getting the whole picture: listing the full source code for the data checking classes


    (Page 4 of 4 )

    Culled from my own experience, I know that it’s much better to have all the source code listed in one place. For this simple reason, below I’ve listed all the data validation classes that I’ve defined in the previous section, so you can have a clear idea of how all the pieces fit together. Here they are:

      // define DataValidator class
      class DataValidator{
        protected $method;
        protected $formObserver;
        public function __construct(FormObserver $formObserver){
            $this->formObserver=$formObserver;
            $this->method=$_POST;
        }
        protected function notifyObserver($errorMessage){
            $this->formObserver->addNotification($errorMessage);
        }
      }
      // define StringValidator class
      class StringValidator extends DataValidator{
        public function __construct($formObserver){
            parent::__construct($formObserver);
        }
        // validate strings
        public function validate($field,$errorMessage,$min=4,$max=32){
            if(!isset($this->method[$field])||trim($this->method
    [$field])==''||strlen($this->method[$field])<$min||strlen($this-
    >method[$field])>$max){
                $this->notifyObserver($errorMessage);
            }
        }
      }
      // define IntegerValidator class
      class IntegerValidator extends DataValidator{
        public function __construct($formObserver){
            parent::__construct($formObserver);
        }
        // validate integers
        public function validate($field,$errorMessage){
            if(!isset($this->method[$field])||!is_numeric($this-
    >method[$field])||intval($this->method[$field])!=$this->method
    [$field]){
                $this->notifyObserver($errorMessage);
            }
        }
      }
      // define NumberValidator class
      class NumberValidator extends DataValidator{
        public function __construct($formObserver){
            parent::__construct($formObserver);
        }
        // validate numbers
        public function validate($field,$errorMessage){
            if(!isset($this->method[$field])||!is_numeric($this-
    >method[$field])){
                $this->notifyObserver($errorMessage);
            }
        }
      }
      // define RangeValidator class
      class RangeValidator extends DataValidator{
        public function __construct($formObserver){
            parent::__construct($formObserver);
        }
        // validate ranges
        public function validate($field,$errorMessage,$min=1,$max=99){
            if(!isset($this->method[$field])||$this->method[$field]
    <$min||$this->method[$field]>$max){
                $this->notifyObserver($errorMessage);
            }
        }
      }
      // define AlphaValidator class
      class AlphaValidator extends DataValidator{
        public function __construct($formObserver){
            parent::__construct($formObserver);
        }
        // validate alphabetic field
        public function validate($field,$errorMessage){
            if(!isset($this->method[$field])||!preg_match("/^[a-zA-Z]
    +$/",$this->method[$field])){
                $this->notifyObserver($errorMessage);
            }
        }
      }
      // define AlphanumValidator class
      class AlphanumValidator extends DataValidator{
        public function __construct($formObserver){
            parent::__construct($formObserver);
        // validate alphanumeric data
        public function validate($field,$errorMessage){
            if(!isset($this->method[$field])||!preg_match("/^[a-zA-
    Z0-9]+$/",$this->method[$field])){
                $this->notifyObserver($errorMessage);
            }
        }
      }
      // define EmailValidator class
      class EmailValidator extends DataValidator{
        public function __construct($formObserver){
            parent::__construct($formObserver);
        }
        // validate email
        public function validate($field,$errorMessage){
            if(!isset($this->method[$field])||!preg_match
    ("/.+@.+..+/",$this->method[$field])||!checkdnsrr(array_pop
    (explode("@",$this->method[$field])),"MX")){
                $this->notifyObserver($errorMessage);
            }
        }
      }
      // define EmailValidatorWin class (Windows systems)
      class EmailValidatorWin extends DataValidator{
        public function __construct($formObserver){
            parent::__construct($formObserver);
        }
        public function validate($field,$errorMessage){
            if(!isset($this->method[$field])||!preg_match
    ("/.+@.+..+/",$this->method[$field])||!$this->windnsrr(array_pop
    (explode("@",$this->method[$field])),"MX")){
                $this->notifyObserver($errorMessage);
            }
        }
        // private method 'windnsrr()' for Windows systems
        private function windnsrr($hostName,$recType=''){
            if(!empty($hostName)){
                if($recType=='')$recType="MX";
                exec("nslookup -type=$recType $hostName",$result);
                foreach($result as $line){
                    if(preg_match("/^$hostName/",$line)){
                        return true;
                    }
                }
                return false;
            }
            return false;
        }
      }

    Here you have it. Now that you have the entire set of data validation classes listed in one place, feel free to improve them, in accordance with your specific programming requirements. It’s truly educational, believe me.

    To wrap up

    In this second article, you learned how to build a data validation system which uses independent objects for checking the validity of a broad range of user-supplied input, and also is capable of sending information about errors to a core object when user data fails to pass the verification process. However, the application is still incomplete, since the “core object” that I mentioned before remains undefined.

    But, there’s no reason to panic. In the last article, I’ll show you how to define an observer object at the application’s core level, in this way providing the program with a centralized mechanism for making programmatic decisions based upon the errors that occurred when validating user-provided data. I'll meet you in the last tutorial!


    DISCLAIMER: The content provided in this article is not warranted or guaranteed by Developer Shed, Inc. The content provided is intended for entertainment and/or educational purposes in order to introduce to the reader key ideas, concepts, and/or product reviews. As such it is incumbent upon the reader to employ real-world tactics for security and implementation of best practices. We are not liable for any negative consequences that may result from implementing any information covered in our articles or tutorials. If this is a hardware review, it is not recommended to open and/or modify your hardware.

       · This second article of the series is aimed at demostrating how an observer object...
     

       

    PHP ARTICLES

    - Working With Different Namespaces in PHP 5
    - User Management Explained: Overview
    - Using Namespaces in PHP 5
    - Database Security: Guarding Against SQL Inje...
    - Building a Modular Exception Class in PHP 5
    - Database and Password Security for Web Appli...
    - Handling MySQL Data Set Failures in PHP 5
    - Building Site Registration for Web Applicati...
    - Intercepting Customized Exceptions in PHP 5
    - Securing Your Web Application Against Attacks
    - Sub Classing Exceptions in PHP 5
    - Authentication for Web Application Security
    - Building a Content Management System with Co...
    - Filters and Login Systems for Web Applicatio...
    - Working with the Email Class in Code Igniter





    © 2003-2008 by Developer Shed. All rights reserved. DS Cluster 3 hosted by Hostway
    Stay green...Green IT