我有以下代码,所有工作都期望error_handler<>/code>。 我不敢确定什么错误。 如果我提出正确的职位要求,则有200份答复数据。 但是,根据不实要求,Im预计有400人没有获得JSON数据。 它只是说400,但并未退回任何错误的json数据。
Expected Behavior
BAD REQ ->curl -X POST -H “Content-Type: application/json” -d{“bad”:“Someone was here”} localhost:80/send
status 400
{
error: String,
server_id: usize,
request_count: usize,
}
Current Behavior
BAD REQ ->curl -X POST -H “Content-Type: application/json” -d{“bad”:“Someone was here”} localhost:80/send
status 400
Possible Solution
页: 1 它发挥作用,但后来无法找到<代码>。 AppState
Code
pub struct MessageApp {
pub port: u16,
}
impl MessageApp {
pub fn new(port: u16) -> Self {
Self{port}
}
pub async fn run(&self) -> std::io::Result<()> {
let messages = Arc::new(Mutex::new(vec![]));
println!("Starting http server: 127.0.0.1:{}", self.port);
HttpServer::new(move || {
App::new()
.data(AppState {
server_id: SERVER_COUNTER.fetch_add(1, Ordering::SeqCst),
request_count: Cell::new(0),
messages: messages.clone(),
})
.wrap(middleware::Logger::new(LOG_FORMAT))
.service(index)
.service(
web::resource("/send")
.data(
web::JsonConfig::default()
.limit(4096)
.error_handler(post_error)
)
.route(web::post().to(post))
)
.service(clear)
})
.bind(("127.0.0.1", self.port))?
.workers(8)
.run()
.await
}
}
<<>rong>
fn post_error(err: JsonPayloadError, req: &HttpRequest) -> Error {
let extns = req.extensions();
let state = extns.get::<web::Data<AppState>>().unwrap();
let request_count = state.request_count.get() + 1;
state.request_count.set(request_count);
let post_error = PostError {
server_id: state.server_id,
request_count,
error: format!("{}", err),
};
InternalError::from_response(err, HttpResponse::BadRequest().json(post_error)).into()
}
Environment
- Pop OS 20.04 LTS
- Rust Version: rustc 1.45.2 (d3fb005a3 2020-07-31)
- Actix Web Version: 2.0.0