- `const_service` creates a `NewService` that clones references to the wrapped service. - `service_fn` creates a `Service` from a function. Useful with closures.
		
			
				
	
	
		
			27 lines
		
	
	
		
			810 B
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			27 lines
		
	
	
		
			810 B
		
	
	
	
		
			Rust
		
	
	
	
	
	
| #![deny(warnings)]
 | |
| extern crate hyper;
 | |
| extern crate futures;
 | |
| extern crate pretty_env_logger;
 | |
| 
 | |
| use hyper::header::{ContentLength, ContentType};
 | |
| use hyper::server::{Http, Response, const_service, service_fn};
 | |
| 
 | |
| static PHRASE: &'static [u8] = b"Hello World!";
 | |
| 
 | |
| fn main() {
 | |
|     pretty_env_logger::init().unwrap();
 | |
|     let addr = ([127, 0, 0, 1], 3000).into();
 | |
| 
 | |
|     let new_service = const_service(service_fn(|_| {
 | |
|         Ok(Response::<hyper::Body>::new()
 | |
|             .with_header(ContentLength(PHRASE.len() as u64))
 | |
|             .with_header(ContentType::plaintext())
 | |
|             .with_body(PHRASE))
 | |
|     }));
 | |
| 
 | |
|     let mut server = Http::new().bind(&addr, new_service).unwrap();
 | |
|     server.no_proto();
 | |
|     println!("Listening on http://{} with 1 thread.", server.local_addr().unwrap());
 | |
|     server.run().unwrap();
 | |
| }
 |