Skip to content

初始数据

应用启动参数 列表中,初始化数据位于 tgWebAppData 参数中。 这是一组数据,主要与启动 小程序的特定用户有关。

init 数据的一个显著特点是,它可用作身份验证或 授权因素。 因此,不要忘记应用程序 和初始数据的安全性。

检索

要提取初始数据,开发人员可以使用 @telegram-apps/sdk 中的 retrieveLaunchParams 函数。

typescript
import { retrieveLaunchParams } from '@telegram-apps/sdk';

const { initDataRaw, initData } = retrieveLaunchParams();

授权和认证

初始数据的一个显著特点是,它可用作身份验证或 授权因素。 初始化数据的一个特点是可以用作授权或 身份验证的因素。 事实上,原生 Telegram 应用程序生成的数据会使用 Telegram 机器人的密钥对 进行签名,然后生成的签名会放在 参数本身旁边。

因此,知道了 Telegram 机器人的秘钥,开发者就有机会验证 参数的签名,确保这些参数确实是发给指定用户的。

此外,签名验证操作足够快,不需要大量服务器 资源。

TIP

你可以在这篇文章中找到使用不同编程语言的示例。

发送至服务器

为了在服务器上对用户进行授权,开发者需要传输启动小程序时指定的初始化 数据。 开发人员可以在每次向服务器发送请求时传输这些信息,然后在服务器端进行签名验证 。 为了简化自己的工作,开发者可以在每次请求服务器时传递它们,之后在服务器端进行签名验证。

下面是开发人员向服务器发送初始数据的方法:

typescript
import { retrieveLaunchParams } from '@telegram-apps/sdk';

const { initDataRaw } = retrieveLaunchParams();

fetch('https://example.com/api', {
  method: 'POST',
  headers: {
    Authorization: `tma ${initDataRaw}`
  },
});

反过来,服务器端必须执行以下操作:

  1. 获取 Authorization(授权)标头的值;
  2. 检查其第一部分是否等于 tma
  3. 获取初始数据并 验证 其签名。

如果该算法成功,应用程序的服务器部分就可以信任传输的 初始数据。

验证

初始数据验证是客户端和服务器之间通信 中最重要的部分之一。 它的有效性保证了初始数据可以被信任 并在未来的代码执行中使用。

要知道,初始数据是以查询参数列表的形式呈现的,要验证 ,开发人员应遵循以下步骤:

  1. 遍历所有键值对,并以 格式创建字符串值数组 {key}={value}hash 应排除在外,但要记下来。 代表初始数据符号,将用于验证过程的最后一步。 hash 应排除在外,但要记下来。 它代表初始数据符号,将用于验证过程的最后一步。
  2. 将计算出的数组按字母顺序排序。
  3. 使用密钥 WebAppData 创建 HMAC-SHA256,并将其应用于绑定到小程序的 Telegram Bot 令牌。
  4. 使用第 3 步的结果作为密钥创建 HMAC-SHA256。\ 可选。 聊天照片链接。 照片可以是.jpeg.svg格式。 只有通过附件 菜单打开的小程序才会返回。
  5. 将第 1 步收到的 hash 值与第 4 步的结果进行比较。
  6. 如果这些值相等,则传递的初始数据是可信的。

TIP

在实际应用中,建议使用其他机制来验证 初始化数据。 例如,添加到期日期。 在实际应用中,建议使用其他机制来验证 初始化数据。 例如,添加到期日期。 这种检查可以通过 auth_date参数来实现,该参数负责参数创建的日期。 该 解决方案可在初始化数据被盗的情况下,防止 攻击者不断使用这些数据。 该 解决方案可在初始化数据被盗的情况下,防止 攻击者不断使用这些数据。

TIP

为避免初始数据验证过程中可能出现的问题,我们建议使用 成熟且经过 测试的软件包:

示例

让我们想象一下,我们有这样的输入:

Telegram Bot token:
5768337691:AAGDAe6rjxu1cUgxK4BizYi--Utc3J9v5AU

Init data:
user=%7B%22id%22%3A279058397%2C%22first_name%22%3A%22Vladislav%22%2C%22last_name%22%3A%22Kibenko%22%2C%22username%22%3A%22vdkfrost%22%2C%22language_code%22%3A%22en%22%2C%22is_premium%22%3Atrue%2C%22allows_write_to_pm%22%3Atrue%7D
&chat_instance=-3788475317572404878
&chat_type=private
&auth_date=1709144340
&hash=371697738012ebd26a111ace4aff23ee265596cd64026c8c3677956a85ca1827

完成第 1 步和第 2 步后,我们将收到以下数据:

js
// Sorted pairs.
[
  'auth_date=1709144340',
  'chat_instance=-3788475317572404878',
  'chat_type=private',
  'user={"id":279058397,"first_name":"Vladislav","last_name":"Kibenko","username":"vdkfrost","language_code":"en","is_premium":true,"allows_write_to_pm":true}'
]

// Hash.
'371697738012ebd26a111ace4aff23ee265596cd64026c8c3677956a85ca1827'

然后,创建第 3 步所需的 HMAC-SHA256。它应基于 WebAppData 字面字符串值和 Telegram Bot token。

HMAC-SHA256(
  "WebAppData", 
  "5768337691:AAGDAe6rjxu1cUgxK4BizYi--Utc3J9v5AU"
) = "aa492a44bdf019c759defb1698c1d77690189973945491a756051cdc1207a449"

最后,让我们使用第 2 步收到的排序对和第 3 步的值来计算初始数据符号:

joined_pairs =
  "auth_date=1709144340
  chat_instance=-3788475317572404878
  chat_type=private
  user={\"id\":279058397,\"first_name\":\"Vladislav\",\"last_name\":\"Kibenko\",\"username\":\"vdkfrost\",\"language_code\":\"en\",\"is_premium\":true,\"allows_write_to_pm\":true}"

HMAC-SHA256(
  "aa492a44bdf019c759defb1698c1d77690189973945491a756051cdc1207a449",
  joined_pairs,
) = "371697738012ebd26a111ace4aff23ee265596cd64026c8c3677956a85ca1827"

现在,将最后收到的结果与第 1 步中的 hash 值进行比较,我们可以看到它们是相等的。这意味着,我们可以信任传递的 init 数据。

参数列表

本节提供初始化数据所用参数的完整列表。

参数类型说明
auth_datenumber初始化数据的创建日期。是一个数字,代表 Unix 时间戳。
can_send_afternumber可选。通过 answerWebAppQuery 方法发送消息的秒数。
chatChat可选。包含通过附件菜单启动机器人的聊天数据的对象。返回超级群组、频道和群组聊天 - 仅适用于通过附件菜单启动的小程序。
chat_typestring可选。打开小程序的聊天类型。值:
  • sender
  • private
  • group
  • supergroup
  • channel
仅返回通过直接链接打开的申请表。
chat_instancestring可选。全局标识符,表示打开小程序的聊天窗口。仅返回通过直接链接打开的申请表。
hashstring初始化数据签名。
query_idstring可选。小程序的唯一会话 ID。在通过answerWebAppQuery方法发送信息的过程中使用。
receiverUser可选。一个对象,包含当前用户在聊天时的聊天伙伴数据,机器人是通过附件菜单启动的。仅对私人聊天和通过附件菜单启动的小程序返回。
start_paramstring可选。链接中指定的startattachstartapp查询参数的值。只有通过附件菜单打开的小程序才会返回。
userUser可选。包含当前用户信息的对象。

其他类型

Chat

描述聊天信息。

属性类型说明
idnumber唯一聊天 ID。
typestring Chat type. 值:
  • group
  • supergroup
  • channel
titlestring聊天标题。
photo_urlstring可选。聊天照片链接。照片可以是.jpeg.svg格式。只有通过附件菜单打开的小程序才会返回。
usernamestring可选。聊天用户登录。

User

描述用户或机器人的信息。

属性类型说明
added_to_attachment_menuboolean可选可选。 如果该用户在附件菜单中添加了机器人,则为 True。
allows_write_to_pmboolean可选可选。 如果该用户允许机器人向其发送信息,则为 "true"。
is_premiumboolean可选可选。 用户是否购买了 Telegram Premium。
first_namestring机器人或用户名。
idnumber机器人或用户 ID。
is_botboolean可选。 用户是否是机器人
last_namestring可选可选。 用户姓氏。
language_codestring可选可选IETF 用户语言。
photo_urlstring可选。 用户或机器人照片的链接。 照片的格式可以是.jpeg.svg。 只有通过附件菜单打开的小程序才会返回。
usernamestring可选可选。 机器人或用户的登录。

Released under the MIT License.