> 웹 프론트엔드 > JS 튜토리얼 > ID번호_javascript 기술의 초정밀 JavaScript 검증의 구체적인 구현 방법

ID번호_javascript 기술의 초정밀 JavaScript 검증의 구체적인 구현 방법

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-05-16 15:31:42
원래의
1470명이 탐색했습니다.

프로그램을 작성하기 전에 먼저 ID 번호 구성을 이해해 봅시다.

ID번호는 2가지 종류가 있는데 기존 15자리, 새 18자리입니다.

신분증 15자리 인코딩 규칙 : dddddd yymmdd xx p

그 중 dddddd: 지역번호 yymmdd: 생년월일 xx: 연속코드, 판별불가 p: 성별, 홀수는 남성, 짝수는 여성

ID 카드 18비트 인코딩 규칙: dddddd yyyymmdd xxx y

그 중 dddddd: 지역번호 yyyymmdd: 생년월일 xxx: 순차코드, 알 수 없음, 홀수는 남성, 짝수는 여성 y: 코드 확인, 이 숫자의 값은 다음과 같이 얻을 수 있습니다. 처음 17자리 계산, 계산식 사용해야 할 상수:

프로그램 참조

18자리 숫자의 가중치는 (오른쪽에서 왼쪽으로) Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2,1 ] 검증 비트 Y = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3 , 2 ] 숫자 계산 공식 확인: Y_P = mod( ∑(Ai×Wi),11 )

i는 오른쪽에서 왼쪽으로 ID 카드 번호 2~18자리입니다. Y_P는 풋 체크 코드가 있는 체크 코드 배열의 위치입니다.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

var Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1 ]; // 加权因子

var ValideCode = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ];   // 身份证验证位值.10代表X

function IdCardValidate(idCard) {

 idCard = trim(idCard.replace(/ /g, ""));    //去掉字符串头尾空格     

 if (idCard.length == 15) {

  return isValidityBrithBy15IdCard(idCard);  //进行15位身份证的验证

 } else if (idCard.length == 18) {

  var a_idCard = idCard.split("");    // 得到身份证数组

  if(isValidityBrithBy18IdCard(idCard)&&isTrueValidateCodeBy18IdCard(a_idCard)){ //进行18位身份证的基本验证和第18位的验证

   return true;

  }else {

   return false;

  }

 } else {

  return false;

 }

}

/**

 * 判断身份证号码为18位时最后的验证位是否正确

 * @param a_idCard 身份证号码数组

 * @return

 */

function isTrueValidateCodeBy18IdCard(a_idCard) {

 var sum = 0;        // 声明加权求和变量

 if (a_idCard[17].toLowerCase() == 'x') {

  a_idCard[17] = 10;     // 将最后位为x的验证码替换为10方便后续操作

 }

 for ( var i = 0; i < 17; i++) {

  sum += Wi[i] * a_idCard[i];   // 加权求和

 }

 valCodePosition = sum % 11;    // 得到验证码所位置

 if (a_idCard[17] == ValideCode[valCodePosition]) {

  return true;

 } else {

  return false;

 }

}

/**

 * 验证18位数身份证号码中的生日是否是有效生日

 * @param idCard 18位书身份证字符串

 * @return

 */

function isValidityBrithBy18IdCard(idCard18){

 var year = idCard18.substring(6,10);

 var month = idCard18.substring(10,12);

 var day = idCard18.substring(12,14);

 var temp_date = new Date(year,parseFloat(month)-1,parseFloat(day));

 // 这里用getFullYear()获取年份,避免千年虫问题

 if(temp_date.getFullYear()!=parseFloat(year)

   ||temp_date.getMonth()!=parseFloat(month)-1

   ||temp_date.getDate()!=parseFloat(day)){

   return false;

 }else{

  return true;

 }

}

 /**

 * 验证15位数身份证号码中的生日是否是有效生日

 * @param idCard15 15位书身份证字符串

 * @return

 */

 function isValidityBrithBy15IdCard(idCard15){

  var year = idCard15.substring(6,8);

  var month = idCard15.substring(8,10);

  var day = idCard15.substring(10,12);

  var temp_date = new Date(year,parseFloat(month)-1,parseFloat(day));

  // 对于老身份证中的你年龄则不需考虑千年虫问题而使用getYear()方法

  if(temp_date.getYear()!=parseFloat(year)

    ||temp_date.getMonth()!=parseFloat(month)-1

    ||temp_date.getDate()!=parseFloat(day)){

    return false;

  }else{

   return true;

  }

 }

//去掉字符串头尾空格

function trim(str) {

 return str.replace(/(^\s*)|(\s*$)/g, "");

}

로그인 후 복사

주민번호로 성별 판별

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

/**

 * 通过身份证判断是男是女

 * @param idCard 15/18位身份证号码

 * @return 'female'-女、'male'-男

 */

function maleOrFemalByIdCard(idCard){

 idCard = trim(idCard.replace(/ /g, ""));  // 对身份证号码做处理。包括字符间有空格。

 if(idCard.length==15){

  if(idCard.substring(14,15)%2==0){

   return 'female';

  }else{

   return 'male';

  }

 }else if(idCard.length ==18){

  if(idCard.substring(14,17)%2==0){

   return 'female';

  }else{

   return 'male';

  }

 }else{

  return null;

 }

}

로그인 후 복사

위는 주민등록번호를 인증하기 위한 자바스크립트의 구체적인 구현 방법인데, 주민등록번호를 기준으로 성별을 인증할 수 있다는 점, 정말 놀랍지 않나요?

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿