This is a simple HTTP web server that serves files from a path specified by the user in the URL. It is written in C and uses sockets to handle and maintain connections, parse HTTP requests, and send HTTP responses with requested files. The server also includes a file reader handler to read requested files from the file system and send them as part of the HTTP response.
No external libraries are required to build this project. To build and run the server, follow these steps:
- Clone this repository to your local machine.
- Open a terminal and navigate to the project directory.
- Create a new build directory and navigate into it:
mkdir build cd build
- Run CMake to generate build files:
cmake ..
- Build the project using the generated build files:
make
- (Optional) Move the executable to the directory where you want to serve files from:
mv C_Web_Server ../path/to/serve/files/from
- Run the executable:
./C_Web_Server
- Open a web browser and navigate to
localhost
to view the files in the directory where you ran the executable.
- Socket handling: This section contains the code for creating, binding, and accepting connections on the server socket.
- HTTP request parsing: This section contains the code for parsing incoming HTTP requests and generating appropriate responses.
- File handling: This section contains the code for reading files from disk and sending them to clients in response to HTTP requests.
This server implementation is basic and lacks many of the features of a full-fledged web server. Some possible improvements include:
- Support for multiple concurrent connections.
- Support for more HTTP methods (e.g. PUT, DELETE).
- Improved error handling and logging.
- Better file handling (e.g. support for serving large files).
- Actual safety, include not allowing .. in paths
- URL encoding/decoding: no files with spaces can be served