<?php
// 18位身份证校验码有效性检查
// idcard_checksum18('...');
function idcard_checksum18($idcard) {
    if (strlen($idcard) != 18) {
        return "您输入的身份证位数不对, 请您重新填写";
    }
    $aCity = array(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 => "国外");
    // 非法地区
    if (!array_key_exists(substr($idcard, 0, 2), $aCity)) {
        return "您输入的身份证地区非法, 请您重新填写!!!";
    }
    // 验证生日
    if (!checkdate(substr($idcard, 10, 2), substr($idcard, 12, 2), substr($idcard, 6, 4))) {
        return "您输入的身份证生日不对, 请您重新填写!!!";
    }
    // 校验码比对
    $idcard_base = substr($idcard, 0, 17);
    if (idcard_verify_number($idcard_base) != strtoupper(substr($idcard, 17, 1))) {
        return "您输入的身份证不对, 请您重新填写";
    } else {
        return '正确';
    }
}
function idcard_verify_number($idcard_base) {
    // 加权因子
    $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 = strtoupper($checksum % 11);
    $verify_number = $verify_number_list[$mod];
    return $verify_number;
}

  

;

最新文章

  1. 构建自己的PHP框架之自动加载类中详解spl_autoload_register()函数
  2. go的markdown解析库和session库
  3. ThinkPHP框架的部署
  4. 字符串匹配KMP算法
  5. [译]MongoDb生产环境注意事项
  6. 【英语】Bingo口语笔记(40) - [aʊ]的发音规则
  7. cocos2dx jsoncpp
  8. 《将博客搬至CSDN》 分类: 勉励自己 2014-09-05 14:29 43人阅读 评论(0) 收藏
  9. ubuntu下安装pyqt5
  10. docker 容器管理上
  11. Unity3D 导出的apk进行混淆和加固防止反编译
  12. 201521123011 《Java程序设计》 第三周学习总结
  13. Hbase对时,时差范围的确定
  14. 使用copy命令合并二进制文件
  15. 跨平台原生AR/VR应用研发引擎-NVisionXR开放内测
  16. 【EXCEL-折线图】百折不挠 | 用EXCEL画出与众不同的折线图(曲线图)
  17. DSAPI 字符串和文件转Md5字符串
  18. java socket / No buffer space available
  19. 【原创】大数据基础之Hive(5)性能调优Performance Tuning
  20. 论文笔记:ReNet: A Recurrent Neural Network Based Alternative to Convolutional Networks

热门文章

  1. ios学习的博客地址
  2. Python环境安装与配置
  3. NULL的学问
  4. MariaDB+Galera+Haproxy+Keepalived搭建集群
  5. sslstrip 中间人HTTP
  6. Debugging that latch timeout
  7. 都是 htmlspecialchars的错,解决 织梦cms dedecms 标题不能为空 不支持php5.3 php5.4 php5.5版本
  8. HDU1087上升子序列的最大和
  9. xampp添加 django支持
  10. ylb:SQL 表的高级查询-多表连接和子查询