gpt4 book ai didi

php - 无法为机器人用户验证 Telegram Web App

转载 作者:行者123 更新时间:2023-12-05 01:51:54 29 4
gpt4 key购买 nike

我尝试为机器人的 Telegram 网络应用程序做用户验证脚本。我不知道如何解决它。哈希和编码字符串相似但不相同。

Telegram 文章(文档):https://core.telegram.org/bots/webapps#validating-data-received-via-the-web-app


$bot_token="5368097647:AAFU8jBho71pglrzDeGw6LawrVuMmxaxpEQ";
$data_check_string=$_POST['a'];
$data_check_string=explode("&", urldecode($data_check_string));

foreach ($data_check_string as &$arrvalue) {
$hash="";
if (substr($arrvalue, 0, 4)=='hash'){
$hash=explode("=", $arrvalue)[1];
break;
}
}

sort($data_check_string);

$data_check_string=implode('\\n', $data_check_string);
$secret_key = $sig = hash_hmac('sha256', $bot_token, "WebAppData");

if (hash_hmac('sha256', $data_check_string, $secret_key) == $hash) {
print("fromtg");
}
else{
print("notg");
}

?>

最佳答案

  • 使用 implode("\n", $data_check_arr); 加入数组
  • hash_mac 函数中将第四个参数设置为 TRUE(输出原始二进制数据);
  • 在比较两个哈希值之前,应用bin2hex函数计算哈希值,将二进制数据转换为十六进制表示;

这是我的代码:

<?php

$data_check_arr = explode('&', rawurldecode($data_check_string));
$needle = 'hash=';
$check_hash = FALSE;
foreach( $data_check_arr AS &$val ){
if( substr( $val, 0, strlen($needle) ) === $needle ){
$check_hash = substr_replace( $val, '', 0, strlen($needle) );
$val = NULL;
}
}

// if( $check_hash === FALSE ) return FALSE;
$data_check_arr = array_filter($data_check_arr);
sort($data_check_arr);

$data_check_string = implode("\n", $data_check_arr);
$secret_key = hash_hmac( 'sha256', $bot_token, "WebAppData", TRUE );
$hash = bin2hex( hash_hmac( 'sha256', $data_check_string, $secret_key, TRUE ) );

if( strcmp($hash, $check_hash) === 0 ){
// validation success
}else{
// validation failed
}

关于php - 无法为机器人用户验证 Telegram Web App,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71905866/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com