域名 AXUM.RS 将于 2025 年 10 月到期。我们无意再对其进行续费,如果你有意接续这个域名,请与我们取得联系。
  • AXUM.RS 现仅需人民币 3000 元(大写:叁仟元整。接受适度议价
  • 按照行业规则,AXUM.RS 到期后,大概率会进入长时间的赎回期,该期间内,如果你想拥有该域名,将要付出高额的费用
  • 我们已启用 AXUM.EU.ORG 域名,并将持续运营
  • 仅接受微信或支付宝交易
如果你对 AXUM.RS 有兴趣,请和我们进行联系:

发送Markdown

Telegram 还支持 Markdown 和 HTML 类型的文本消息。本章我们将实现/help指令,它会将帮助信息以 Markdown 格式发送给用户。

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

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

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

// src/types/mod.rs

pub enum MsgType {
    Text(String),
    Photo(String),
    Markdown(String),
}

hook 处理

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 消息内容

// src/handler/command.rs

pub fn help(msg: Option<&str>) -> String {
    let header = match msg {
        Some(txt) => format!("你输入的 `{}` 有误", txt),
        None => "".to_string(),
    };
    let body = r#"
__使用帮助__
`/website`:访问官方网站
`/logo`:获取官方LOGO
`/help`:显示帮助信息
        "#;
    format!(r#"{}{}"#, header, body)
}
要查看完整内容,请先登录