作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有下面的代码,一切正常,期望error_handler
。我不知道怎么了。如果我以正确的格式发出过帐请求,则会得到200份响应数据。但是在错误的请求下,我期望400的JSON数据无法接收。它只是说400,但不返回任何错误json数据。
预期行为
不良请求-> curl -X POST -H "Content-Type: application/json" -d '{"bad": "Someone was here"}' localhost:8080/send
status 400
{
error: String,
server_id: usize,
request_count: usize,
}
当前行为
curl -X POST -H "Content-Type: application/json" -d '{"bad": "Someone was here"}' localhost:8080/send
status 400
可能的解决方案
.data
替换了
.app_data
,但可以,但是找不到
AppState
代码
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
}
}
错误处理程序
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()
}
环境
最佳答案
如前所述,在可能的解决方案中。
在github上获得作者的帮助后。他提到我需要移出.app_data
来解决此问题,或移至新版本3.0来解决此问题。
但是使用下面的2.0.0版本是解决方案:
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")
.app_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
以及提取AppState的方法我做错了。该问题已在
post_error 函数内部固定。
fn post_error(err: JsonPayloadError, req: &HttpRequest) -> Error {
// let extns = req.extensions();
// let state = extns.get::<web::Data<AppState>>().unwrap();
let state = req.app_data::<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()
}
关于rust - Actix-Web 2.0 JsonConfig error_handler无法正常工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63361464/
我有下面的代码,一切正常,期望error_handler。我不知道怎么了。如果我以正确的格式发出过帐请求,则会得到200份响应数据。但是在错误的请求下,我期望400的JSON数据无法接收。它只是说40
我是一名优秀的程序员,十分优秀!