Skip to content

Latest commit

 

History

History
160 lines (115 loc) · 6 KB

README.md

File metadata and controls

160 lines (115 loc) · 6 KB

MaxLib.WebServer

.NET Core NuGet Publish License: MIT Current Version Top Language

MaxLib.WebServer is a full web server written in C#. To use this webserver you only need to add the .NuGet package to your project, instantiate the server in your code and thats it. No special configuration files or multiple processes.

This web server is build modular. Any modules can be replaced by you and you decide what the server is capable of. The server can fully configured (including exchanging the modules) during runtime - no need to restart everything.

Some of the current features of the web server are:

  • HTTP web server (of course, that's the purpose of the project)
  • HTTPS web server with SSL certificates
  • HTTP and HTTPS web server on the same port. The server detects automatically what the user intends to use.
  • Asynchronous handling of requests. Every part of the pipeline works with awaitable Tasks.
  • REST Api builder. You can directly bind your methods to the handlers.
  • Chunked transport. The server understands chunked data streams and can produce these.
  • Lazy handling of requests. The server allows you to produce the content while you are sending the response. No need to wait.
  • Work with components that belongs to another AppDomain with Marshaling.
  • Deliver contents from your local drive (e.g. HDD)
  • Session keeping. You can identify the user later.
  • ...

Getting Started

This will add MaxLib.WebServer to your project and create a basic server with basic functions.

Installing

Add the MaxLib.WebServer package.

dotnet add package MaxLib.WebServer

Create a simple server

Write somewhere in your code (e.g.) in your Main method of your programm the following snippet:

using MaxLib.WebServer;
using MaxLib.WebServer.Builder; // this using is used later in this tutorial

// ...

using var server = new Server(new WebServerSettings(
    8000, // this will run the server on port 8000
    5000  // set the timout to 5 seconds.
));

// now add some services. You can use your own implementations but here we
// will add a basic set of services from MaxLib.WebServer.Services.
server.InitDefault();

// the server can now be started. A basic set of services is defined so a new
// request will be handled and the user gets a response. Right now its a 
// 404 NOT FOUND but we will add more.
server.Start();

// if you want to stop the server but don't release any of its resources you can do it with:
server.Stop();

Right now you can start the server and open the url http://localhost:8000 in your browser and will get a nice 404 response.

Create own service

Now we will create our own service, that will responds with a beautiful "Hello World" message.

Create a new class MyServices and put this code in it:

using System;
using System.Threading.Tasks;
using MaxLib.WebServer;
using MaxLib.WebServer.Builder;

// every service that uses the included Builder system needs to be derived from Service
public class MyServices : Service
{
    // this method should listen on /hello and return a nice hello
    [Path("/hello")]
    public string Hello()
    {
        return "<html><head><title>Hello World</title></head>" +
            "<body><h1>Hello World!</h1></body></html>";
    }
}

Now you need to add this line to add your service to server:

server.AddWebService(Service.Build<MyServices>()!);

After that you can run your programm and open the page http://localhost:8000/hello. You will see your hello world message.

More information about the new builder system can be found here

Example

Contributing

Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.

Versioning

We use SemVer for versioning. For the versions available, see the tags on this repository.

Authors

See also the list of contributors who participated in this project.

Lincense

This project is licensed under the MIT License - see the LICENSE.md file for details

Acknowledgments

  • StackOverflow for the help
  • Wikipedia, SelfHTML and Mozilla for their documentation
  • PurpleBooth for her README.md template

Last Words

This project was a free time project of mine and I have done it because why not. The source code was a long time a part of MaxLib (a collection of other fun projects and code) but got its own repository for better maintenance.

Some of the documentation inside the code is still in German and other things needs to be optimized.

I have used this for some projects with my friends. It can handle some TB of traffic over a long period without any problems or crashes. I am a little proud of this.

I will further maintain and extend this library if I have new cool features in mind (this was the case for the full WebSocket support and easy Builder System).