身份证号码验证算法(php和js实现)
2024-09-01 16:01:54
原文:http://blog.chinaunix.net/xmlrpc.php?r=blog/article&uid=21126994&id=3938244
http://www.jb51.net/article/57627.htm
从网上找的,已经测试通过,备忘
js:
//身份证号合法性验证
//支持15位和18位身份证号
//支持地址编码、出生日期、校验位验证
function IdentityCodeValid(code) { var city={
11:"北京",12:"天津",13:"河北",14:"山西",15:"内蒙古", 21:"辽宁",
22:"吉林",23:"黑龙江 ",31:"上海",32:"江苏",33:"浙江", 34:"安徽",
35:"福建",36:"江西",37:"山东",41:"河南",42:"湖北 ", 43:"湖南",
44:"广东",45:"广西",46:"海南",50:"重庆",51:"四川", 52:"贵州",
53:"云南",54:"西藏 ",61:"陕西",62:"甘肃",63:"青海", 64:"宁夏",
65:"新疆",71:"台湾",81:"香港",82:"澳门",91:"国外 "};
var tip = "";
var pass= true; if(!code || !/^\d{6}(18|19|20)?\d{2}(0[1-9]|1[12])(0[1-9]|[12]\d|3[01])\d{3}(\d|X)$/i.test(code)){
tip = "身份证号格式错误";
pass = false;
} else if(!city[code.substr(0,2)]){
tip = "地址编码错误";
pass = false;
}
else{
//18位身份证需要验证最后一位校验位
if(code.length == 18){
code = code.split('');
//∑(ai×Wi)(mod 11)
//加权因子
var factor = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ];
//校验位
var parity = [ 1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2 ];
var sum = 0;
var ai = 0;
var wi = 0;
for (var i = 0; i < 17; i++)
{
ai = code[i];
wi = factor[i];
sum += ai * wi;
}
var last = parity[sum % 11];
if(parity[sum % 11] != code[17]){
tip = "校验位错误";
pass =false;
}
}
}
if(!pass) alert(tip);
return pass;
}
var c = '130981199312253466';
var res= IdentityCodeValid(c);
php:
function checkId($id) { $len = strlen($id);
if($len != 18) {
return 0;
} $a=str_split($id,1);
$w=array(7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2); $c=array(1,0,'X',9,8,7,6,5,4,3,2); $sum = 0;
for($i=0;$i<17;$i++){
$sum= $sum + $a[$i]*$w[$i];
}
$r=$sum%11;
$res=$c[$r];
//echo "校验位是: ".$res;
if ($res == $a[17]) {
return 1;
} else {
return 0;
} }
最新文章
- System.Linq.Dynamic的使用
- c# 多语言实现 与 InitializeCulture
- [JS]setInterval,setTimeout的使用以及伪随机数
- 浅析ado.net获取数据库元数据信息 DeriveParameters
- win7 cmd命令行窗口 宽度无法变大 自由调整大小
- SAXParser 解析器和 XMLEventReader(读取XML文档)
- openflow tutorial 开始openflow的学习(一)
- 关于js中window.location.href,location.href,parent.location.href,top.location.href的用法与区别(跳出iframe方法)
- thiscall仅仅应用于“C++”成员函数(this指针存放于CX寄存器,参数从右到左压)
- Chapter 1 First Sight——15
- 控制器没有足够的带宽可利用为USB大容量存储设备的解决方法
- 单链表数据结构 - java简单实现
- C++ 提取网页内容系列之一
- linux下的C语言程序设计
- [UE4]混合动画以及Try Get Pawn Owner、Get Velocity、VectorLength的使用
- 【LeetCode题解】237_删除链表中的节点
- 软工之404 Note Found队选题报告
- win64位操作系统下安装pl/sql developer 并登录连接到oracle12c
- Netty私有协议栈 读书笔记
- C++开学第一次作业(5.4)