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.01var 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.0var 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?