JavaScript 身份證號有效驗證詳解及實例代碼
最近需要對身份證合法性進行驗證,實名驗證是不指望了,不過原來的驗證規(guī)則太過簡單,只是簡單的驗證了身份證長度,現(xiàn)在業(yè)務(wù)需要加強下身份證驗證規(guī)則,網(wǎng)上找到了不少資料,不過都不合偶的心意,無奈只好直接寫一個,代碼還是用自己的舒服哈
JavaScript驗證身份證號
<%@ page language="java" contentType="text/html; charset=GB18030" pageEncoding="GB18030"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=GB18030"> <title>身份證驗證</title> <script type="text/javascript"> var arr2=[7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2]; var arr3=[1,0,'X',9,8,7,6,5,4,3,2]; function checkid(){ var t=document.getElementById("gettext").value; if(t.length==18){ var arr=t.split(''); var s; var reg = /^\d+$/; var pd=0; for(i=0;i<17;i++){ if(reg.test(arr[i])){ s=true; pd=arr[i]*arr2[i]+pd; }else{ s=false; break; } } if(s=true){ var r=pd%11; if(arr[17]==arr3[r]){ document.getElementById("show").innerHTML="身份證號合法 尾號為:"+arr3[r]; }else{ document.getElementById("show").innerHTML="非合法身份證號"; } } }else{ document.getElementById("show").innerHTML="非合法身份證號"; } } </script> </head> <body > <input id="gettext" type="text" size="30" onkeyup="checkid()"> <p id="show"></p><br> </body> </html>
根據(jù)網(wǎng)上的身份證的計算公式寫的一個驗證身份證號的js
第一步:將身份證號碼的第1位數(shù)字與7相乘;將身份證號碼的第2位數(shù)字與9相乘;將身份證號碼的第3位數(shù)字與10相乘;將身份證號碼的第4位數(shù)字與5相乘;將身份證號碼的第5位數(shù)字與8相乘;將身份證號碼的第6位數(shù)字與4相乘;將身份證號碼的第7位數(shù)字與2相乘;將身份證號碼的第8位數(shù)字與1相乘;將身份證號碼的第9位數(shù)字與6相乘;將身份證號碼的第10位數(shù)字與3相乘;將身份證號碼的第11位數(shù)字與7相乘;將身份證號碼的第12位數(shù)字與9相乘;將身份證號碼的第13位數(shù)字與10相乘;將身份證號碼的第14位數(shù)字與5相乘;將身份證號碼的第15位數(shù)字與8相乘;將身份證號碼的第16位數(shù)字與4相乘;將身份證號碼的第17位數(shù)字與2相乘。
第二步:將第一步身份證號碼1~17位相乘的結(jié)果求和,全部加起來。
第三步:用第二步計算出來的結(jié)果除以11,這樣就會出現(xiàn)余數(shù)為0,余數(shù)為1,余數(shù)為2,余數(shù)為3,余數(shù)為4,余數(shù)為5,余數(shù)為6,余數(shù)為7,余數(shù)為8,余數(shù)為9,余數(shù)為10共11種可能性。
第四步:如果余數(shù)為0,那對應(yīng)的最后一位身份證的號碼為1;如果余數(shù)為1,那對應(yīng)的最后一位身份證的號碼為0;如果余數(shù)為2,那對應(yīng)的最后一位身份證的號碼為X;如果余數(shù)為3,那對應(yīng)的最后一位身份證的號碼為9;如果余數(shù)為4,那對應(yīng)的最后一位身份證的號碼為8;如果余數(shù)為5,那對應(yīng)的最后一位身份證的號碼為7;如果余數(shù)為6,那對應(yīng)的最后一位身份證的號碼為6;如果余數(shù)為7,那對應(yīng)的最后一位身份證的號碼為5;如果余數(shù)為8,那對應(yīng)的最后一位身份證的號碼為4;如果余數(shù)為9,那對應(yīng)的最后一位身份證的號碼為3;如果余數(shù)為10,那對應(yīng)的最后一位身份證的號碼為2。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
在TypeScript項目中搭配Axios封裝后端接口調(diào)用
這篇文章主要介紹了在TypeScript項目中搭配Axios封裝后端接口調(diào)用,本文記錄一下在?TypeScript?項目里封裝?axios?的過程,之前在開發(fā)?StarBlog-Admin?的時候已經(jīng)做了一次封裝,不過那時是JavaScript跟TypeScript還是有些區(qū)別的,需要的朋友可以參考下2024-01-01Javascript實現(xiàn)hashcode函數(shù)實現(xiàn)對象比較與原理說明
在JavaScript中,數(shù)值的比較是比較簡單的,使用相等(==)和全等(===)符號基本上可以解決大多數(shù)非對象的比較。但是相等(==)和全等(===)符號在對象 object 的比較上,就不能滿足所有的要求了2023-06-06js中使用DOM復制(克?。┲付ü?jié)點名數(shù)據(jù)到新的XML文件中的代碼
使用DOM復制(克?。┲付ü?jié)點名數(shù)據(jù)到新的XML文件中 ,用到三個類的相關(guān)知識點 : DOMDocument - DOMNodeList - DOMNode2011-07-07G6?TreeGraph樹圖節(jié)點懶加載使用場景示例
這篇文章主要為大家介紹了G6?TreeGraph樹圖節(jié)點懶加載使用場景示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-10-10CSS和JS標簽style屬性對照表(方便js開發(fā)的朋友)
CSS和JS標簽style屬性對照表(方便js開發(fā)的朋友),需要的朋友可以收藏下。2010-11-11