LiteNetwork 2.0.0-rc.2
See the version list below for details.
dotnet add package LiteNetwork --version 2.0.0-rc.2
NuGet\Install-Package LiteNetwork -Version 2.0.0-rc.2
<PackageReference Include="LiteNetwork" Version="2.0.0-rc.2" />
paket add LiteNetwork --version 2.0.0-rc.2
#r "nuget: LiteNetwork, 2.0.0-rc.2"
// Install LiteNetwork as a Cake Addin #addin nuget:?package=LiteNetwork&version=2.0.0-rc.2&prerelease // Install LiteNetwork as a Cake Tool #tool nuget:?package=LiteNetwork&version=2.0.0-rc.2&prerelease
LiteNetwork
LiteNetwork
is a simple and fast networking library built with C# and compatible with .NET Standard 2, .NET 5 and .NET 6. Its main goal is to simply the creation of basic socket servers over the TCP/IP protocol.
Initially, LiteNetwork has been initialy developed for game development networking, but can also be used for other purposes.
How to install
LiteNetwork
is shiped as a single package, you can install it through the Visual Studio project package manager or using the following command in the Package Manager Console:
$> Install-Package LiteNetwork
Or you can use the dotnet command:
$> dotnet add package LiteNetwork
Getting started
Create a server
There is two ways of building a TCP server with LiteNetwork
:
- The instance way, by creating a
LiteServer
instance and then run it manually - The service way
- In fact,
LiteNetwork
provides an extension to theServiceCollection
object, and can be integrated in a .NET Generic Host (used by ASP.NET Core, MAUI).
- In fact,
Common code
First of all, you will need to create the user class that will represent a connected user on your server. Simple create a new class
that implements the LiteServerUser
class.
using LiteNetwork.Server;
public class ClientUser : LiteServerUser
{
}
Within this class, you will be able to handle this client's incoming message sent by a client program thanks to the HandleMessageAsync()
method.
You can also be notified when the client connects to the server or disconnects.
using LiteNetwork.Protocol.Abstractions;
using LiteNetwork.Server;
public class TcpUser : LiteServerUser
{
public override Task HandleMessageAsync(byte[] packetBuffer)
{
// Handle incoming messages using a BinaryReader or any other solution for reading a byte[].
}
protected override void OnConnected()
{
// When the client connects.
}
protected override void OnDisconnected()
{
// When the client disconnects.
}
}
Once the server user is ready, you can create the server itself that will handle this TcpUser
type of users.
Create another new class
, and implement the LiteServer<T>
class where T
is the previously created TcpUser
.
public class MyTcpServer : LiteServer<TcpUser>
{
public MyTcpServer(LiteServerOptions options, IServiceProvider serviceProvider = null)
: base(options, serviceProvider)
{
}
}
The server has some hooks that allows you to control its life time, such as:
Method | Description |
---|---|
OnBeforeStart() |
Called before the server starts. |
OnAfterStart() |
Called after the server starts. |
OnBeforeStop() |
Called before the server stops. |
OnAfterStop() |
Called after the server stops. |
OnError(ILiteConnection, Exception) |
Called when there is an unhandled error witht the given ILiteConnection . |
Create the server via instance
Now that the server and user classes are built, you can now instanciate your server and call the Start()
method to start the server.
// Using minimal API
using LiteNetwork.Server;
using System;
// Create the server configuration, to listen on "127.0.0.1" and port "4444"
var configuration = new LiteServerOptions()
{
Host = "127.0.0.1",
Port = 4444
};
// Create the server instance by givin the server options and start it.
using var server = new MyTcpServer(configuration);
server.Start();
// Just for the example, otherwise the console will just shutdown.
// Do not use in production environment.
Console.ReadKey();
Create the server via service
For this example, you will need to install the Microsoft.Extensions.Hosting
package from nuget in order to build a .NET Generic Host.
// Using minimal API
using Microsoft.Extensions.Hosting;
using System;
var host = new HostBuilder()
.UseConsoleLifetime()
.Build();
return host.RunAsync();
Then, once your host is setup and running, you can configure the LiteServer
service using the ConfigureLiteNetwork()
method located in the LiteNetwork.Hosting
namespace:
// Using minimal API
using LiteNetwork.Hosting;
using LiteNetwork.Server.Hosting;
using Microsoft.Extensions.Hosting;
using System;
using System.Threading.Tasks;
var host = new HostBuilder()
// Configures the LiteNetwork context.
.ConfigureLiteNetwork((context, builder) =>
{
// Adds a LiteServer instance for the MyTcpServer class.
builder.AddLiteServer<MyTcpServer>(options =>
{
// This configures the server's LiteServerOptions instance.
options.Host = "127.0.0.1";
options.Port = 4444;
});
})
.UseConsoleLifetime()
.Build();
return host.RunAsync();
Your server is now listening on "127.0.0.1" and port "4444".
Also, since you are using a .NET generic host, it also provides dependency injection into the server and client classes. Hence, you can inject services, configuration (IOptions<T>
if configured, etc..).
Note: You can also add as many servers you want into a single .NET generic host by calling the
builder.AddLiteServer<>()
method with different parameters.
Create a client
TBA.
Protocol
Packet Processor
TBA.
Thanks
I would like to thank everyone that contributed to this library directly by fixing bugs or add new features, but also the people with who I had the chance to discuss about networking problematics which helped me to improve this library.
Credits
Package Icon : from Icons8
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 is compatible. net5.0-windows was computed. net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Microsoft.Extensions.DependencyInjection (>= 3.1.10 && < 5.0.0)
- Microsoft.Extensions.Hosting.Abstractions (>= 3.1.10 && < 5.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 3.1.10 && < 5.0.0)
- Microsoft.Extensions.ObjectPool (>= 3.1.10 && < 5.0.0)
-
net5.0
- Microsoft.Extensions.DependencyInjection (>= 5.0.0 && < 6.0.0)
- Microsoft.Extensions.Hosting.Abstractions (>= 5.0.0 && < 6.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 5.0.0 && < 6.0.0)
- Microsoft.Extensions.ObjectPool (>= 5.0.0 && < 6.0.0)
-
net6.0
- Microsoft.Extensions.DependencyInjection (>= 6.0.0)
- Microsoft.Extensions.Hosting.Abstractions (>= 6.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 6.0.0)
- Microsoft.Extensions.ObjectPool (>= 6.0.0)
NuGet packages (3)
Showing the top 3 NuGet packages that depend on LiteNetwork:
Package | Downloads |
---|---|
LiteNetwork.Extensions
Super simple packet handling support for LiteNetwork. |
|
HeavyNetwork
Package Description |
|
LiteNetwork.Extensions.Processing
Super simple packet handling support for LiteNetwork. |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
2.4.0 | 615 | 1/21/2024 |
2.3.0 | 1,541 | 7/30/2023 |
2.2.0 | 1,064 | 12/28/2022 |
2.1.0 | 1,008 | 11/12/2022 |
2.0.0 | 1,059 | 5/27/2022 |
2.0.0-rc.6 | 218 | 5/14/2022 |
2.0.0-rc.5 | 137 | 4/24/2022 |
2.0.0-rc.4 | 135 | 4/23/2022 |
2.0.0-rc.3 | 124 | 4/23/2022 |
2.0.0-rc.2 | 137 | 4/23/2022 |
2.0.0-rc.1 | 132 | 4/23/2022 |
1.0.4 | 1,062 | 1/23/2022 |
1.0.3 | 1,020 | 1/22/2022 |
1.0.2 | 863 | 12/22/2021 |
1.0.1 | 817 | 12/22/2021 |
1.0.0 | 919 | 11/8/2021 |