Last active
March 6, 2025 11:02
-
Star
(172)
You must be signed in to star a gist -
Fork
(30)
You must be signed in to fork a gist
-
-
Save rafael-neri/ab3e58803a08cb4def059fce4e3c0e40 to your computer and use it in GitHub Desktop.
Validar CPF em PHP (Completo)
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
function validaCPF($cpf) { | |
// Extrai somente os números | |
$cpf = preg_replace( '/[^0-9]/is', '', $cpf ); | |
// Verifica se foi informado todos os digitos corretamente | |
if (strlen($cpf) != 11) { | |
return false; | |
} | |
// Verifica se foi informada uma sequência de digitos repetidos. Ex: 111.111.111-11 | |
if (preg_match('/(\d)\1{10}/', $cpf)) { | |
return false; | |
} | |
// Faz o calculo para validar o CPF | |
for ($t = 9; $t < 11; $t++) { | |
for ($d = 0, $c = 0; $c < $t; $c++) { | |
$d += $cpf[$c] * (($t + 1) - $c); | |
} | |
$d = ((10 * $d) % 11) % 10; | |
if ($cpf[$c] != $d) { | |
return false; | |
} | |
} | |
return true; | |
} |
Boa @hiltonbruce
@hiltonbruce se a função der um strlen diferente de 11, ele não vai retornar imediatamente a closure $fail, a função vai tentar verificar as outras regras, se o o usuário colocar uma string menor de 9 ele vai jogar um exception de offset quando o php tentar executar o "for". Aqui está o bug corrigido.
/**
* Run the validation rule.
*
* Extrai somente os números
* Verifica se foi informado todos os digitos corretamente
* Verifica se foi informada uma sequência de digitos repetidos. Ex: 111.111.111-11
* Faz o calculo para validar o CPF
*
* @param \Closure(string): \Illuminate\Translation\PotentiallyTranslatedString $fail
*/
public function validate(string $attribute, mixed $value, Closure $fail): void
{
$cpf = apenasNumeros($value);
if (strlen($cpf) !== 11) {
$fail('O :attribute deve ter exatamente 11 números.');
} elseif (preg_match('/(\d)\1{10}/', $cpf)) {
$fail('O :attribute não deve ser uma sequência de números iguais.');
} else {
for ($t = 9; $t < 11; $t++) {
for ($d = 0, $c = 0; $c < $t; $c++) {
$d += $cpf[$c] * (($t + 1) - $c);
}
$d = ((10 * $d) % 11) % 10;
if ($cpf[$c] != $d) {
$fail('O :attribute não é um número válido.');
}
}
}
}
para limpar um pouco mais o código eu coloquei a lógica de regex para limpar os caracteres do cpf em um helper "apenasNumeros", mas a lógica é a mesma ainda.
Obrigado, @rafael-neri !!
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Versão para Laravel 11
Executar comando na raiz do projeto
php artisan make:rule ValidaCPF
Classe criada com o comando anterior deverá ficar assim:
Depois que a regra for definida, você pode anexá-la a um validador, como o exemplo a seguir: