0

0

如何在 PHP 中实现 Aadhaar 纸质离线 e-KYC 的手机号哈希生成

花韻仙語

花韻仙語

发布时间:2026-03-11 21:07:03

|

425人浏览过

|

来源于php中文网

原创

如何在 PHP 中实现 Aadhaar 纸质离线 e-KYC 的手机号哈希生成

本文详解 aadhaar 纸质离线 e-kyc(paperless offline e-kyc)中手机号字段的标准化哈希生成逻辑,基于 uidai 官方规范,使用 php 实现多层 sha-256 哈希计算,并说明关键参数(aadhaar 末位数字、共享短语)对迭代次数的决定性影响。

本文详解 aadhaar 纸质离线 e-kyc(paperless offline e-kyc)中手机号字段的标准化哈希生成逻辑,基于 uidai 官方规范,使用 php 实现多层 sha-256 哈希计算,并说明关键参数(aadhaar 末位数字、共享短语)对迭代次数的决定性影响。

在 Aadhaar 纸质离线 e-KYC XML 文件中,用户手机号并非明文存储,而是以确定性哈希值形式嵌入 节点的 m= 属性中(例如:m="a1b2c3...")。该哈希严格遵循 UIDAI 官方定义的嵌套哈希规则,其核心逻辑是:

对 MobileNumber + SharePhrase 字符串执行 n 次 SHA-256 迭代哈希,其中 n 等于 Aadhaar 号码最后一位数字;若末位为 0,则 n = 1(即仅执行一次 SHA-256)。

⚠️ 注意:UIDAI 规范明确指出——“number of times last digit of Aadhaar number”,即仅取末位数字作为迭代次数(非末4位),且 0 视为 1 次(非 0 次),这是开发者最易出错的关键点。

一帧秒创
一帧秒创

基于秒创AIGC引擎的AI内容生成平台,图文转视频,无需剪辑,一键成片,零门槛创作视频。

下载

✅ 正确的 PHP 实现代码

以下函数完整封装该逻辑,支持任意长度的手机号、任意 SharePhrase(即 XML 解密密码/Passcode)及任意 Aadhaar 末位数字:

立即学习PHP免费学习笔记(深入)”;

<?php
function generateMobileHash(string $mobile, string $sharePhrase, int $aadhaarLastDigit): string
{
    // UIDAI 规则:末位为 0 时,迭代次数为 1
    $iterations = ($aadhaarLastDigit === 0) ? 1 : $aadhaarLastDigit;

    $input = $mobile . $sharePhrase;
    $hash = $input;

    // 执行 n 层 SHA-256 哈希(每轮输入为上一轮输出)
    for ($i = 0; $i < $iterations; $i++) {
        $hash = hash('sha256', $hash);
    }

    return $hash;
}

// 示例:Aadhaar 末4位为 3632 → 末位 = 2 → 迭代 2 次
$mobile = '1234567890';
$sharePhrase = 'Lock@487'; // 注意:此即 XML 解密口令(Passcode),非用户设置的 PIN
$aadhaarLastDigit = 2;

$expectedHash = generateMobileHash($mobile, $sharePhrase, $aadhaarLastDigit);
echo "Mobile Hash: " . $expectedHash . "\n";
// 输出:e.g. 8a9b...(64字符小写十六进制)
?>

? 验证与调试要点

  • 输入一致性:确保 $mobile 不含空格、+91 前缀或括号(如 '1234567890',非 '+91 1234567890');
  • SharePhrase 大小写敏感:'Lock@487' ≠ 'lock@487',必须与用户提供的离线 KYC ZIP 解压密码完全一致;
  • Aadhaar 末位提取方式:从 Ref ID(XML 中 字段的后4位)取最后一位数字,不是整个 Aadhaar 号
  • 哈希输出格式:始终为 64 字符小写十六进制字符串(hash() 默认行为),无需 base64 或其他编码;
  • 安全对比:校验时应使用 hash_equals() 防止时序攻击:
    if (hash_equals($xmlMValue, $generatedHash)) {
        echo "✅ Mobile hash verification passed.";
    }

? 总结

Aadhaar 离线 e-KYC 的手机号哈希本质是一个可控迭代的确定性摘要算法,其安全性不依赖于密码学强度提升,而在于绑定唯一 Aadhaar 末位与共享短语,防止哈希被预计算复用。PHP 开发者只需严格遵循 n = max(1, last_digit) 迭代规则,即可准确生成或验证 m= 值。务必以 UIDAI 官方文档为唯一权威依据(uidai.gov.in/ecosystem/authentication-devices-documents/about-aadhaar-paperless-offline-e-kyc.html),避免自行扩展或简化逻辑。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1946

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2119

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1168

2024.11.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1566

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

649

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1228

2024.03.22

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.3万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号