Skip to content
Derek Jones edited this page Jul 4, 2012 · 3 revisions

Esta Library ajuda a resolver certos problemas de validação de alguns campos comuns para quem trabalha no Brasil, são eles: CEP, CNPJ, CPF e e-mail. Quem quiser colaborar e colocar mais validações, fique à vontade.

<?php  if (!defined('BASEPATH')) exit('No direct script access allowed');
/**
 * Library Validar
 *
 * @author DGmike http://dgmike.wordpress.com
 */
class validar {
    /**
     * Retira todos os caracteres que nao forem numericos de uma string
     *
     * @param string $value
     * @return string
     */
    function _toNumber ($value) {
        return preg_replace('/[^0-9]/','',$value);
    }
    /**
     * Faz a soma dos produtos de um determinado número decomposto, ate o dois.
     * Por exeplo, _soma (15346,5) efetuará a seguinte equaçao:
     * 5*1 + 4*5 + 3*3 + 2*4
     * Esta funçao e primordial para as funções de cpf e cnpj
     *
     * @param integer $value
     * @param integer $start
     * @return integer
     */
    function _soma ($value,$start) {
        for ($soma=0,$i=$start,$j=0;$i!=1;$i--,$j++) $soma+=$i*$value{$j};
        return $soma;
    }
    function cep ($uf,$cep) {
        $cep=self::_toNumber($cep);
        $uf=strtoupper ($uf);
        if      ($uf=='SP') $regex = '/^([1][0-9]{3}|[01][0-9]{4})' . '[0-9]{3}$/';
        else if ($uf=='RJ') $regex = '/^[2][0-8][0-9]{3}'           . '[0-9]{3}$/';
        else if ($uf=='MS') $regex = '/^[7][9][0-9]{3}'             . '[0-9]{3}$/';
        else if ($uf=='MG') $regex = '/^[3][0-9]{4}'                . '[0-9]{3}$/';
        else if ($uf=='MT') $regex = '/^[7][8][8][0-9]{2}'          . '[0-9]{3}$/';
        else if ($uf=='AC') $regex = '/^[6][9]{2}[0-9]{2}'          . '[0-9]{3}$/';
        else if ($uf=='AL') $regex = '/^[5][7][0-9]{3}'             . '[0-9]{3}$/';
        else if ($uf=='AM') $regex = '/^[6][9][0-8][0-9]{2}'        . '[0-9]{3}$/';
        else if ($uf=='AP') $regex = '/^[6][89][9][0-9]{2}'         . '[0-9]{3}$/';
        else if ($uf=='BA') $regex = '/^[4][0-8][0-9]{3}'           . '[0-9]{3}$/';
        else if ($uf=='CE') $regex = '/^[6][0-3][0-9]{3}'           . '[0-9]{3}$/';
        else if ($uf=='DF') $regex = '/^[7][0-3][0-6][0-9]{2}'      . '[0-9]{3}$/';
        else if ($uf=='ES') $regex = '/^[2][9][0-9]{3}'             . '[0-9]{3}$/';
        else if ($uf=='GO') $regex = '/^[7][3-6][7-9][0-9]{2}'      . '[0-9]{3}$/';
        else if ($uf=='MA') $regex = '/^[6][5][0-9]{3}'             . '[0-9]{3}$/';
        else if ($uf=='PA') $regex = '/^[6][6-8][0-8][0-9]{2}'      . '[0-9]{3}$/';
        else if ($uf=='PB') $regex = '/^[5][8][0-9]{3}'             . '[0-9]{3}$/';
        else if ($uf=='PE') $regex = '/^[5][0-6][0-9]{2}'           . '[0-9]{3}$/';
        else if ($uf=='PI') $regex = '/^[6][4][0-9]{3}'             . '[0-9]{3}$/';
        else if ($uf=='PR') $regex = '/^[8][0-7][0-9]{3}'           . '[0-9]{3}$/';
        else if ($uf=='RN') $regex = '/^[5][9][0-9]{3}'             . '[0-9]{3}$/';
        else if ($uf=='RO') $regex = '/^[7][8][9][0-9]{2}'          . '[0-9]{3}$/';
        else if ($uf=='RR') $regex = '/^[6][9][3][0-9]{2}'          . '[0-9]{3}$/';
        else if ($uf=='RS') $regex = '/^[9][0-9]{4}'                . '[0-9]{3}$/';
        else if ($uf=='SC') $regex = '/^[8][89][0-9]{3}'            . '[0-9]{3}$/';
        else if ($uf=='SE') $regex = '/^[4][9][0-9]{3}'             . '[0-9]{3}$/';
        else if ($uf=='TO') $regex = '/^[7][7][0-9]{3}'             . '[0-9]{3}$/';
        else return false;
        if(!preg_match($regex,$cep)) return false;
        return true;
    }
    /**
     * Valida um e-mail especificado
     *
     * @param string $email
     * @return bool
     */
    function email ($email) {
        $email=trim (strtolower($email));
        if (strlen($email)<6) return false;
        if (!preg_match('/^[a-z0-9]+([\._-][a-z0-9]+)*@[a-z0-9_-]+(\.[a-z0-9]+){0,4}\.[a-z0-9]{1,4}$/',$email)) return false;
        $domain=end (explode ('@',$email));
        //if (!gethostbynamel ($domain)) return false;
        return true;
    }
    /**
     * Valida um cpf ou cnpj, dependendo da quantidade de caracteres numericos que a string contiver
     * O cpf ou cnpj podem ser passados com os pontos separadores ou barras
     *
     * @param string $value
     * @return array
     */
    function cpfcnpj ($value) {
        $value=self::_toNumber($value);
        if ( in_array( strlen($value), array (10,11) ) ) return self::CPF($value,true);
        if ( in_array( strlen($value), array (14) ) ) return self::CNPJ($value,true);
        return array ('CPF/CNPJ');
    }
    /**
     * CPF, pode ser passado com separadores
     *
     * @param string $value
     * @param bool $returnArray
     * @return bool|array
     */
    function CPF ($value,$returnArray=false) {
        $value=self::_toNumber($value);
        if ( !in_array( strlen($value), array (10,11) ) ) return ($returnArray?array('cpf',false):false);
        if (str_repeat($value{1},strlen($value))==$value) return ($returnArray?array('cpf',false):false);
        $value=str_pad($value,11,0,STR_PAD_LEFT);
        if ( in_array($value,array ('12345678909','01234567890','00123456797'))) return ($returnArray?array('cpf',false):false);
        $soma=self::_soma($value,10);
        $soma=$soma;
        $resultado1=($soma==0 || $soma==1)?0:11-$soma;
        if ($resultado1!=$value{9}) return ($returnArray?array('cpf',false):false);
        $soma=self::_soma($value,11);
        $soma=$soma;
        $resultado2=($soma==0 || $soma==1)?0:11-$soma;
        return (($resultado2==$value{10})?($returnArray?array('cpf',true):true):($returnArray?array('cpf'):false));
    }
    /**
     * CNPJ, pode ser passado com separadores
     *
     * @param string $value
     * @param bool $returnArray
     * @return bool|array
     */
    function CNPJ ($value,$returnArray=false) {
        $value=self::_toNumber($value);
        if ( !in_array( strlen($value), array (14) ) ) return ($returnArray?array('cnpj',false):false);
        if (str_repeat($value{1},strlen($value))==$value) return ($returnArray?array('cnpj',false):false);
        if ( in_array($value,array ('12345678901230','01234567890107'))) return ($returnArray?array('cnpj',false):false);
        $soma=self::_soma($value,5)+self::_soma(substr($value,4),9);
        $soma=$soma;
        $resultado1=($soma==0 || $soma==1)?0:11-$soma;
        if ($resultado1!=$value{12}) return ($returnArray?array('cnpj',false):false);
        $soma=self::_soma($value,6)+self::_soma(substr($value,5),9);
        $soma=$soma;
        $resultado1=($soma==0 || $soma==1)?0:11-$soma;
        return (($resultado1==$value{13})?($returnArray?array('cnpj',true):true):($returnArray?array('cnpj'):false));
    }
    function senha ($senha,$senha2=null,$minChr=5,$noSpaces=true) {
      if ( ($noSpaces) && ( strpos ($senha,chr(32)) ) ) return false;
      if (strlen ($senha)<$minChr) return false;
      if (($senha2) && ($senha!=$senha2)) return false;
      return true;
    }
}
?&gt;
Clone this wiki locally