<?php
class CPF
{
// Codigo que valida um CPF informado quanto a validade de seus dígitos verificadores.
/**
*
* Verifica se um valor informado é um CPF válido
* @author Marcos Regis <marcos@marcosregis.com>
* @param string $cpf
* @return bool
*/
public static function validar(string $cpf): bool
{
if (strlen($cpf) != 11) {
return false;
}
$elementos = (array)str_split($cpf);
$elementos[10] = 0; // Reduz uma comparação no calculo de $somaB
$somaA = 0;
$somaB = 0;
foreach ($elementos as $indice => $elemento) {
$multiplicador = count($elementos) - $indice;
$somaA += (int)$elemento * (int)($multiplicador > 2 ? $multiplicador - 1 : 0);
$somaB += (int)$elemento * (int)$multiplicador;
}
$moduloA = (($somaA * 10) % 11) % 10;
$moduloB = (($somaB * 10) % 11) % 10;
return preg_replace('#\d{9}(\d{2})$#', '$1', $cpf) == $moduloA . $moduloB;
}
/**
* Filtra um CPF informado em <var>$cpf</var> removendo mascaras e valores como 111.111.111-11 que são
* falsos positivos
* @param string $cpf
* @return string
*/
public static function filtrar(string $cpf): string
{
$cpf = (string)preg_replace('#\D#', '', $cpf);
return (string)preg_replace('#(\d)\1{10}#', '', $cpf);
}
}
$cpfs = [
'529.982.247-25', // válido, com mascara
'123.456.789-09', // válido, regra do resto 0 ou 1
'834.115.113-89', // válido, com mascara
'50365387223', // válido, sem mascara
'112413460-38', // válido, com apenas parte da máscara
'242.629.250-92', // inválido, com máscara
'88888888888', // inválido, falso positivo sem máscaa=ra
'123.456.789', // inválido, incompleto com máscara
'123456789', // inválido, incompleto sem máscara
'', // inválido, vazio
];
foreach ($cpfs as $cpf) {
$cpfFiltrado = CPF::filtrar($cpf);
echo sprintf('O cpf [%s] é %s!' . PHP_EOL, $cpf, (CPF::validar($cpfFiltrado) ? 'válido' : 'inválido'));
}
preferences:
24.1 ms | 406 KiB | 5 Q