当前位置: 首页 > 图文教程 > 网络编程 > PHP > 身份证方面的函数

PHP
工作笔记:配置MySQL为高可用集群 (1)
MySQL (C API)VC实例及代码下载 (1)(5)
MySQL (C API)VC实例及代码下载 (1)(4)
MySQL (C API)VC实例及代码下载 (1)(3)
MySQL (C API)VC实例及代码下载 (1)(2)
MySQL (C API)VC实例及代码下载 (1)
用JSP连接mysql数据库的方法 (1)(2)
用JSP连接mysql数据库的方法 (1)
MySQL数据库账户授权的相关管理解析 (1)(2)
MySQL数据库账户授权的相关管理解析 (1)
SAP MaxDB MySQL修补数据库严重漏洞
MySQL研发中心成立发布会会后访问整理 (1)(2)
MySQL研发中心成立发布会会后访问整理 (1)
MySQL中SQL-TEXT、DATE和SET数据类型
MySQL存在权限提升及安全限制绕过漏洞
MySQL 卸载的问题
windows下安装、卸载mysql服务
如何正确卸载MySQL
MySQL手册版本 5.0.20-MySQL优化(四) (1)(5)
MySQL手册版本 5.0.20-MySQL优化(四) (1)(4)

PHP 中的 身份证方面的函数


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 114 ::
收藏到网摘: n/a

写了几个身份证方面的函数,个人感觉挺有用的,特别是在网络问卷调查时,对个人信息里的身份证进行验证很有用,但是应者寥寥,还是收在自己的blog里算了。

//计算身份证校验码,根据国家标准GB11643-1999
functionidcard_verify_number($idcard_base){
if(strlen($idcard_base)!=17){returnfalse;}

//加权因子
$factor=array(7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2);

//校验码对应值
$verify_number_list=array('1','0','X','9','8','7','6','5','4','3','2');

$checksum=0;
for($i=0;$i<strlen($idcard_base);$i++){
$checksum+=substr($idcard_base,$i,1)*$factor[$i];
}

$mod=$checksum%11;
$verify_number=$verify_number_list[$mod];

return$verify_number;

}

//将15位身份证升级到18位
functionidcard_15to18($idcard){
if(strlen($idcard)!=15){
returnfalse;
}else{
//如果身份证顺序码是996997998999,这些是为百岁以上老人的特殊编码
if(array_search(substr($idcard,12,3),array('996','997','998','999'))!==false){
$idcard=substr($idcard,0,6).'18'.substr($idcard,6,9);
}else{
$idcard=substr($idcard,0,6).'19'.substr($idcard,6,9);
}
}

$idcard=$idcard.idcard_verify_number($idcard);

return$idcard;
}

//18位身份证校验码有效性检查
functionidcard_checksum18($idcard){
if(strlen($idcard)!=18){returnfalse;}
$idcard_base=substr($idcard,0,17);

if(idcard_verify_number($idcard_base)!=strtoupper(substr($idcard,17,1))){
returnfalse;
}else{
returntrue;
}
}
?>

其中的$idcard_base是指身份证中的本位码,本位码是18位身份证里才有的,也就是18位身份证的前17位,最后一位称为校验码
一般在使用的时候不用直接调用idcard_verify_number(),平时的应用大多是使用后两个函数
这些函数都没有关心身份证字符串的格式问题,在调用前自行进行格式检查