Ir para conteúdo

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

contato.hudsonalves

Problema com validação de CPF

Recommended Posts

Estou precisando de uma ajuda, no meu sistema (antigo) utilizava um campo de cadastro de usuários contendo: Usuário, senha, nome, sobrenome, e-mail, estado e Endereço. O campo endereço era o único que não passava pela validação de campo por não ter obrigatoriedade de registro. Hoje quero qe o campo endereço seja CPF e gostaria de incluir a validação dele.

 

 

Bem atualmente utilizo este script para validação dos campos anteriores que funciona muito bem:

 

<script language="JavaScript" type="text/JavaScript"><!--function MM_findObj(n, d) { //v4.01  var p,i,x;  if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {    d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}  if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];  for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document);  if(!x && d.getElementById) x=d.getElementById(n); return x;} function MM_validateForm() { //v4.0  var i,p,q,nm,test,num,min,max,errors='',args=MM_validateForm.arguments;  for (i=0; i<(args.length-2); i+=3) { test=args[i+2]; val=MM_findObj(args[i]);    if (val) { nm=val.name; if ((val=val.value)!="") {      if (test.indexOf('isEmail')!=-1) { p=val.indexOf('@');        if (p<1 || p==(val.length-1)) errors+='- '+nm+' deve conter endereço de e-mail.\n';      } else if (test!='R') { num = parseFloat(val);        if (isNaN(val)) errors+='- '+nm+' deve conter um número.\n';        if (test.indexOf('inRange') != -1) { p=test.indexOf(':');          min=test.substring(8,p); max=test.substring(p+1);          if (num<min || max<num) errors+='- '+nm+' deve conter um número no meio '+min+' and '+max+'.\n';    } } } else if (test.charAt(0) == 'R') errors += '- '+nm+' é necessário.\n'; }  } if (errors) alert('Ocorreram os seguinte(s) erro(s):\n'+errors);  document.MM_returnValue = (errors == '');}//-->
<script language="JavaScript" type="text/JavaScript">

</script></script>

 

 

Ao realizar o cadastro envio desta forma:

 

<input name="Register" type="submit" class="button" id="Register" onClick="MM_validateForm('CPF','','Rcpf','U_ID','','R','U_FIRST','','R','U_LAST','','R','U_EMAIL','','RisEmail','U_COUNTRY','','R','U_PASSWORD','','R');return document.MM_returnValue" value="Cadastre-se">

 

Os campos do banco de dados são exatamente estes, embora utilize este código de validação ele não vai verificar o CPF, desta forma encontrei o arquivo abaixo para validação:

 

function abre_janela(width, height, nome) {var top; var left;top = ( (screen.height/2) - (height/2) )left = ( (screen.width/2) - (width/2) )window.open('',nome,'width='+width+',height='+height+',scrollbars=no,toolbar=no,location=no,status=no,menubar=no,resizable=no,left='+left+',top='+top);}function recebe_imagem(campo, imagem){var foto = 'img_' + campodocument.form_incluir[campo].value = imagem;document.form_incluir[foto].src = imagem;}function verifica_form(form) {var passed = false;var ok = falsevar campofor (i = 0; i < form.length; i++) {  campo = form[i].name; var excessoes = "nome,email,assunto,mensagem"; if (excessoes.indexOf(form[i].name) != -1) {    if (form[i].type == "text"  | form[i].type == "textarea" | form[i].type == "select-one") {      if (form[i].value == "" | form[i].value == "http://") {form[campo].className='campo_alerta'        form[campo].focus();        alert("Preencha corretamente o campo");        return passed;        stop;      }    }    else if (form[i].type == "radio") {      for (x = 0; x < form[campo].length; x++) {        ok = false;        if (form[campo][x].checked) {          ok = true;          break;        }      }      if (ok == false) {        form[campo][0].focus();form[campo][0].select();        alert("Informe uma das opcões");        return passed;        stop;      }    }    var msg = ""    if (form[campo].df_validar == "cpf") msg = checa_cpf(form[campo].value);    if (form[campo].df_validar == "cnpj") msg = checa_cnpj(form[campo].value);    if (form[campo].df_validar == "cpf_cnpj") { msg = checa_cpf(form[campo].value); if (msg != "") msg = checa_cnpj(form[campo].value);}     if (form[campo].id == "email") msg = checa_email(form[campo].value);    if (form[campo].df_validar == "numerico") msg = checa_numerico(form[campo].value);    if (msg != "") { if (form[campo].df_validar == "cpf_cnpj") msg = "informe corretamente o número do CPF ou CNPJ"; form[campo].className='campo_alerta'      form[campo].focus();      form[campo].select();      alert(msg);      return passed;      stop;    }  }}passed = true;return passed;}function desabilita_cor(campo) {campo.className='campos_formulario'}function checa_numerico(String) {var mensagem = "Este campo aceita somente números"var msg = "";if (isNaN(String)) msg = mensagem;return msg;}function checa_email(campo) {var mensagem = "Informe corretamente o email"var msg = "";var email = campo.match(/(\w+)@(.+)\.(\w+)$/);if (email == null){  msg = mensagem;  }return msg;}function checa_cpf(CPF) {var mensagem = "informe corretamente o número do CPF"var msg = "";if (CPF.length != 11 || CPF == "00000000000" || CPF == "11111111111" ||  CPF == "22222222222" || CPF == "33333333333" || CPF == "44444444444" ||  CPF == "55555555555" || CPF == "66666666666" || CPF == "77777777777" ||  CPF == "88888888888" || CPF == "99999999999")msg = mensagem;soma = 0;for (y=0; y < 9; y ++)soma += parseInt(CPF.charAt(y)) * (10 - y);resto = 11 - (soma % 11);if (resto == 10 || resto == 11)resto = 0;if (resto != parseInt(CPF.charAt(9)))  msg = mensagem; soma = 0;for (y = 0; y < 10; y ++)  soma += parseInt(CPF.charAt(y)) * (11 - y);resto = 11 - (soma % 11);if (resto == 10 || resto == 11) resto = 0;if (resto != parseInt(CPF.charAt(10)))  msg = mensagem;return msg;}function checa_cnpj(s) {var mensagem = "informe corretamente o número do CNPJ"var msg = "";var y;var c = s.substr(0,12);var dv = s.substr(12,2);var d1 = 0;for (y = 0; y < 12; y++){d1 += c.charAt(11-y)*(2+(y % 8));}if (d1 == 0) msg = mensagem;d1 = 11 - (d1 % 11);if (d1 > 9) d1 = 0;if (dv.charAt(0) != d1)msg = mensagem;d1 *= 2;for (y = 0; y < 12; y++){d1 += c.charAt(11-y)*(2+((y+1) % 8));}d1 = 11 - (d1 % 11);if (d1 > 9) d1 = 0;if (dv.charAt(1) != d1) msg = mensagem;return msg;}function mascara_data(data){ var mydata = ''; mydata = mydata + data; if (mydata.length == 2){ mydata = mydata + '/'; } if (mydata.length == 5){ mydata = mydata + '/'; } return mydata; } function verifica_data(data) { if (data.value != "") {dia = (data.value.substring(0,2));mes = (data.value.substring(3,5)); ano = (data.value.substring(6,10)); situacao = ""; if ((dia < 01)||(dia < 01 || dia > 30) && (  mes == 04 || mes == 06 || mes == 09 || mes == 11 ) || dia > 31) { situacao = "falsa"; } if (mes < 01 || mes > 12 ) { situacao = "falsa"; }if (mes == 2 && ( dia < 01 || dia > 29 || ( dia > 28 && (parseInt(ano / 4) != ano / 4)))) { situacao = "falsa"; } if (situacao == "falsa") { data.focus();data.select();alert("Data inválida!"); }} } 

 

 

Qual é minha dúvida:

 

No formulário de envio utilizo o "onClick="MM_validateForm", como eu faço para unir os dois e reconhecer e validar o CPF?

 

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

coloque a função de validação dentro do MM_validateForm no evento onclick , ou usar uma função separada também no evento onclick

Compartilhar este post


Link para o post
Compartilhar em outros sites

essa função MM_validateForm é característica do DW, vc terá que adptar sua função de CPF dentro dela, ou vc pode usar um regularexpression para o CPF, i´ra ficar até com um desempenho melhor

 

use esse

 

 

<%

'-----------------------------------------------------

'Funcao: IsCPF(ByVal intNumero)

'Sinopse: Verifica se o valor passado é um CPF válido

' Formatos aceitos: XXX.XXX.XXX-XX ou

' XXXXXXXXXXXXXX

'Parametro: intNumero

'Retorno: Booleano

'-----------------------------------------------------

Function IsCPF(ByVal intNumero)

'Validando o formato do CPF com expressão regular

Set regEx = New RegExp 'Cria o Objeto Expressão

regEx.Pattern = "^(\d{3}\.\d{3}\.\d{3}-\d{2})|(\d{11})$" ' Expressão Regular

regEx.IgnoreCase = True ' Sensitivo ou não

regEx.Global = True

Retorno = RegEx.Test(intNumero)

Set regEx = Nothing

'Caso seja verdadeiro posso validar se o CPF é válido

If Retorno = True Then

'Validando a sequencia números

Dim CPF_temp

CPF_temp = intNumero

CPF_temp = Replace(CPF_temp, ".", "")

CPF_temp = Replace(CPF_temp, "-", "")

CPF_Digito_temp = Right(CPF_temp, 2)

 

'Somando os nove primeiros digitos do CPF

Soma = (Clng(Mid(CPF_temp,1,1)) * 10) + (Clng(Mid(CPF_temp,2,1)) * 9) + (Clng(Mid(CPF_temp,3,1)) * 8) + (Clng(Mid(CPF_temp,4,1)) * 7) + (Clng(Mid(CPF_temp,5,1)) * 6) + (Clng(Mid(CPF_temp,6,1)) * 5) + (Clng(Mid(CPF_temp,7,1)) * 4) + (Clng(Mid(CPF_temp,8,1)) * 3) + (Clng(Mid(CPF_temp,9,1)) * 2)

'----------------------------------

'Calculando o 1º dígito verificador

'----------------------------------

'Pegando o resto da divisão por 11

Resto = (Soma Mod 11)

 

If Resto = 1 Or Resto = 0 Then

DigitoHum = 0

Else

DigitoHum = Cstr(11-Resto)

End If

'----------------------------------

'----------------------------------

'Calculando o 2º dígito verificador

'----------------------------------

'Somando os 9 primeiros digitos do CPF mais o 1º dígito

Soma = (Clng(Mid(CPF_temp,1,1)) * 11) + (Clng(Mid(CPF_temp,2,1)) * 10) + (Clng(Mid(CPF_temp,3,1)) * 9) + (Clng(Mid(CPF_temp,4,1)) * 8) + (Clng(Mid(CPF_temp,5,1)) * 7) + (Clng(Mid(CPF_temp,6,1)) * 6) + (Clng(Mid(CPF_temp,7,1)) * 5) + (Clng(Mid(CPF_temp,8,1)) * 4) + (Clng(Mid(CPF_temp,9,1)) * 3) + (DigitoHum * 2)

'Pegando o resto da divisão por 11

Resto = (Soma Mod 11)

 

If Resto = 1 Or Resto = 0 Then

DigitoDois = 0

Else

DigitoDois = Cstr(11-Resto)

End If

'----------------------------------

'Verificando se os digitos são iguais aos digítados.

DigitoCPF = Cstr(DigitoHum) & Cstr(DigitoDois)

If Cstr(CPF_Digito_temp) = Cstr(DigitoCPF) Then

Retorno = True

Else

Retorno = False

End If

End If

IsCPF = Retorno

End Function

%>

Compartilhar este post


Link para o post
Compartilhar em outros sites

×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.