利用身份证验证性别和获取生日

简介: 利用身份证验证性别和获取生日

通过身份证号码验证性别和获取生日的方法如下:

  1. 身份证号码的17位代表性别,奇数代表男性,偶数代表女性。
  2. 身份证号码的18位数字的7-10位代表出生年份,格式为YYYY
  3. 11-12位:出生月份,格式为MM
  4. 13-14位:出生日,格式为DD

根据这个规则,我们可以编写一个程序来验证性别和获取生日。

1.HTML部分

首先在页面上设置三个input输入框,分别放置身份证号码、性别和出生日期

<body>
    <!-- 身份证号码输入框 -->
    <input type="text" placeholder="请输入身份证号码" />
    <!-- 性别输入框 -->
    <input type="text" placeholder="输入身份证号码自动填充" />
    <!-- 出生日期选择框 -->
    <input type="date" placeholder="输入身份证号码自动填充" />
  </body>

然后给身份证输入框绑定oninput事件

<body>
    <!-- 身份证号码输入框 -->
    <input type="text" placeholder="请输入身份证号码" id="sfzh" oninput="sfzh()" />
    <!-- 性别输入框 -->
    <input type="text" placeholder="输入身份证号码自动填充" id="xingbie" />
    <!-- 出生日期选择框 -->
    <input type="date" placeholder="输入身份证号码自动填充" id="birthday" />
  </body>

2.JS部分

然后在JS中设置身份证的oninput事件

首先声明一个正则表达式

let reg = /^[1-9]\d{5}(19|20)\d{2}((0[1-9])|(1[0-2]))(([0-2][1-9])|10|20|30|31)\d{3}[0-9xX]$/

这个正则表达式可以匹配一个身份证号码,并验证其格式是否正确。

这个正则表达式中:

  • /^[1-9]\d{5}/ 匹配以 1-9 的数字开头的 6 位数字。
  • /((19|20)\d{2})/ 匹配 19 或 20 的 4 位年份。
  • /((0[1-9])|(1[0-2]))/ 匹配 01-12 的月份。
  • /(([0-2][1-9])|10|20|30|31)/ 匹配 01-31 的日期。
  • /d{3}/ 匹配 3 位顺序码。
  • /[0-9xX]/ 匹配校验码,可以是数字或 X。

然后再声明一个变量来获取到身份证输入框里的值

let idcard = document.getElementById('sfzh').value

判断输入框里的值是否为空,如果为空,则让性别和生日输入框的值也为空,同时出现提示文本

// 如果身份证输入框的值为空
        if (idcard == "") {
          // 显示身份证号、性别、出生日期提示框,并且生日和性别的输入框值为空
          $(".sfzh").text("请输入身份证号").css("display", "block");
          $("#xingbie").val("");
          $("#birthday").val("");
          $(".xingbie").show();
          $(".birthday").show();
        }

再判断如果身份证输入框里的值不符合正则表达式,则出现不符合格式提示,性别和生日输入框的值也为空

// 如果不符合正则表达式
        }else if(!reg.test(idcard)){
          // 显示身份证号、性别、出生日期提示框,并且生日和性别的输入框值为空
          $(".sfzh").text("证件号码格式不正确").css("display", "block");
          $("#xingbie").val("");
          $("#birthday").val("");
          $(".xingbie").show();
          $(".birthday").show();
        }

再判断输入框的值符合正则表达式时,隐藏提示文本,

// 如果符合正则表达式
        if (reg.test(idcard)) {
          // 隐藏身份证提示文本
          $(".sfzh").css("display", "none");
          // 隐藏性别提示文本
          $('.xingbie').hide();
          // 隐藏生日提示文本
          $('.birthday').hide();
        }

substring用来截取字符串的函数,起始索引(包括)和结束索引(不包括),有两个参数,从起始索引开始截取,直到但不包括结束索引。

声明一个变量等于身份证号从第16截取到第17位的字符串并转换成整形。

// 获取截取身份证号第16-17位的字符串
          let genderCode = parseInt(idcard.substring(16, 17));

声明一个变量等于身份证号从第6位截取到第10位的字符串

// 获取截取身份证号第6-10位的字符串
          let birthYear = idcard.substring(6, 10);

声明一个变量等于身份证号从第10位截取到第12位的字符串

// 获取截取身份证号第10-12位的字符串
          let birthMonth = idcard.substring(10, 12);

声明一个变量等于身份证号从第12位截取到第14位的字符串

// 获取截取身份证号第12-14位的字符串
          let birthDay = idcard.substring(12, 14);

控制台输出出生年月日

// 控制台输出出生日期
          console.log(birthYear, birthMonth, birthDay);

然后判断性别是男是女,这里采用的是取余的方法,用获取到的第16和第17组成的字符串%2,余数等于0则为女,否则为男。

gender = genderCode % 2 === 0 ? '女' : '男';

控制台输出这个值

然后让性别输入框的值等于这个值

// 将这个值加到性别输入框中
          $('#xingbie').val(gender);

最后让生日输入框的值等于出生年月日拼接的字符串,因为是date格式,中间用-连接

// 拼接出生年月日字符串
          document.getElementById('birthday').value = birthYear + "-" + birthMonth + "-" + birthDay;

3.整体代码

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title></title>
    <script src="./js/jquery-3.7.1.js"></script>
  </head>
  <body>
    <!-- 身份证号码输入框 -->
    <input type="text" placeholder="请输入身份证号码" id="sfzh" oninput="sfzh()" />
    <p class="sfzh" style="color: red; display: none;">请输入身份证号码</p>
    <!-- 性别输入框 -->
    <input type="text" placeholder="输入身份证号码自动填充" id="xingbie" />
    <p class="xingbie" style="color: red; display: none;">请输入身份证号码</p>
    <!-- 出生日期选择框 -->
    <input type="date" placeholder="输入身份证号码自动填充" id="birthday" />
    <p class="birthday" style="color: red; display: none;">请输入身份证号码</p>
    <script>
      // 身份证验证生日和性别
      function sfzh() {
        // 身份证验证正则表达式
        let reg = /^[1-9]\d{5}(19|20)\d{2}((0[1-9])|(1[0-2]))(([0-2][1-9])|10|20|30|31)\d{3}[0-9xX]$/
        // 获取到身份证输入框的值
        let idcard = document.getElementById('sfzh').value
        // 如果身份证输入框的值为空
        if (idcard == "") {
          // 显示身份证号、性别、出生日期提示框,并且生日和性别的输入框值为空
          $(".sfzh").text("请输入身份证号").css("display", "block");
          $("#xingbie").val("");
          $("#birthday").val("");
          $(".xingbie").show();
          $(".birthday").show();
          // 如果不符合正则表达式
        } else if (!reg.test(idcard)) {
          // 显示身份证号、性别、出生日期提示框,并且生日和性别的输入框值为空
          $(".sfzh").text("证件号码格式不正确").css("display", "block");
          $("#xingbie").val("");
          $("#birthday").val("");
          $(".xingbie").show();
          $(".birthday").show();
        }
        // 如果符合正则表达式
        if (reg.test(idcard)) {
          // 隐藏身份证提示文本
          $(".sfzh").css("display", "none");
          // 隐藏性别提示文本
          $('.xingbie').hide();
          // 隐藏生日提示文本
          $('.birthday').hide();
          // 获取截取身份证号第16-17位的字符串
          let genderCode = parseInt(idcard.substring(16, 17));
          // 获取截取身份证号第6-10位的字符串作为出生年份
          let birthYear = idcard.substring(6, 10);
          // 获取截取身份证号第10-12位的字符串作为出生月份
          let birthMonth = idcard.substring(10, 12);
          // 获取截取身份证号第12-14位的字符串作为出生日
          let birthDay = idcard.substring(12, 14);
          // 控制台输出出生日期
          console.log(birthYear, birthMonth, birthDay);
          // 用获取到的第16和第17组成的字符串%2,余数等于0则为女,否则为男
          gender = genderCode % 2 === 0 ? '女' : '男';
          // 控制台输出男女
          console.log(gender);
          // 将这个值加到性别输入框中
          $('#xingbie').val(gender);
          // 拼接出生年月日字符串
          document.getElementById('birthday').value = birthYear + "-" + birthMonth + "-" + birthDay;
        }
      }
    </script>
  </body>
</html>
相关文章
|
算法 程序员 应用服务中间件
推荐一款基于docker部署的个人免费笔记工具wiznote
推荐一款基于docker部署的个人免费笔记工具wiznote
推荐一款基于docker部署的个人免费笔记工具wiznote
|
Web App开发 应用服务中间件 PHP
|
8月前
|
JSON 算法 API
深度分析小红书城API接口,用Python脚本实现
小红书作为以UGC内容为核心的生活方式平台,其非官方API主要通过移动端抓包解析获得,涵盖内容推荐、搜索、笔记详情、用户信息和互动操作等功能。本文分析了其接口体系、认证机制及请求规范,并提供基于Python的调用框架,涉及签名生成、登录态管理与数据解析。需注意非官方接口存在稳定性与合规风险,使用时应遵守平台协议及法律法规。
|
9月前
|
消息中间件 NoSQL Redis
水镜 OMS 系统:全渠道电商中台的设计与实现
水镜OMS是全渠道电商中台,整合线上线下资源,统一管理订单、库存与营销。支持天猫、京东等10+平台接入,通过订单路由与库存共享,实现高效订单处理。系统采用SpringCloud Alibaba架构,结合Redis、Kafka、分库分表等技术,保障高并发下稳定运行,日均订单量超10万,峰值达5000TPS,助力企业提升运营效率与数字化能力。
488 0
|
数据采集 Web App开发 JavaScript
利用Selenium和XPath抓取JavaScript动态加载内容的实践案例
利用Selenium和XPath抓取JavaScript动态加载内容的实践案例
|
人工智能 自然语言处理 前端开发
Lobe Vidol:AI数字人交互平台,可与虚拟人和3D模型聊天互动
Lobe Vidol是一款开源的AI数字人交互平台,允许用户创建和互动自己的虚拟偶像。该平台提供流畅的对话体验、丰富的动作姿势库、优雅的用户界面设计以及多种技术支持,如文本到语音和语音到文本技术。Lobe Vidol适用于娱乐互动、在线教育、客户服务、品牌营销和社交媒体等多个应用场景。
974 7
Lobe Vidol:AI数字人交互平台,可与虚拟人和3D模型聊天互动
|
存储 算法 计算机视觉
OpenCV(四十二):Harris角点检测
OpenCV(四十二):Harris角点检测
630 0
|
搜索推荐 数据挖掘 BI
问卷调查软件精选,效能与易用双赢
本文推荐了四款问卷调查软件:ZohoSurvey、SurveyMonkey、GoogleForms和Typeform。ZohoSurvey功能全面,性价比高,适合中小企业和个人;SurveyMonkey功能强大,适合大型企业和科研机构;GoogleForms免费易用,适合预算有限的用户;Typeform注重用户体验,适合需要高参与率的调查。选择时需综合考虑功能、易用性和品牌信任度等因素。
502 2
|
JavaScript 前端开发
JavaScript的命名规则
JavaScript的命名规则
561 0
|
缓存 移动开发 JavaScript
WKWebView对网页和js,css,png等资源文件的缓存机制及如何刷新缓存
WKWebView对网页和js,css,png等资源文件的缓存机制及如何刷新缓存
1322 1