Skip to content

Simple HTTP server built with C and Linux Socket API

Notifications You must be signed in to change notification settings

rajeshrah22/simple-http

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

36 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SimpleHttp

A simple Http server written for learning purposes with C that utilizes the Linux Socket API. We will not implement the full HTTP specification; rather, we will implement just enough to get a taste of the Socket API, concurrent programming, and potentially some defensive security measures.

Core Functionality

An HTTP server is responsible for handling client requests and serving responses over the HTTP protocol. Here are the core functionalities of an HTTP server:

  1. Listening for Incoming Connections
    The server listens on a specified port for incoming TCP connections from clients.

  2. Accepting Client Connections
    Once a connection request is detected, the server accepts the connection, establishing a communication link with the client.

  3. Receiving HTTP Requests
    The server reads the HTTP request from the client. This includes:

  • Request Line: Method (GET, POST, etc.), URL, and HTTP version.
  • Headers: Metadata about the request (e.g., Host, User-Agent, Content-Type).
  • Body: Data sent by the client (primarily in POST requests).
  1. Parsing HTTP Requests
    The server parses the incoming HTTP request to understand what the client is requesting.

  2. Handling Requests
    The server processes the request based on the method and URL. This involves:

  • Static Content: Serving files from the file system (e.g., HTML, CSS, images).
  • Dynamic Content: Executing server-side scripts or applications (e.g., CGI, PHP).
  1. Generating HTTP Responses
    The server creates an HTTP response to send back to the client. This includes:
  • Status Line: HTTP version, status code (e.g., 200 OK, 404 Not Found).
  • Headers: Metadata about the response (e.g., Content-Type, Content-Length).
  • Body: The content being returned (e.g., HTML, JSON).
  1. Sending HTTP Responses
    The server sends the generated response back to the client over the established connection.

TO DO

  • Parse Request Method.
    • GET
    • POST
  • Parse Request Path.
  • Create Response.
  • Send Response.
  • Resolve Path and get correct resource
  • Add Concurrency
  • Async I/O

Future Additions

  • Security Measures.
  • Support POST.
  • Refactor into a simple library.
  • More of the HTTP Spec.

About

Simple HTTP server built with C and Linux Socket API

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published