
telegram bot api 中,`forward_from` 字段位于 `message` 对象内部,而非根层级;直接访问 `$update['forward_from']` 会导致空值或报错,必须通过 `$update['message']['forward_from']['id']` 才能安全读取转发者 id。
在开发 Telegram Bot 时,若需识别被转发消息的原始发送者(即 forward_from 用户),一个常见误区是忽略 Telegram Webhook 回调数据的嵌套结构。接收到的 $update 是一个完整的 JSON 解析数组,其顶层键为 update_id、message、edited_message 等,而消息相关字段(包括 forward_from、from、text、date 等)均封装在 $update['message'] 下。
✅ 正确写法如下:
$update = json_decode(file_get_contents('php://input'), TRUE);
// ✅ 安全访问:先判断 message 是否存在,再检查 forward_from
if (isset($update['message']) && isset($update['message']['forward_from'])) {
$forwarderId = $update['message']['forward_from']['id'];
$forwarderUsername = $update['message']['forward_from']['username'] ?? 'N/A';
echo "转发者 ID: {$forwarderId}, 用户名: {$forwarderUsername}";
} else {
echo "该消息未被转发,或未包含 forward_from 信息。";
}⚠️ 注意事项:
- forward_from 仅在消息明确被用户手动转发(非 channel 转发、非 bot 转发)且原用户未开启“隐藏转发来源”隐私设置时才存在;
- 即使隐私关闭,若转发来自频道(forward_from_chat)或为匿名管理员转发,则 forward_from 仍为 null,此时应检查 forward_from_chat 和 forward_signature;
- 始终使用 isset() 或 array_key_exists() 进行空值防护,避免 PHP Notice 错误(如 Trying to access array offset on value of type null);
- 不要混淆 forward_from(原始用户)与 from(当前消息发送者,即转发操作人)。
? 小结:Telegram 的更新对象是分层设计的——message 是核心载体,所有消息元数据都归属其下。养成「先定位 message,再取子字段」的习惯,可避免绝大多数字段访问错误。










