Both of the following "hello world" samples build successfully, but only the first results in a page that says "Hello World"; the second one gives me an error about the page not being found. The Cargo.toml file is the same for both. I'm accessing the IP 127.0.0.1:3030
.
I tried accessing the second one using curl, but it returned nothing and went back to the prompt. The browser I used for the successful first one is Microsoft Edge 84.
Why doesn't the second one work?
First one
#![deny(warnings)]
use warp::Filter;
#[tokio::main]
async fn main() {
// Match any request and return hello world!
let routes = warp::any().map(|| "Hello, World!");
warp::serve(routes).run(([127, 0, 0, 1], 3030)).await;
Second one
use warp::Filter;
#[tokio::main]
async fn main() {
// GET /hello/warp => 200 OK with body "Hello, warp!"
let hello = warp::path!("hello" / String)
.map(|name| format!("Hello, {}!", name));
warp::serve(hello)
.run(([127, 0, 0, 1], 3030))
.await;
}
Cargo.toml
[package]
name = "warptest"
version = "0.1.0"
authors = ["user"]
edition = "2018"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies]
tokio = { version = "0.2", features = ["full"] }
warp = "0.2"
The second example only responds to requests at the path /hello/string-argument
. It is not configured to respond to the root path /
:
% curl -vvvv 'http://0.0.0.0:3030/'
* Trying 0.0.0.0...
* TCP_NODELAY set
* Connected to 0.0.0.0 (127.0.0.1) port 3030 (#0)
> GET / HTTP/1.1
> Host: 0.0.0.0:3030
> User-Agent: curl/7.64.1
> Accept: */*
>
< HTTP/1.1 404 Not Found
< content-length: 0
< date: Mon, 24 Aug 2020 19:53:06 GMT
<
* Connection #0 to host 0.0.0.0 left intact
* Closing connection 0
% curl -vvvv 'http://0.0.0.0:3030/hello/world'
* Trying 0.0.0.0...
* TCP_NODELAY set
* Connected to 0.0.0.0 (127.0.0.1) port 3030 (#0)
> GET /hello/world HTTP/1.1
> Host: 0.0.0.0:3030
> User-Agent: curl/7.64.1
> Accept: */*
>
< HTTP/1.1 200 OK
< content-type: text/plain; charset=utf-8
< content-length: 13
< date: Mon, 24 Aug 2020 19:54:01 GMT
<
* Connection #0 to host 0.0.0.0 left intact
Hello, world!* Closing connection 0