org.jrimum.vallia.CPFValidator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bpp-cobranca Show documentation
Show all versions of bpp-cobranca Show documentation
This is a fork and merge from JRimum ( http://www.jrimum.org ),
- Bopepo: https://github.com/jrimum/bopepo
- Texgit: https://github.com/jrimum/texgit
- Valia: https://github.com/jrimum/vallia
- Utilix: https://github.com/jrimum/utilix
- Domkee: https://github.com/jrimum/domkee
For Brazillian Boleto Payment Method. So much thanks for original authors:
Gilmar P. S. L, Misael Barreto and Rômulo Augusto.
The newest version!
/*
* Copyright 2008 JRimum Project
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by
* applicable law or agreed to in writing, software distributed under the
* License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS
* OF ANY KIND, either express or implied. See the License for the specific
* language governing permissions and limitations under the License.
*
* Created at: 30/03/2008 - 18:21:21
*
* ================================================================================
*
* Direitos autorais 2008 JRimum Project
*
* Licenciado sob a Licença Apache, Versão 2.0 ("LICENÇA"); você não pode usar
* esse arquivo exceto em conformidade com a esta LICENÇA. Você pode obter uma
* cópia desta LICENÇA em http://www.apache.org/licenses/LICENSE-2.0 A menos que
* haja exigência legal ou acordo por escrito, a distribuição de software sob
* esta LICENÇA se dará “COMO ESTÁ”, SEM GARANTIAS OU CONDIÇÕES DE QUALQUER
* TIPO, sejam expressas ou tácitas. Veja a LICENÇA para a redação específica a
* reger permissões e limitações sob esta LICENÇA.
*
* Criado em: 30/03/2008 - 18:21:21
*
*/
package org.jrimum.vallia;
/**
*
* Validador especialista para CPF.
*
*
* O cadastro de pessoa física tem as seguintes características:
*
* - Contém apenas números.
* - Possui tamanho 11 sem formatação e 14 com formatação.
* - Pode estar no formato ###.###.###-XX, onde XX é o dígito
* verificador.
*
*
*
* A validação consiste em verificar essas características e se o dígito
* verificador é válido.
*
*
*
* @author Gilmar P.S.L
* @author Misael Barreto
* @author Rômulo Augusto
* @author Nordeste Fomento
* Mercantil
*
* @since 0.2
*
* @version 0.2
*/
public class CPFValidator extends AbstractCPRFValidator {
/**
*
*/
private static final long serialVersionUID = 7284156043760247784L;
/**
* @see
* br.com.nordestefomento.jrimum.vallia.AbstractCPRFValidator#isValido()
* @since 0.2
*/
@Override
public boolean isValido() {
String cpf = getCodigoDoCadastro();
boolean isValido = isValidoCpf(cpf);
return isValido;
}
protected boolean isValidoCpf(String cpf) throws NumberFormatException, IllegalArgumentException {
boolean isValido = false;
int dv = 0;
int dvCalculado = -1;
dv = Integer.parseInt(cpf.substring(9, 11));
dvCalculado = digitoVerificador.calcule(cpf.substring(0, 9));
isValido = (dvCalculado >= 0 && dv == dvCalculado);
return isValido;
}
/**
* @see
* br.com.nordestefomento.jrimum.vallia.AbstractCPRFValidator#removeFormatacao()
* @since 0.2
*/
@Override
protected void removeFormatacao() {
String codigo = getCodigoDoCadastro();
codigo = codigo.replace(".", "");
codigo = codigo.replace("-", "");
codigoDoCadastro.delete(0, codigoDoCadastro.length());
codigoDoCadastro.append(codigo);
}
}