Skip to content

Commit 442eda7

Browse files
authored
Merge pull request #3857 from Chris-T-Jansen/ch20-full-code-update
Update full code reference main.rs in ch20-03
2 parents c64ca0d + 3bff679 commit 442eda7

2 files changed

Lines changed: 40 additions & 52 deletions

File tree

  • listings/ch20-web-server
Lines changed: 20 additions & 26 deletions
Original file line numberDiff line numberDiff line change
@@ -1,10 +1,11 @@
11
use hello::ThreadPool;
2-
use std::fs;
3-
use std::io::prelude::*;
4-
use std::net::TcpListener;
5-
use std::net::TcpStream;
6-
use std::thread;
7-
use std::time::Duration;
2+
use std::{
3+
fs,
4+
io::{prelude::*, BufReader},
5+
net::{TcpListener, TcpStream},
6+
thread,
7+
time::Duration,
8+
};
89

910
// ANCHOR: here
1011
fn main() {
@@ -24,30 +25,23 @@ fn main() {
2425
// ANCHOR_END: here
2526

2627
fn handle_connection(mut stream: TcpStream) {
27-
let mut buffer = [0; 1024];
28-
stream.read(&mut buffer).unwrap();
29-
30-
let get = b"GET / HTTP/1.1\r\n";
31-
let sleep = b"GET /sleep HTTP/1.1\r\n";
32-
33-
let (status_line, filename) = if buffer.starts_with(get) {
34-
("HTTP/1.1 200 OK", "hello.html")
35-
} else if buffer.starts_with(sleep) {
36-
thread::sleep(Duration::from_secs(5));
37-
("HTTP/1.1 200 OK", "hello.html")
38-
} else {
39-
("HTTP/1.1 404 NOT FOUND", "404.html")
28+
let buf_reader = BufReader::new(&mut stream);
29+
let request_line = buf_reader.lines().next().unwrap().unwrap();
30+
31+
let (status_line, filename) = match &request_line[..] {
32+
"GET / HTTP/1.1" => ("HTTP/1.1 200 OK", "hello.html"),
33+
"GET /sleep HTTP/1.1" => {
34+
thread::sleep(Duration::from_secs(5));
35+
("HTTP/1.1 200 OK", "hello.html")
36+
}
37+
_ => ("HTTP/1.1 404 NOT FOUND", "404.html"),
4038
};
4139

4240
let contents = fs::read_to_string(filename).unwrap();
41+
let length = contents.len();
4342

44-
let response = format!(
45-
"{}\r\nContent-Length: {}\r\n\r\n{}",
46-
status_line,
47-
contents.len(),
48-
contents
49-
);
43+
let response =
44+
format!("{status_line}\r\nContent-Length: {length}\r\n\r\n{contents}");
5045

5146
stream.write_all(response.as_bytes()).unwrap();
52-
stream.flush().unwrap();
5347
}
Lines changed: 20 additions & 26 deletions
Original file line numberDiff line numberDiff line change
@@ -1,10 +1,11 @@
11
use hello::ThreadPool;
2-
use std::fs;
3-
use std::io::prelude::*;
4-
use std::net::TcpListener;
5-
use std::net::TcpStream;
6-
use std::thread;
7-
use std::time::Duration;
2+
use std::{
3+
fs,
4+
io::{prelude::*, BufReader},
5+
net::{TcpListener, TcpStream},
6+
thread,
7+
time::Duration,
8+
};
89

910
fn main() {
1011
let listener = TcpListener::bind("127.0.0.1:7878").unwrap();
@@ -22,30 +23,23 @@ fn main() {
2223
}
2324

2425
fn handle_connection(mut stream: TcpStream) {
25-
let mut buffer = [0; 1024];
26-
stream.read(&mut buffer).unwrap();
27-
28-
let get = b"GET / HTTP/1.1\r\n";
29-
let sleep = b"GET /sleep HTTP/1.1\r\n";
30-
31-
let (status_line, filename) = if buffer.starts_with(get) {
32-
("HTTP/1.1 200 OK", "hello.html")
33-
} else if buffer.starts_with(sleep) {
34-
thread::sleep(Duration::from_secs(5));
35-
("HTTP/1.1 200 OK", "hello.html")
36-
} else {
37-
("HTTP/1.1 404 NOT FOUND", "404.html")
26+
let buf_reader = BufReader::new(&mut stream);
27+
let request_line = buf_reader.lines().next().unwrap().unwrap();
28+
29+
let (status_line, filename) = match &request_line[..] {
30+
"GET / HTTP/1.1" => ("HTTP/1.1 200 OK", "hello.html"),
31+
"GET /sleep HTTP/1.1" => {
32+
thread::sleep(Duration::from_secs(5));
33+
("HTTP/1.1 200 OK", "hello.html")
34+
}
35+
_ => ("HTTP/1.1 404 NOT FOUND", "404.html"),
3836
};
3937

4038
let contents = fs::read_to_string(filename).unwrap();
39+
let length = contents.len();
4140

42-
let response = format!(
43-
"{}\r\nContent-Length: {}\r\n\r\n{}",
44-
status_line,
45-
contents.len(),
46-
contents
47-
);
41+
let response =
42+
format!("{status_line}\r\nContent-Length: {length}\r\n\r\n{contents}");
4843

4944
stream.write_all(response.as_bytes()).unwrap();
50-
stream.flush().unwrap();
5145
}

0 commit comments

Comments
 (0)