如果要做到全国通用。估计有点问题。毕竟身份证是与个人的信息相互对应的。除非走专业的通道去校验!!如果只是简单判断身份证是否合法有效,可以参考一下身份证号码的构造结构。
首先看看身份证是怎么构造的:
首先:
1)地区代码:表示出生地,上图为北京市朝阳区
2)出生日期:不解释,只要合理就好
3)顺序号:最后一位为奇数表示性别男,偶数性别女
4)校验位:这是系统验证比较关键的一位,由前面17位通过公式计算得出,具体公式在此不做讨论,因为其结果为数字0~9或者字母X
这些条件都知道了。
就可以开始了:
//首先最迟判断身份证号码的位数(18)var CardNumber=""//待验证的身份证号码
var iscard=/^\d{17}([0-9]|X)$/
if(iscard.text(CardNumber)){
//验证身份证的"地区代码(前6位数字,这里需要搜集各个地区的代码...)"
if(这里校验地区代码){
if(这里校验出生日期){
//校验出生日期时,会牵扯到日历算法(计算某年的某月有多少天,防止用户随意输入大于31的日期)
//如果判断到这里了,就可以初步确定为"合法有效"的身份证号码了。
//因为“校验位”相对而言较复杂。如果楼主有意思。可以百度找资料。
}
}
}
百度不能出来吗?js实现身份证号码验证以下是根据身份证号码编码规则,使用JS对其进行有效性验证代码IdCard-Validate.js代码如下: /**
* 身份证15位编码规则:dddddd yymmdd xx p
* dddddd:地区码
* yymmdd: 出生年月日
* xx: 顺序类编码,无法确定
* p: 性别,奇数为男,偶数为女
* <p />
* 身份证18位编码规则:dddddd yyyymmdd xxx y
* dddddd:地区码
* yyyymmdd: 出生年月日
* xxx:顺序类编码,无法确定,奇数为男,偶数为女
* y: 校验码,该位数值可通过前17位计算获得
* <p />
* 18位号码加权因子为(从右到左) Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2,1 ]
* 验证位 Y = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ]
* 校验位计算公式:Y_P = mod( ∑(Ai×Wi),11 )
* i为身份证号码从右往左数的 2...18 位Y_P为脚丫校验码所在校验码数组位置
*
*/
var Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1 ]// 加权因子
var ValideCode = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ]// 身份证验证位值.10代表X
function IdCardValidate(idCard) {
idCard = trim(idCard.replace(/ /g, ""))
if (idCard.length == 15) {
return isValidityBrithBy15IdCard(idCard)
} else if (idCard.length == 18) {
var a_idCard = idCard.split("")// 得到身份证数组
if(isValidityBrithBy18IdCard(idCard)&&isTrueValidateCodeBy18IdCard(a_idCard)){
return true
}else {
return false
}
} else {
return false
}
}
/**
* 判断身份证号码为18位时最后的验证位是否正确
* @param a_idCard 身份证号码数组
* @return
*/
function isTrueValidateCodeBy18IdCard(a_idCard) {
var sum = 0// 声明加权求和变量
if (a_idCard[17].toLowerCase() == 'x') {
a_idCard[17] = 10// 将最后位为x的验证码替换为10方便后续操作
}
for ( var i = 0i <17i++) {
sum += Wi[i] * a_idCard[i]// 加权求和
}
valCodePosition = sum % 11// 得到验证码所位置
if (a_idCard[17] == ValideCode[valCodePosition]) {
return true
} else {
return false
}
}
/**
* 通过身份证判断是男是女
* @param idCard 15/18位身份证号码
* @return 'female'-女、'male'-男
*/
function maleOrFemalByIdCard(idCard){
idCard = trim(idCard.replace(/ /g, ""))// 对身份证号码做处理。包括字符间有空格。
if(idCard.length==15){
if(idCard.substring(14,15)%2==0){
return 'female'
}else{
return 'male'
}
}else if(idCard.length ==18){
if(idCard.substring(14,17)%2==0){
return 'female'
}else{
return 'male'
}
}else{
return null
}
// 可对传入字符直接当作数组来处理
// if(idCard.length==15){
// alert(idCard[13])
// if(idCard[13]%2==0){
// return 'female'
// }else{
// return 'male'
// }
// }else if(idCard.length==18){
// alert(idCard[16])
// if(idCard[16]%2==0){
// return 'female'
// }else{
// return 'male'
// }
// }else{
// return null
// }
}
/**
* 验证18位数身份证号码中的生日是否是有效生日
* @param idCard 18位书身份证字符串
* @return
*/
function isValidityBrithBy18IdCard(idCard18){
var year = idCard18.substring(6,10)
var month = idCard18.substring(10,12)
var day = idCard18.substring(12,14)
var temp_date = new Date(year,parseFloat(month)-1,parseFloat(day))
// 这里用getFullYear()获取年份,避免千年虫问题
if(temp_date.getFullYear()!=parseFloat(year)
||temp_date.getMonth()!=parseFloat(month)-1
||temp_date.getDate()!=parseFloat(day)){
return false
}else{
return true
}
}
/**
* 验证15位数身份证号码中的生日是否是有效生日
* @param idCard15 15位书身份证字符串
* @return
*/
function isValidityBrithBy15IdCard(idCard15){
var year = idCard15.substring(6,8)
var month = idCard15.substring(8,10)
var day = idCard15.substring(10,12)
var temp_date = new Date(year,parseFloat(month)-1,parseFloat(day))
// 对于老身份证中的你年龄则不需考虑千年虫问题而使用getYear()方法
if(temp_date.getYear()!=parseFloat(year)
||temp_date.getMonth()!=parseFloat(month)-1
||temp_date.getDate()!=parseFloat(day)){
return false
}else{
return true
}
}
//去掉字符串头尾空格
function trim(str) {
return str.replace(/(^\s*)|(\s*$)/g, "")
}
var s="11111111111111x"if (s.length==18){
if (s.substring(17).toUpperCase()=="X"){
if (isNaN(s.substr(0,17))){
alert("不是身份证号码")
}
else{
alert("是身份证号码")
}
}
else{
if (isNaN(s)){
alert("不是身份证号码")
}
else{
alert("是身份证号码")
}
}
}
else if(s.length==15 && !isNaN(s)){
alert("是身份证号码")
}
else{
alert("不是身份证号码")
}