php 身份证验证类
PHP 验证 身份证
2023-09-14 08:56:56 时间
<?php //身份证件验证 class chekcIdcard { /** * 验证身份证是否有效 * * @param $IDCard * @return bool */ public static function validateIDCard($IDCard) { if (strlen($IDCard) == 18) { return self::check18IDCard($IDCard); } elseif ((strlen($IDCard) == 15)) { $IDCard = self::convertIDCard15to18($IDCard); return self::check18IDCard($IDCard); } else { return false; } } //计算身份证的最后一位验证码,根据国家标准GB 11643-1999 private static function calcIDCardCode($IDCardBody) { if (strlen($IDCardBody) != 17) { return false; } //加权因子 $factor = array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2); //校验码对应值 $code = array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'); $checksum = 0; for ($i = 0; $i < strlen($IDCardBody); $i++) { $checksum += substr($IDCardBody, $i, 1) * $factor[$i]; } return $code[$checksum % 11]; } // 将15位身份证升级到18位 private static function convertIDCard15to18($IDCard) { if (strlen($IDCard) != 15) { return false; } else { // 如果身份证顺序码是996 997 998 999,这些是为百岁以上老人的特殊编码 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 . self::calcIDCardCode($IDCard); return $IDCard; } // 18位身份证校验码有效性检查 private static function check18IDCard($IDCard) { if (strlen($IDCard) != 18) { return false; } $IDCardBody = substr($IDCard, 0, 17); //身份证主体 $IDCardCode = strtoupper(substr($IDCard, 17, 1)); //身份证最后一位的验证码 if (self::calcIDCardCode($IDCardBody) != $IDCardCode) { return false; } else { return true; } } }
使用方法
$chekcIdcard = new chekcIdcard(); var_dump($chekcIdcard->validateIDCard('110101199003072033')); echo '<br>'; var_dump($chekcIdcard->validateIDCard('110101199003072031'));
相关文章
- php://input allow_url_include,php allow_url_include的应用和解释_PHP教程
- php allow_url_include,allow_url_include的应用和解释
- 【说站】php消息队列的介绍
- 用PHP获取客户端真实IP的函数代码分享
- [PHP] PHP的脚本执行详解编程语言
- MySQL指令的灵活执行:PHP的强大助力(php执行mysql)
- PHP下载文件
- 数据库使用PHP框架管理Oracle数据库(php框架oracle)
- 的数据库连接PHP与Oracle数据库的连接技术指南(php与oracle)
- MySQL验证:PHP实现细节(php验证mysql)
- PHP轻松构建高效应用——Redis实战指南(redis使用php)
- MacOS上配置PHP环境的指南(Macos配置php)
- 学习PHP提升Linux技能(php学linux)
- PHP连接MySQL数据库失败的解决方案(php连接mysql失败)
- 利用Redis和PHP实现高效数据处理(redis php 使用)
- 使用PHP连接MSSQL数据库的实例示范(php连接mssql例子)
- PHP如何开启MSSQL支持?(php怎么开启mssql)
- 使用PHP封装MSSQL管理数据库(php封装mssql)
- PHP编写的MSSQL查询:实现可能性无限(php写mssql查询)
- PHP与MSSQL的融合——开启新的编程前程(php mssql 空白)
- MySQL与PHP结合抵御注入攻击(mysql php 注入)
- PHP与MySQL实现三表关联操作(mysql三表关联pHP)
- PHP图片上传类带图片显示
- PHP生成excel时单元格内换行问题的解决方法
- php数据结构与算法(PHP描述)快速排序quicksort
- 关于尝试开发PHP的MYSQL扩展的使用
- php读取富文本的时p标签会出现红线是怎么回事
- SELinux导致PHP连接MySQL异常Can'tconnecttoMySQLserver的解决方法