域名 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️⃣),本站将关闭。届时我们或许会以另一种方式与你再相遇。

创建短链接

本章将实现创建短链接功能。

本章代码在03/创建短链接分支。

{%extends "base.html"%} {%block content%}
<main class="p-3">
  <h1>创建你的短网址</h1>
  <form action="/" method="post" autocomplete="off">
    <div class="mb-3">
      <label for="url" class="form-label">网址:</label>
      <input
        type="url"
        class="form-control"
        id="url"
        name="url"
        placeholder="输入你要缩短的网址"
        required
      />
    </div>
    <div class="mb-3">
      <label for="email" class="form-label">邮箱:</label>
      <input
        type="email"
        class="form-control"
        id="email"
        name="email"
        placeholder="输入你的邮箱"
        required
      />
    </div>
    <button type="submit" class="btn btn-primary">提交</button>
  </form>
</main>
{%endblock%}

可以看到,我们只是简单的做了一个表单。

  • index_action:用于接收用户提交的表单,并将其作为参数调用数据库操作的函数

  • index:显示表单

index:显示表单

数据库操作

pub async fn create(client: &Client, cu: form::CreateUrl, id: String) -> Result<UrlID> {
    // 是否存在
    let result = super::query_one(client, "SELECT id FROM url WHERE id=$1", &[&id]).await;
    match result {
        // 如果已存在,直接返回
        Ok(result) => return Ok(result),
        // 如果不是“未找到”的错误,直接返回
        Err(err) if !err.is_not_found() => return Err(err),
        // 如果不存在,什么也不做,继续下面的代码
        _ => {}
    };
    let result = super::query_one(
        client,
        "INSERT INTO url(id, url, email) VALUES ($1,$2,$3) RETURNING id",
        &[&id, &cu.url, &cu.email],
    )
    .await?;
    Ok(result)
}

首先判断提交的原始链接是否存在,如果存在,直接返回对应的短链接。否则,将提交的数据写入数据库。注意,虽然这个函数有两个数据库操作,但并不需要使用事务来保证原子性,因为这两个操作是无关联的。

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