域名 AXUM.RS 将于2025年10月到期。我们无意再对其进行续费,我们希望你能够接续这个域名,让更多 AXUM 开发者继续受益。
  • 方案1️⃣AXUM.RS 域名 = 3000
  • 方案2️⃣方案1️⃣ + 本站所有专题原始 Markdown 文档 = 5000
  • 方案3️⃣方案2️⃣ + 本站原始数据库 = 5500
如果你有意接续这份 AXUM 情怀,请与我们取得联系。
说明:
  1. 如果有人购买 AXUM.RS 域名(方案1️⃣),或者该域名到期,本站将启用新的免费域名继续提供服务。
  2. 如果有人购买了 AXUM.RS 域名,且同时购买了内容和/或数据库(方案2️⃣/方案3️⃣),本站将关闭。届时我们或许会以另一种方式与你再相遇。

发送Markdown

Telegram 只是有限支持 Markdown 和 HTML,即便如此,我们也可以利用这有限的支持发送格式多样的文本消息。

Markdown 消息其实也是文本消息,所以它调用的 API 和发送普通文本消息的 API 是一样的。

定义 Markdown 消息类型

我们需要给MsgType增加一个枚举值:

hook 处理

pub async fn hook(
    Json(payload): Json<Update>,
    Extension(state): Extension<AppState>,
) -> Result<String> {
    // ..

    let msg_text = payload.message.text.unwrap_or("".to_string());

    let msg_type = match msg_text.as_str() {
        "/website" => MsgType::Text(command::website()),
        "/logo" => MsgType::Photo(command::logo()),
        "/help" => MsgType::Markdown(command::help(None)),
        _ => MsgType::Markdown(command::help(Some(&msg_text))),
    };

    let res = match msg_type {
        MsgType::Text(reply_msg) => {
            bot::send_text_message(&state.bot.token, payload.message.chat.id, reply_msg).await
        }
        MsgType::Photo(reply_msg) => {
            bot::send_photo_message(&state.bot.token, payload.message.chat.id, reply_msg).await
        }
        MsgType::Markdown(reply_msg) => {
            bot::send_markdown_message(&state.bot.token, payload.message.chat.id, reply_msg).await
        }
    }
    .map_err(log_error(msg_text));

    // ..
}

调用 API 的函数

pub async fn send_markdown_message(token: &str, chat_id: u64, text: String) -> Result<Response> {
    let data = request::MarkdownMessage {
        chat_id,
        text,
        parse_mode: "MarkdownV2".to_string(),
    };
    invoke_api(&data, "sendMessage", token).await
}

这里指明了 parse_modeMarkdownV2,这样 Telegram 就会使用 Markdown 来解析文本消息了。

MarkdownMessage 的定义

Telegram 是通过 parse_mode 字段来识别采用何种格式解析文本消息的。所以我们的 MarkdownMessage 和之前的 TextMessage 相比,只需要加上一个parse_mode字段。

// src/types/request.rs

#[derive(Serialize, Debug)]
pub struct MarkdownMessage {
    pub chat_id: u64,
    pub text: String,
    pub parse_mode: String,
}

你可以只定义一个结构体来发送不同格式的文本消息,而不是像本专题这样分别定义不同的结构体。

你可以只定义一个结构体来发送不同格式的文本消息,而不是像本专题这样分别定义不同的结构体。

返回 Markdown 消息内容

要查看完整内容,请先登录