Skip to content

Latest commit

 

History

History
164 lines (121 loc) · 5.33 KB

README.md

File metadata and controls

164 lines (121 loc) · 5.33 KB

TCP Server Project

This project is a simple TCP server written in C, using socket programming concepts. It listens on a specified port, accepts client connections, and serves dynamic HTML content based on incoming requests using a templating system that supports dynamic values, if-else conditions, and loops. The code is organized into multiple files with CMake as the build system.

Project Structure

project/
├── CMakeLists.txt             # Build configuration
├── include/
│   ├── server.h               # Main server header file
│   ├── html_serve.h           # Header for serve_html function
│   ├── request_handler.h      # Header for handle_client function
│   ├── template.h             # Header for template processing functions
│   └── socket_utils.h         # Header for socket utility functions
├── src/
│   ├── server.c               # Main server program
│   ├── html_serve.c           # serve_html function
│   ├── request_handler.c      # handle_client function
│   ├── template.c             # Template processing functions
│   └── socket_utils.c         # Utility functions for socket operations
└── README.md                  # Project documentation

Files

  • server.c: Contains the main server loop, which listens for and accepts client connections.
  • html_serve.c: Handles HTML file reading and serves HTML content to clients. Contains the serve_html function.
  • request_handler.c: Manages client requests by processing incoming HTTP requests and serving appropriate responses. Contains the handle_client function.
  • template.c: Implements template processing functions to support dynamic values, if-else conditions, and loops in HTML content.
  • socket_utils.c: Includes utility functions for socket initialization and client data handling. Contains the initialize_server and read_client_data functions.
  • server.h: Declares main server-related constants and functions.
  • html_serve.h: Declares the function used to read and serve HTML files.
  • request_handler.h: Declares the function to handle client requests.
  • template.h: Declares functions for processing templates with dynamic content.
  • socket_utils.h: Declares utility functions for initializing sockets and reading client data.

Prerequisites

  • CMake (version 3.10 or higher)
  • GCC or another compatible C compiler
  • Linux or WSL (Windows Subsystem for Linux) recommended for running this server

Setup Instructions

1. Clone the Repository

git clone <repository_url>
cd project

2. Build the Project

  1. Create a build directory and navigate into it:

    mkdir build && cd build
  2. Generate the makefiles with CMake:

    cmake ..
  3. Compile the project using make:

    make

This will create an executable file named server inside a bin directory under the build folder.

3. Run the Server

After building, you can start the server as follows:

valgrind --leak-check=full ./bin/server 

The server will listen on port 8080 (default setting) and process incoming client requests.

Template Features

The server supports a templating system that allows for dynamic content in HTML files. The following features are implemented:

1. Dynamic Values

You can replace placeholders in the template with dynamic values. Placeholders are defined as {{key}}, where key corresponds to the variable you want to insert.

2. If-Else Conditions

The server can handle if-else statements within templates. Use the following syntax:

{% if condition %}
    Content to show if condition is true
{% else %}
    Content to show if condition is false
{% endif %}

3. For Loops

You can create loops to iterate over a list of items in your templates using the following syntax:

{% for item in items %}
    Content to repeat for each item
{% endfor %}

Example Usage

HTML Template

Create an HTML file (e.g., index.html) with the following content to test the features:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Dynamic Template Example</title>
</head>
<body>
    <h1>Welcome to the Template Server</h1>
    
    <p>{{ greeting }}</p>

    {% if is_logged_in %}
        <p>Hello, {{ username }}!</p>
    {% else %}
        <p>Please log in to access more features.</p>
    {% endif %}

    <h2>Your Items:</h2>
    <ul>
        {% for item in items %}
            <li>{{ item }}</li>
        {% endfor %}
    </ul>
</body>
</html>

Sending a Request

To send a request to the server, you can use a web browser or a tool like curl. Make sure to specify the correct HTML file to serve based on your request.

Troubleshooting

If you encounter errors:

  1. Ensure that no other process is using port 8080.
  2. Verify that CMake and GCC are correctly installed.
  3. Use the command netstat -tuln | grep 8080 to check if the port is occupied.

Acknowledgments


Feel free to reach out for any questions or improvements!