Home  >  Article  >  Backend Development  >  PHP 验证身份证号的函数

PHP 验证身份证号的函数

WBOY
WBOYOriginal
2016-07-25 08:55:021080browse
  1. function validation_filter_id_card($id_card){
  2. if(strlen($id_card)==18){
  3. return idcard_checksum18($id_card);
  4. }elseif((strlen($id_card)==15)){
  5. $id_card=idcard_15to18($id_card);
  6. return idcard_checksum18($id_card);
  7. }else{
  8. return false;
  9. }
  10. }
  11. // 计算身份证校验码,根据国家标准GB 11643-1999
  12. function idcard_verify_number($idcard_base){
  13. if(strlen($idcard_base)!=17){
  14. return false;
  15. }
  16. //加权因子
  17. $factor=array(7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2);
  18. //校验码对应值
  19. $verify_number_list=array('1','0','X','9','8','7','6','5','4','3','2');
  20. $checksum=0;
  21. for($i=0;$i $checksum += substr($idcard_base,$i,1) * $factor[$i];
  22. }
  23. $mod=$checksum % 11;
  24. $verify_number=$verify_number_list[$mod];
  25. return $verify_number;
  26. }
  27. // 将15位身份证升级到18位
  28. function idcard_15to18($idcard){
  29. if(strlen($idcard)!=15){
  30. return false;
  31. }else{
  32. // 如果身份证顺序码是996 997 998 999,这些是为百岁以上老人的特殊编码
  33. if(array_search(substr($idcard,12,3),array('996','997','998','999')) !== false){
  34. $idcard=substr($idcard,0,6).'18'.substr($idcard,6,9);
  35. }else{
  36. $idcard=substr($idcard,0,6).'19'.substr($idcard,6,9);
  37. }
  38. }
  39. $idcard=$idcard.idcard_verify_number($idcard);
  40. return $idcard;
  41. }
  42. // 18位身份证校验码有效性检查
  43. function idcard_checksum18($idcard){
  44. if(strlen($idcard)!=18){
  45. return false;
  46. }
  47. $idcard_base=substr($idcard,0,17);
  48. if(idcard_verify_number($idcard_base)!=strtoupper(substr($idcard,17,1))){
  49. return false;
  50. }else{
  51. return true;
  52. }
  53. }
复制代码

调用方法:

  1. validation_filter_id_card('身份证号码');
复制代码


Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact [email protected]