Skip to content

HTTP is the protocol that powers the web. In this challenge, I buildta HTTP server that's capable of handling simple GET/POST requests, serving files and handling multiple concurrent connections. Along the way, I learnt about TCP connections, HTTP headers, HTTP verbs, handling multiple connections and more.

Notifications You must be signed in to change notification settings

daviidy/codecrafters-http-server-java

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

25 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

progress-banner

This is a starting point for Java solutions to the "Build Your Own HTTP server" Challenge.

HTTP is the protocol that powers the web. In this challenge, you'll build a HTTP/1.1 server that is capable of serving multiple clients.

Along the way you'll learn about TCP servers, HTTP request syntax, and more.

Note: If you're viewing this repo on GitHub, head over to codecrafters.io to try the challenge.

Passing the first stage

The entry point for your HTTP server implementation is in src/main/java/Main.java. Study and uncomment the relevant code, and push your changes to pass the first stage:

git add .
git commit -m "pass 1st stage" # any msg
git push origin master

Time to move on to the next stage!

Stage 2 & beyond

Note: This section is for stages 2 and beyond.

  1. Ensure you have java (21) installed locally
  2. Run ./your_server.sh to run your program, which is implemented in src/main/java/Main.java.
  3. Commit your changes and run git push origin master to submit your solution to CodeCrafters. Test output will be streamed to your terminal.

About

HTTP is the protocol that powers the web. In this challenge, I buildta HTTP server that's capable of handling simple GET/POST requests, serving files and handling multiple concurrent connections. Along the way, I learnt about TCP connections, HTTP headers, HTTP verbs, handling multiple connections and more.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published