在axum中使用Query/Form收集重复/数组/列表参数

本文介绍了如何在Java的SpringWeb框架中,通过axum和axum-extra库处理数组形式的Query或Form参数,以及如何在官方文档中找到这类隐藏的功能。
摘要由CSDN通过智能技术生成

在Java Spring Web等框架中,我们可以收集重复的Query或者Form参数到一个列表中,就像这样:

@GetMapping
public String getValues(@RequestParam String[] values) {
    return String.join(values, ",");
}

我们只要按照这种方式访问接口就可以将参数作为数组传递到后端:

curl "http://localhost:8080/test?values=value1&values=value2"

但是axum默认的Form和Query提取器是不支持这种玩法的。

解决方法其实很简单,就一句话:下载一个包:axum-extra,使用其中提供的Form提取器。(这个Form对GET请求会解析参数,效果是和Query一样的)。这个包是axum官方项目的一部分。示例代码:

use axum::{
    http::StatusCode,
    routing::{get, post},
};
use axum_extra::extract::Form;
use tokio::net::TcpListener;

#[derive(serde::Deserialize, Debug)]
pub struct TestParam {
    #[serde(rename = "value")]
    pub values: Vec<String>,
}

async fn test(Form(params): Form<TestParam>) -> Result<String, (StatusCode, String)> {
    Ok(params.values.join(","))
}

#[tokio::main]
async fn main() {
    let app = axum::Router::new()
        .route("/test", post(test))
        .route("/test", get(test));

    let tcp_listener = TcpListener::bind("0.0.0.0:3000").await.unwrap();

    axum::serve(tcp_listener, app.into_make_service())
        .await
        .unwrap();
}

不管是用GET + query参数还是用POST + 表单参数都可以正常地识别数组参数了。

如果在values的serde注解中再加一个(default)的话还可以兼容空数组(也就是什么都没有传入的情况)。

不得不说,官方是真能藏,这么有用的东西不管是文档还是issue里面都没有提到一下,发现这个东西的存在纯属误打误撞,希望后面的人看到这篇文章就不要再去绕弯路了。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的示例,展示如何使用Rust后端框架Axum来创建一个基本的Web应用程序: 首先,确保您已经安装Rust和Cargo。然后,在您的项目目录创建一个新的Cargo.toml文件,并添加以下内容: ```toml [package] name = "axum_example" version = "0.1.0" edition = "2021" [dependencies] axum = "0.2" tokio = { version = "1", features = ["full"] } ``` 接下来,创建一个main.rs文件,并添加以下代码: ```rust use axum::{handler::get, Router}; use std::net::SocketAddr; async fn hello_world() -> &'static str { "Hello, world!" } #[tokio::main] async fn main() { // 创建一个Axum应用程序的根路由 let app = Router::new().route("/", get(hello_world)); // 定义服务器的地址和端口 let addr = SocketAddr::from(([127, 0, 0, 1], 3000)); // 运行服务器 axum::Server::bind(&addr) .serve(app.into_make_service()) .await .unwrap(); } ``` 上述代码创建了一个简单的Axum应用程序,该应用程序定义了一个根路由"/",并使用GET方法处理请求。处理程序函数hello_world返回一个字符串"Hello, world!"作为响应。 最后,打开终端,导航到您的项目目录,并运行以下命令来构建和运行应用程序: ``` cargo build cargo run ``` 您应该会看到类似于以下输出: ``` Listening on http://127.0.0.1:3000 ``` 现在,您可以在浏览器访问http://127.0.0.1:3000,并应该看到"Hello, world!"的响应。 这只是Axum的一个简单示例,您可以根据需要添加更多的路由和处理程序来构建更复杂的应用程序。Axum提供了许多功能和间件,使您能够处理不同类型的请求和实现复杂的业务逻辑。您可以参考Axum的官方文档以获得更多详细信息和示例代码:https://docs.rs/axum/0.2.5/axum/

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值