TG创建小程序交互APP登录以及机器人信息

1、搜索 BotFather ,输入命令**/newbot** 创建机器人。

2、修改机器人信息**/mybots**

编辑名称 : 修改机器人名称

编辑关于: 修改关于 hayden yyds,修改以后打开机器人会出现在下图

编辑描述 : 机器人的描述

编辑描述图片 : 机器人的图片

编辑 Botpic : 点击以后发送图片,修改机器人的头像

编辑命令 : 编辑命令以后机器人对话框旁边会出现菜单,点击菜单可以出现我们编辑d

创建小程序:发送**/newapp**命令,选择关联小程序的机器人。 然后按照提示输入标题和描述。

完成以后会要我们 :现在上传演示 GIF 或发送/empty 以跳过此步骤。

我们跳过以后会让我们输入小程序外部链接的https的url。

完成以后:很好!现在请为您的 Web 应用选择一个简称:3-30 个字符,a-zA-Z0-9_。此简称将用于 t.me/TetrisHayDenBot/myapp 等 URL,并作为您的 Web 应用的唯一标识符。

完成以后返回给我们小程序的访问链接地址

将我们机器人菜单改为自定义按钮。

输入命令:/mybots ,点击 Menu Button

后续。。。。。。

到此我们完成了TG小程序配置

使用TG小程序交互我们web平台,进行登录操作

Telegram Web Apps在启动时会提供一个initDatahash参数,用于验证数据的完整性和来源。你可以使用这些参数来确保数据没有被篡改。

当我们获取到了initData以后可以做一个hash验签:

java 复制代码
package com.app.web;
import org.apache.commons.codec.binary.Hex;
import org.springframework.boot.SpringApplication;

import lombok.extern.slf4j.Slf4j;
import org.apache.commons.codec.digest.DigestUtils;
import org.apache.commons.codec.digest.HmacAlgorithms;
import org.apache.commons.codec.digest.HmacUtils;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.scheduling.annotation.EnableScheduling;

import javax.crypto.Mac;
import javax.crypto.spec.SecretKeySpec;
import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;
import java.nio.charset.StandardCharsets;
import java.util.Arrays;
import java.util.Map;
import java.util.stream.Collectors;

@Slf4j
@EnableScheduling
@SpringBootApplication
public class PeipeiApplication {

    public static void main(String[] args) {
        // initData和botToken
        String initData = "user=%7B%22id%22%3A5000109645%2C%22first_name%22%3A%22John%22%2C%22last_name%22%3A%22Zeng%22%2C%22language_code%22%3A%22zh-hans%22%2C%22allows_write_to_pm%22%3Atrue%7D&chat_instance=-1844952925335620055&chat_type=private&auth_date=1720850073&hash=79b805a0d61c577211e63fa8f2df178c87eff97ce162218fffc84faa2f84e900";
        //这个botToken就是我们创建机器人的token,创建的机器人和TG小程序绑定的
        String botToken = "5000906011:AAFqS3Ygb9eKYHJ8jJ_ply_3awwC79DrbeY";

        // 提取hash并解码其余的键值对
        Map<String, String> params = Arrays.stream(initData.split("&"))
            .map(param -> param.split("=", 2))
            .collect(Collectors.toMap(
                arr -> arr[0],
                arr -> {
                    try {
                        return URLDecoder.decode(arr[1], StandardCharsets.UTF_8.name());
                    } catch (UnsupportedEncodingException e) {
                        throw new RuntimeException(e);
                    }
                }
            ));

        // 提取并移除hash
        String hash = params.remove("hash");

        // 按键名排序其余的键值对
        String dataCheckString = params.entrySet().stream()
            .sorted(Map.Entry.comparingByKey())
            .map(entry -> entry.getKey() + "=" + entry.getValue())
            .collect(Collectors.joining("\n"));

        // 生成密钥
        byte[] secretKey = hmacSha256("WebAppData", botToken);

        // 生成HMAC-SHA256签名
        String computedHash = hmacSha256Hex(secretKey, dataCheckString);

        // 验证hash
        if (computedHash.equals(hash)) {
            System.out.println("Data is valid");
        } else {
            System.out.println("Data is invalid");
        }


    }



    private static byte[] hmacSha256(String key, String data) {
        try {
            Mac mac = Mac.getInstance("HmacSHA256");
            SecretKeySpec secretKeySpec = new SecretKeySpec(key.getBytes(StandardCharsets.UTF_8), "HmacSHA256");
            mac.init(secretKeySpec);
            return mac.doFinal(data.getBytes(StandardCharsets.UTF_8));
        } catch (Exception e) {
            throw new RuntimeException("Failed to calculate hmac-sha256", e);
        }
    }

    private static String hmacSha256Hex(byte[] key, String data) {
        try {
            Mac mac = Mac.getInstance("HmacSHA256");
            SecretKeySpec secretKeySpec = new SecretKeySpec(key, "HmacSHA256");
            mac.init(secretKeySpec);
            byte[] hashBytes = mac.doFinal(data.getBytes(StandardCharsets.UTF_8));
            return Hex.encodeHexString(hashBytes);
        } catch (Exception e) {
            throw new RuntimeException("Failed to calculate hmac-sha256 hex", e);
        }
    }
}
相关推荐
武子康2 小时前
AI-调查研究-104-具身智能 从模型训练到机器人部署:ONNX、TensorRT、Triton全流程推理优化详解
人工智能·gpt·ai·性能优化·机器人·tensorflow·具身智能
灵犀物润2 小时前
机器宠物建模的第一步:基础形体搭建(Blocking)
人工智能·机器人·宠物
yubinCloud3 小时前
【具身智能】RoboTwin 2.0:一个可扩展的、强领域随机化的数据生成器,用于双臂机器人操作
机器人
取酒鱼食--【余九】4 小时前
机器人学基础(一)【坐标系和位姿变换】
笔记·算法·机器人·开源·机器人运动学·机器人学基础
WWZZ20257 小时前
快速上手大模型:机器学习1
人工智能·深度学习·机器学习·计算机视觉·机器人·slam
沫儿笙8 小时前
川崎焊接机器人弧焊气体节约
人工智能·机器人
zskj_qcxjqr1 天前
七彩喜艾灸机器人:当千年中医智慧遇上现代科技
大数据·人工智能·科技·机器人
机器人行业研究员1 天前
让机器拥有“手感”:六维力传感器在医疗机器人领域的破局之路
机器人
唤醒手腕1 天前
唤醒手腕2025年最新钉钉开放平台钉钉机器人stream搭建部署详细教程(更新中)
机器人·钉钉
MarkHD1 天前
Dify从入门到精通 第16天 工作流进阶 - 分支与判断:构建智能路由客服机器人
人工智能·机器人