Problema com validação de CPF
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?
Discussão (3)
Carregando comentários...