欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【身份证方面的函数】,下面是详细的分享!
身份证方面的函数
写了几个身份证方面的函数,个人感觉挺有用的,特别是在网络问卷调查时,对个人信息里的身份证进行验证很有用,但是应者寥寥,还是收在自己的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_verify_number(),平时的应用大多是使用后两个函数
这些函数都没有关心身份证字符串的格式问题,在调用前自行进行格式检查
以上所分享的是关于身份证方面的函数,下面是编辑为你推荐的有价值的用户互动:
相关问题:excel里怎样用函数选出身份证中不是18位数的号码
答:你是要判断一列单元格中身份证号位数有错的行,按说15位和18位都是正确的 假证号写在B列,从B1单元格开始的证号,则可在C1单元格写入公式 =IF(OR(LEN(B1)={15,18}),"","证号位数不对") 下拉填充公式 如果是只判断是否为18证号,则公式为 =IF(LEN(B1)... >>详细
相关问题:excel中根据给定人身份证号码求性别的函数
答:首先看一下原始数据,本例以18位身份证号为例。A列是18位的身份证号,需要在B列和C列分别提计算出年龄和性别信息。 18位身份证号从第7位开始的8位数字代表出生日期。出生的年份是从第7位开始的4位数字,因此,我们可以用MID函数将出生年份提取出... >>详细
相关问题:求在Excel中通过身份证号码提取性别的函数
答:如果身份证号码在A2单元格,那么在性别单元格输入以下公式 =IF(MOD(MID(A2,17,1),2)=0,"男","女") >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
