1
0
Fork 0
mirror of https://github.com/actix/actix-web.git synced 2025-01-09 00:35:56 +00:00

Fix StaticFiles does not support percent encoded paths #177

This commit is contained in:
Nikolay Kim 2018-04-13 10:13:12 -07:00
parent c0976bfa17
commit 22c776f46e
2 changed files with 21 additions and 1 deletions

View file

@ -1,6 +1,11 @@
# Changes
## 0.5.2 (2018-04-xx)
* Fix StaticFiles does not support percent encoded paths #177
## 0.5.1 (2018-04-12)
* Client connector provides stats, `ClientConnector::stats()`

View file

@ -15,6 +15,7 @@ use bytes::{Bytes, BytesMut, BufMut};
use futures::{Async, Poll, Future, Stream};
use futures_cpupool::{CpuPool, CpuFuture};
use mime_guess::get_mime_type;
use percent_encoding::percent_decode;
use header;
use error::Error;
@ -484,7 +485,10 @@ impl<S: 'static> Handler<S> for StaticFiles<S> {
if !self.accessible {
Ok(self.default.handle(req))
} else {
let relpath = match req.match_info().get("tail").map(PathBuf::from_param) {
let relpath = match req.match_info().get("tail").map(
|tail| percent_decode(tail.as_bytes()).decode_utf8().unwrap())
.map(|tail| PathBuf::from_param(tail.as_ref()))
{
Some(Ok(path)) => path,
_ => return Ok(self.default.handle(req))
};
@ -671,4 +675,15 @@ mod tests {
let loc = response.headers().get(header::LOCATION).unwrap().to_str().unwrap();
assert_eq!(loc, "/test/Cargo.toml");
}
#[test]
fn integration_percent_encoded() {
let mut srv = test::TestServer::with_factory(
|| App::new()
.handler("test", StaticFiles::new(".").index_file("Cargo.toml")));
let request = srv.get().uri(srv.url("/test/%43argo.toml")).finish().unwrap();
let response = srv.execute(request.send()).unwrap();
assert_eq!(response.status(), StatusCode::OK);
}
}