//驗證身份證是否有效 function validateIDCard($IDCard) { if (strlen($IDCard) == 18) { return check18IDCard($IDCard); } elseif ((strlen($IDCard) == 15)) { $IDCard = convertIDCard15to18($IDCard); return check18IDCard($IDCard); } else { return false; } } //計算身份證的最后一位驗證碼,根據國家標准GB 11643-1999 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位 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 . calcIDCardCode($IDCard); return $IDCard; } // 18位身份證校驗碼有效性檢查 function check18IDCard($IDCard) { if (strlen($IDCard) != 18) { return false; } $IDCardBody = substr($IDCard, 0, 17); //身份證主體 $IDCardCode = strtoupper(substr($IDCard, 17, 1)); //身份證最后一位的驗證碼 if (calcIDCardCode($IDCardBody) != $IDCardCode) { return false; } else { return true; } }
//使用方法 validateIDCard('身份證');
/** * 根據身份證判斷,是否滿足年齡條件 * @param type $IDCard 身份證 * @param type $minAge 最小年齡 */ function isMeetAgeByIDCard($IDCard, $minAge) { $ret = validateIDCard($IDCard); if ($ret === FALSE) { return FALSE; } if (strlen($IDCard) <= 15) { $IDCard = convertIDCard15to18($IDCard); } $year = date('Y') - substr($IDCard, 6, 4); $monthDay = date('md') - substr($IDCard, 10, 4); return ($year > $minAge || $year == $minAge && $monthDay > 0) ? TRUE : FALSE; }