创建短链接

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

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

/// 处理提交的内容
pub async fn index_action(
    Extension(state): Extension<AppState>,
    Form(cu): Form<form::CreateUrl>,
) -> HandlerRedirectResult {
    let id = core::short_url(&cu.url);
    let handler_name = "index_action";
    let client = get_client(&state, handler_name).await?;
    let result = db::create(&client, cu, id)
        .await
        .map_err(log_error(handler_name.to_string()))?;
    let msg = MsgArgs {
        ok: Some(format!("添加成功,短网址是:{}", result.id)),
        err: None,
        target: Some("/".to_string()),
    };
    Ok(redirect_with_msg("/msg", Some(&msg)))
}

/// 首页
pub async fn index() -> HandlerHtmlResult {
    let handler_name = "index";
    let tmpl = IndexTemplate {};
    render(tmpl).map_err(log_error(handler_name.to_string()))
}

数据库操作

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)
}

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

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