Actix or Tokio runtime not found; halting

Rust使用Actix构建web后端报错

报错信息:Actix or Tokio runtime not found; halting

  1. 按照网上的文档Cargo.toml中依次添加了对应的依赖
  2. 在main.rs文件中声明了一个请求方式,并启动,结果报错如下图:
    在这里插入图片描述
    在网上找了很久都没找到解决方案,Cargo clean Cargo run也试过了,都不行;
    最后在通过科学上网发现有人说是actix-rt的版本需要修改,改为actix-rt="2.9.0"即可。
    修改之后的Cargo.toml如下:
[package]
name = "login_rust"
version = "0.1.0"
edition = "2021"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies]
actix-web="4" 
actix-rt="2.9.0" 
serde = { version = "1.0", features = ["derive"] }
serde_json = "1.0"

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`HttpResponse::NotFound().json()` 是 Rust 中 `actix-web` 框架提供的一种方式,用于创建一个 HTTP 响应对象,并将 JSON 格式的数据作为响应体。它返回一个 `HttpResponse` 对象,表示资源未找到的错误响应,并将响应体设置为指定的 JSON 数据。 这个方法的定义如下: ```rust pub fn json<T: Serialize>(self, value: T) -> Result<HttpResponse, Error> ``` 它接受一个实现了 `Serialize` trait 的类型参数 `T`,用于对要序列化为 JSON 的数据进行泛型处理。它返回一个 `Result`,其中 `Ok` 分支包含了一个带有设置好的 JSON 响应体的 `HttpResponse` 对象,而 `Err` 分支则包含了一个错误对象。 使用 `HttpResponse::NotFound().json()` 方法创建的响应对象可以进一步进行定制,例如设置其他响应头、修改响应状态码等。 以下是一个示例,演示如何使用 `HttpResponse::NotFound().json()` 方法创建一个带有自定义 JSON 数据的 404 Not Found 响应: ```rust use actix_web::{HttpResponse, http::StatusCode}; use serde::Serialize; #[derive(Serialize)] struct ErrorDetails { message: String, } fn handle_request() -> Result<HttpResponse, actix_web::Error> { // 创建带有自定义 JSON 数据的 404 Not Found 响应 let error_details = ErrorDetails { message: "Resource not found".to_string(), }; let response = HttpResponse::NotFound().json(error_details)?; Ok(response) } ``` 在上面的示例中,我们先定义了一个名为 `ErrorDetails` 的结构体,并使用 `serde` 的 `Serialize` trait 来自动实现 JSON 序列化。然后,在 `handle_request()` 函数中,我们创建了一个 `ErrorDetails` 实例作为要返回的 JSON 数据。 接下来,我们使用 `HttpResponse::NotFound().json()` 方法将 `ErrorDetails` 实例序列化为 JSON 数据,并设置为响应体。最后,我们将这个响应对象返回。 这样,当你调用 `handle_request()` 函数时,它将返回一个带有自定义 JSON 数据的 404 Not Found 响应。 希望这可以解释清楚 `HttpResponse::NotFound().json()` 的用法!如果你有更多关于 `actix-web` 或 JSON 响应的问题,请继续提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值