身份证号码前六位所代表的省,市,区, 以及地区编码下载


Posted in Javascript onApril 12, 2007

在我上一篇文章里面,讨论了如何验证15,18位身份证号码的合法性,并能取得一些简单的信息,
比如:身份,生日,性别等。

现在,可以取城市和地区了。

<script language="javascript">  
// 地区代码实在太大了,我这里只贴出 北京,上海,广州的代码,完整国内地区编码请下载附件  // Go_Rush(阿舜)  from http://ashun.cnblogs.com/  
var areaCode={  
    '11':'北京市','1101':'北京市市辖区','110101':'北京市东城区','110102':'北京市西城区'  
    ,'110103':'北京市崇文区','110104':'北京市宣武区','110105':'北京市朝阳区','110106':'北京市丰台区'  
    ,'110107':'北京市石景山区','110108':'北京市海淀区','110109':'北京市门头沟区','110111':'北京市房山区'  
    ,'1102':'北京市市辖县','110221':'北京市昌平县','110222':'北京市顺义县','110223':'北京市通县'  
    ,'110224':'北京市大兴县','110226':'北京市平谷县','110227':'北京市怀柔县','110228':'北京市密云县'  
    ,'110229':'北京市延庆县'  
    ,'12':'天津市','1201':'天津市市辖区','120101':'天津市和平区'  
    ,'120102':'天津市河东区','120103':'天津市河西区','120104':'天津市南开区','120105':'天津市河北区'  
    ,'120106':'天津市红桥区','120107':'天津市塘沽区','120108':'天津市汉沽区','120109':'天津市大港区'  
    ,'120110':'天津市东丽区','120111':'天津市西青区','120112':'天津市津南区','120113':'天津市北辰区'  
    ,'1202':'天津市市辖县','120221':'天津市宁河县','120222':'天津市武清县','120223':'天津市静海县'  
    ,'120224':'天津市宝坻县','120225':'天津市蓟县'  
    ,'31':'上海市'  
    ,'3101':'上海市市辖区','310101':'上海市黄浦区','310102':'上海市南市区','310103':'上海市卢湾区'  
    ,'310104':'上海市徐汇区','310105':'上海市长宁区','310106':'上海市静安区','310107':'上海市普陀区'  
    ,'310108':'上海市闸北区','310109':'上海市虹口区','310110':'上海市扬浦区','310112':'上海市闵行区'  
    ,'310113':'上海市宝山区','310114':'上海市嘉定区','310115':'上海市浦东新区','3102':'上海市市辖县'  
    ,'310225':'上海市南汇县','310226':'上海市奉贤县','310227':'上海市松江县','310228':'上海市金山县'  
    ,'310229':'上海市青浦县','310230':'上海市崇明县'          
    ,'44':'广东省','4401':'广东省广州市','440101':'广东省广州市市辖区'  
    ,'440102':'广东省广州市东山区','440103':'广东省广州市荔湾区'  
    ,'440104':'广东省广州市越秀区','440105':'广东省广州市海珠区'  
    ,'440106':'广东省广州市天河区','440107':'广东省广州市芳村区'  
    ,'440111':'广东省广州市白云区','440112':'广东省广州市黄埔区'  
    ,'440122':'广东省从花县','440181':'广东省番禺市','440182':'广东省花都市','440183':'广东省增城市'  
    ,'71':'台湾省','7100':'台湾','710000':'台湾省'      
    ,'72':'香港','7200':'香港特别行政区','720000':'香港特别行政区'  
    ,'73':'澳门','7300':'澳门特别行政区'  
    ,'91':'国外'  
}  

function checkId(pId){  
    var arrVerifyCode = [1,0,"x",9,8,7,6,5,4,3,2];  
    var Wi = [7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2];  
    var Checker = [1,9,8,7,6,5,4,3,2,1,1];  
    if(pId.length != 15 && pId.length != 18)    return "身份证号共有 15 码或18位";  
    var Ai=pId.length==18?pId.substring(0,17):pId.slice(0,6)+"19"+pId.slice(6,16);  
    if (!/^\d+$/.test(Ai)) return "身份证除最后一位外,必须为数字!";  
    var yyyy=Ai.slice(6,10),mm=Ai.slice(10,12)-1,dd=Ai.slice(12,14);  
    var d=new Date(yyyy,mm,dd),year=d.getFullYear(),mon=d.getMonth(),day=d.getDate(),now=new Date();  
    if (year!=yyyy || mon!=mm || day!=dd || d>now || now.getFullYear()-year>140) return "身份证输入错误!";  
    for(var i=0,ret=0;i<17;i++)  ret+=Ai.charAt(i)*Wi[i];      
    Ai+=arrVerifyCode[ret %=11];       
    return pId.length ==18 && pId.toLowerCase() != Ai?"身份证输入错误!":Ai;  
};  
function getInfo(id){               
    //根据身份证取 省份,生日,性别  Go_Rush(阿舜) from http://ashun.cnblogs.com/  
    id=checkId(id)  
    if (isNaN(id)) return "错误的身份证号码"      
    var id=String(id),sex=id.slice(14,17)%2?"男":"女"  
    prov=areaCode[id.slice(0,6)] || areaCode[id.slice(0,4)] || areaCode[id.slice(0,2)] || "未知地区"  
    var birthday=(new Date(id.slice(6,10),id.slice(10,12)-1,id.slice(12,14))).toLocaleDateString()   
    return [prov,birthday,sex]    
}  
var id="110102198006262301"   
alert(getInfo(id))   
</script>

下载(64kb) 
建议: 地区编码很大,900多行,90Kb大小,建议把他们放在数据库里面通过Ajax来取
Javascript 相关文章推荐
Packer 3.0 JS压缩及混淆工具 下载
May 03 Javascript
javascript 操作cookies及正确使用cookies的属性
Oct 15 Javascript
JavaScript中setInterval的用法总结
Nov 20 Javascript
jQuery动态显示和隐藏datagrid中的某一列的方法
Dec 11 Javascript
jQuery中next方法用法实例
Apr 24 Javascript
jquery悬浮提示框完整实例
Jan 13 Javascript
使用jquery.qrcode.min.js实现中文转化二维码
Mar 11 Javascript
Vue.js学习笔记之 helloworld
Aug 14 Javascript
自动化测试读写64位操作系统的注册表
Aug 15 Javascript
纯js实现的积木(div层)拖动功能示例
Jul 19 Javascript
小程序中this.setData的使用和注意事项
Aug 28 Javascript
详解element上传组件before-remove钩子问题解决
Apr 08 Javascript
对google个性主页的拖拽效果的js的完整注释[转]
Apr 10 #Javascript
FireFox中textNode分片的问题
Apr 10 #Javascript
AJAX架构之Dojo篇
Apr 10 #Javascript
Dojo之路:如何利用Dojo实现Drag and Drop效果
Apr 10 #Javascript
给moz-firefox下添加IE方法和属性
Apr 10 #Javascript
用javascript父窗口控制只弹出一个子窗口
Apr 10 #Javascript
javascript 控制弹出窗口
Apr 10 #Javascript
You might like
Javascript 异步加载详解(浏览器在javascript的加载方式)
2012/05/20 Javascript
你的 mixin 真的兼容 ECMAScript 5 吗?
2013/04/11 Javascript
网页广告中JS代码的信息监听示例
2014/04/02 Javascript
JavaScript将取代AppleScript?
2014/09/18 Javascript
Jquery中基本选择器用法实例详解
2015/05/18 Javascript
vue实现全选、反选功能
2020/11/17 Javascript
node koa2实现上传图片并且同步上传到七牛云存储
2017/07/31 Javascript
JavaScript实现各种排序的代码详解
2017/08/28 Javascript
Vue Prop属性功能与用法实例详解
2019/02/23 Javascript
优化Vue中date format的性能详解
2020/01/13 Javascript
JS实现多选框的操作
2020/06/24 Javascript
详解JavaScript原型与原型链
2020/11/16 Javascript
JavaScript实现打字游戏
2021/02/19 Javascript
python的几种开发工具介绍
2007/03/07 Python
Python编码时应该注意的几个情况
2013/03/04 Python
python线程池的实现实例
2013/11/18 Python
pandas or sql计算前后两行数据间的增值方法
2018/04/20 Python
Flask框架响应、调度方法和蓝图操作实例分析
2018/07/24 Python
python 获取毫秒数,计算调用时长的方法
2019/02/20 Python
python 处理微信对账单数据的实例代码
2019/07/19 Python
Java文件与类动手动脑实例详解
2019/11/10 Python
Python接口开发实现步骤详解
2020/04/26 Python
阿拉伯世界最大的电子卖场:Souq埃及
2016/08/01 全球购物
Volcom法国官网:美国冲浪滑板品牌
2017/05/25 全球购物
英国网络托管和域名领导者:Web Hosting UK
2017/10/15 全球购物
教师自荐信
2013/12/10 职场文书
高中竞选班长演讲稿
2014/04/24 职场文书
档案信息化建设方案
2014/05/16 职场文书
收款授权委托书
2014/10/02 职场文书
成本会计岗位职责
2015/02/03 职场文书
2015年清明节网上祭英烈留言寄语
2015/03/04 职场文书
幼儿园园长安全责任书
2015/05/08 职场文书
2015年街道除四害工作总结
2015/05/15 职场文书
新学期感想
2015/08/10 职场文书
pdf论文中python画的图Type 3 fonts字体不兼容的解决方案
2021/04/24 Python
Nginx+Tomcat负载均衡集群的实现示例
2021/10/24 Servers