All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jrimum.vallia.CPFDV Maven / Gradle / Ivy

Go to download

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:51:09
 * 
 * ================================================================================
 * 
 * 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:51:09
 * 
 */

package org.jrimum.vallia;

import java.util.regex.Pattern;

import org.apache.commons.lang3.StringUtils;
import org.jrimum.texgit.Filler;


/**
 * 

* O cálculo do dígito verificador do CPF é realizado em duas etapas e é * auxiliado pela rotina de módulo 11. *

*

* Abaixo é demonstrado como esse cálculo é feito: *

*

Exemplo para um número hipotético 222.333.666-XX:

*

* Primeiramente obtém-se um número R, calculado através da rotina de módulo 11, * a partir dos nove primeiros números do CPF, nesse caso 222333666. * Para obter o primeiro dígito verificador deve-se seguir a seguinte lógica: * * Se o número R for menor que 2, o dígito terá valor 0 (zero); senão, será a * subtração do valor do módulo (11) menos o valor do número R, ou seja, * DV = 11 - R. *

*

* Para obter o segundo dígito verificador é da mesma forma do primeiro, porém * deve ser calculado a partir dos dez primeiros números do CPF, ou seja, * 222333666 + primeiro dígito. *

*

* Obs.: Os limites mínimos e máximos do módulo 11 para o cálculo do primeiro e * do segundo dígito verificador são 2 - 10 e 2 e 11, respectivamente. *

* * @see Modulo * * * @author Gilmar P.S.L * @author Misael Barreto * @author Rômulo Augusto * @author Nordeste Fomento * Mercantil * * @since 0.2 * * @version 0.2 */ public class CPFDV extends AbstractDigitoVerificador { /** * */ private static final long serialVersionUID = 2059692008894172695L; /** *

* Liminte mínimo do para cálculo no módulo 11. *

*/ private static final int LIMITE_MINIMO = 2; /** *

* Expressão regular para validação dos nove primeiros números do CPF sem * formatação: "#########". *

*/ private static final String REGEX_CPF_DV = "\\d{9}"; /** *

* Expressão regular para validação dos nove primeiros números do CPF * formatado: "###.###.###". *

*/ private static final String REGEX_CPF_DV_FORMATTED = "\\d{3}\\.\\d{3}\\.\\d{3}"; /** * @see br.com.nordestefomento.jrimum.vallia.digitoverificador.AbstractDigitoVerificador#calcule(long) * @since 0.2 */ @Override public int calcule(long numero) { return calcule(Filler.ZERO_LEFT.fill(String.valueOf(numero), 9)); } /** * @see br.com.nordestefomento.jrimum.vallia.digitoverificador.AbstractDigitoVerificador#calcule(java.lang.String) * @since 0.2 */ @Override public int calcule(String numero) throws IllegalArgumentException { int dv1 = 0; int dv2 = 0; boolean isFormatoValido = false; validacao: { if (StringUtils.isNotBlank(numero)) { isFormatoValido = (Pattern.matches(REGEX_CPF_DV, numero) || Pattern .matches(REGEX_CPF_DV_FORMATTED, numero)); if (isFormatoValido) { numero = StringUtils.replaceChars(numero, ".", ""); dv1 = calcule(numero, 10); dv2 = calcule(numero + dv1, 11); break validacao; } } throw new IllegalArgumentException( "O CPF [ " + numero + " ] deve conter apenas números, sendo eles no formato ###.###.### ou ######### !"); } return Integer.parseInt(dv1 + "" + dv2); } /** *

* Método auxiliar para o cálculo do dígito verificador. *

*

* Calcula os dígitos separadamente. *

* * @param numero * - número a partir do qual será extraído o dígito verificador. * @param limiteMaximoDoModulo * - limite máximo do módulo utilizado, no caso, módulo 11. * @return um número que faz parte de um dígito verificador. * @throws IllegalArgumentException * caso o número não esteja no formatador desejável. * @since 0.2 */ private int calcule(String numero, int limiteMaximoDoModulo) throws IllegalArgumentException { int dv = 0; int resto = 0; resto = Modulo .calculeMod11(numero, LIMITE_MINIMO, limiteMaximoDoModulo); if (resto >= 2) { dv = TipoDeModulo.MODULO11.valor() - resto; } return dv; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy