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

短链接跳转到原始链接

我们继续实现功能,本章要实现的是通过短链接跳转到原始链接的功能。注意,跳转之前,我们需要将它的访问量加一。

本章代码在04/跳转链接分支。

handler

数据库

pub async fn goto_url(client: &Client, id: String) -> Result<UrlTarget> {
    let result = super::query_one(
        client,
        "UPDATE url SET visit=visit+1 WHERE id=$1 RETURNING url",
        &[&id],
    )
    .await?;
    Ok(result)
}

利益于 PostgreSQL 数据库的强大,我们可以使用单条 SQL 语句就实现既增加访问量,又返回原始链接。如果是其它数据库,则需要使用事务来分步操作:

// 1. 执行 UPDATE url SET visit=visit+1 WHERE id=?
// 2. 判断该 UPDATE 的结果,如果出错回滚事务
// 3. 执行 SELECT url FROM url WHERE id=?
// 4. 提交事务
// 5. 返回 SELECT 的结果
要查看完整内容,请先登录