nanoFramework.WebServer 1.2.133

Prefix Reserved
There is a newer version of this package available.
See the version list below for details.
dotnet add package nanoFramework.WebServer --version 1.2.133
                    
NuGet\Install-Package nanoFramework.WebServer -Version 1.2.133
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="nanoFramework.WebServer" Version="1.2.133" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="nanoFramework.WebServer" Version="1.2.133" />
                    
Directory.Packages.props
<PackageReference Include="nanoFramework.WebServer" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add nanoFramework.WebServer --version 1.2.133
                    
#r "nuget: nanoFramework.WebServer, 1.2.133"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package nanoFramework.WebServer@1.2.133
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=nanoFramework.WebServer&version=1.2.133
                    
Install as a Cake Addin
#tool nuget:?package=nanoFramework.WebServer&version=1.2.133
                    
Install as a Cake Tool

Quality Gate Status Reliability Rating NuGet #yourfirstpr Discord

nanoFramework logo


.NET nanoFramework WebServer with Model Context Protocol (MCP)

Build status

Component Build Status NuGet Package
nanoFramework.WebServer Build Status NuGet
nanoFramework.WebServer.FileSystem Build Status NuGet
nanoFramework.WebServer.Mcp Build Status NuGet

Overview

This library provides a lightweight, multi-threaded HTTP/HTTPS WebServer for .NET nanoFramework with comprehensive Model Context Protocol (MCP) support for AI agent integration.

Key Features

  • Multi-threaded request handling
  • Static file serving with FileSystem support
  • RESTful API support with parameter handling
  • Route-based controllers with attribute decoration
  • Authentication support (Basic, API Key)
  • HTTPS/SSL support with certificates
  • Model Context Protocol (MCP) for AI agent integration
  • Automatic tool discovery and JSON-RPC 2.0 compliance

Quick Start

Basic Event Based WebServer

Using the Web Server is very straight forward and supports event based calls.

// You need to be connected to a Wi-Fi or ethernet connection with a proper IP Address
// Optionally you can pass a parameter with the IP address for the server to bind to

using (WebServer server = new WebServer(80, HttpProtocol.Http))
{
    server.CommandReceived += ServerCommandReceived;
    server.Start();
    Thread.Sleep(Timeout.Infinite);
}

private static void ServerCommandReceived(object source, WebServerEventArgs e)
{
    if (e.Context.Request.RawUrl.ToLower() == "/hello")
    {
        WebServer.OutputAsStream(e.Context.Response, "Hello from nanoFramework!");
    }
    else
    {
        WebServer.OutputHttpCode(e.Context.Response, HttpStatusCode.NotFound);
    }
}

Controller-Based WebServer

Controllers are supported including with parametarized routes like 'api/led/{id}/dosomething/{order}'.

using (WebServer server = new WebServer(80, HttpProtocol.Http, new Type[] { typeof(MyController) }))
{
    server.Start();
    Thread.Sleep(Timeout.Infinite);
}

public class MyController
{
    [Route("api/hello")]
    [Method("GET")]
    public void Hello(WebServerEventArgs e)
    {
        WebServer.OutputAsStream(e.Context.Response, "Hello from Controller!");
    }

    [Route("api/led/{id}")]
    [Method("GET")]
    public void LedState(WebServerEventArgs e)
    {
        string ledId = e.GetRouteParameter("id");
        WebServer.OutputAsStream(e.Context.Response, $"You selected Led {ledId}!");
    }
}

Model Context Protocol (MCP) Support

Enable AI agents to interact with your embedded devices through standardized tools and JSON-RPC 2.0 protocol.

Defining MCP Tools

public class IoTTools
{
    [McpServerTool("read_sensor", "Reads temperature from sensor")]
    public static string ReadTemperature()
    {
        // Your sensor reading code
        return "23.5°C";
    }

    [McpServerTool("control_led", "Controls device LED", "Uutput the statusof the LED")]
    public static string ControlLed(LedCommand command)
    {
        // Your LED control code
        return $"LED set to {command.State}";
    }
}

public class LedCommand
{
    [Description("LED state: on, off, or blink")]
    public string State { get; set; }
}

Defining MCP Prompts

You can define reusable, high-level prompts for AI agents using the McpServerPrompt attribute. Prompts encapsulate multi-step instructions or workflows that can be invoked by agents.

Here's a simple example:

using nanoFramework.WebServer.Mcp;

public class McpPrompts
{
    [McpServerPrompt("echo_sanity_check", "Echo test prompt")]
    public static PromptMessage[] EchoSanityCheck()
    {
        return new PromptMessage[]
        {
            new PromptMessage("Call Echo with the string 'Hello MCP world!' and return the response.")
        };
    }
}

Prompts can be discovered and invoked by AI agents in the same way as tools. You can also define prompts with parameters using the McpPromptParameter attribute.

Setting Up MCP Server

public static void Main()
{
    // Connect to WiFi first
    var connected = WifiNetworkHelper.ConnectDhcp(Ssid, Password, requiresDateTime: true);
    
    // Discover and register MCP tools
    McpToolRegistry.DiscoverTools(new Type[] { typeof(IoTTools) });

    // Discover and register MCP prompts
    McpPromptRegistry.DiscoverPrompts(new Type[] { typeof(McpPrompts) });
    
    // Start WebServer with MCP support
    using (var server = new WebServer(80, HttpProtocol.Http, new Type[] { typeof(McpServerController) }))
    {
        // Optional customization
        McpServerController.ServerName = "MyIoTDevice";
        McpServerController.Instructions = "IoT device with sensor and LED control capabilities.";
        
        server.Start();
        Thread.Sleep(Timeout.Infinite);
    }
}

AI Agent Integration

Once running, AI agents can discover and invoke your tools:

// Tool discovery
POST /mcp
{
    "jsonrpc": "2.0",
    "method": "tools/list",
    "id": 1
}

// Tool invocation
POST /mcp
{
    "jsonrpc": "2.0",
    "method": "tools/call",
    "params": {
        "name": "control_led",
        "arguments": {"State": "on"}
    },
    "id": 2
}

Documentation

Topic Description
Controllers and Routing Learn about route attributes, method decorations, and URL parameters
Authentication Configure Basic Auth, API Key, and custom authentication
HTTPS and Certificates Set up SSL/TLS encryption with certificates
File System Support Serve static files from storage devices
Model Context Protocol (MCP) Complete MCP guide for AI agent integration
REST API Development Build RESTful APIs with request/response handling
Event-Driven Programming Handle requests through events and status monitoring
Examples and Samples Working examples and code samples

Limitations

  • No compression support in request/response streams
  • MCP implementation supports server features only (no notifications or SSE)
  • No or single parameter limitation for MCP tools (use complex objects for multiple parameters)
  • Prompt parameters, when declared, are always mandatory.

Installation

Install 'nanoFramework.WebServer' for the Web Server without File System support. Install 'nanoFramework.WebServer.FileSystem' for file serving, so with devices supporting File System. Install 'nanoFramework.WebServer.Mcp' for MCP support. It does contains the full 'nanoFramework.WebServer' but does not include native file serving. You can add this feature fairly easilly by reusing the code function serving it.

Contributing

For documentation, feedback, issues and contributions, please refer to the Home repo.

Join our Discord community here.

Credits

The list of contributors to this project can be found at CONTRIBUTORS.

License

Licensed under the MIT license.

Code of Conduct

This project has adopted the code of conduct defined by the Contributor Covenant to clarify expected behaviour in our community. For more information see the .NET Foundation Code of Conduct.

.NET Foundation

This project is supported by the .NET Foundation.

Product Compatible and additional computed target framework versions.
.NET Framework net is compatible. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories (2)

Showing the top 2 popular GitHub repositories that depend on nanoFramework.WebServer:

Repository Stars
nanoframework/Samples
🍬 Code samples from the nanoFramework team used in testing, proof of concepts and other explorational endeavours
nanoframework/nanoFramework.IoT.Device
📦 This repo includes .NET nanoFramework implementations for various sensors, chips, displays, hats and drivers
Version Downloads Last Updated
1.2.134 419 11/21/2025
1.2.133 307 11/13/2025
1.2.131 253 10/17/2025
1.2.130 178 10/15/2025
1.2.126 396 8/12/2025
1.2.125 281 7/7/2025
1.2.124 172 7/7/2025
1.2.123 182 6/27/2025
1.2.122 294 6/2/2025
1.2.121 342 4/25/2025
1.2.118 353 4/2/2025
1.2.117 214 4/2/2025
1.2.116 553 3/26/2025
1.2.115 536 3/26/2025
1.2.114 544 3/26/2025
1.2.112 260 3/12/2025
1.2.111 279 3/10/2025
1.2.110 218 3/10/2025
1.2.109 241 3/10/2025
1.2.108 248 3/10/2025
1.2.107 286 3/7/2025
1.2.106 216 3/3/2025
1.2.105 311 2/27/2025
1.2.104 181 2/27/2025
1.2.101 203 2/25/2025
1.2.97 186 2/25/2025
1.2.95 178 2/25/2025
1.2.93 346 2/5/2025
1.2.92 176 2/5/2025
1.2.89 205 2/4/2025
1.2.88 207 2/4/2025
1.2.87 193 1/31/2025
1.2.86 182 1/30/2025
1.2.85 179 1/30/2025
1.2.84 173 1/30/2025
1.2.83 146 1/30/2025
1.2.77 183 1/29/2025
1.2.74 296 1/10/2025
1.2.73 204 1/6/2025
1.2.72 202 1/2/2025
1.2.70 330 12/11/2024
1.2.69 157 12/11/2024
1.2.63 587 10/8/2024
1.2.60 252 9/26/2024
1.2.56 303 7/30/2024
1.2.55 248 7/24/2024
1.2.52 354 6/3/2024
1.2.48 260 5/17/2024
1.2.45 168 5/13/2024
1.2.43 259 5/10/2024
1.2.40 308 4/12/2024
1.2.38 199 4/9/2024
1.2.36 193 4/8/2024
1.2.34 216 4/5/2024
1.2.32 191 4/3/2024
1.2.30 193 4/3/2024
1.2.27 411 2/14/2024
1.2.25 185 2/12/2024
1.2.23 304 1/26/2024
1.2.21 195 1/26/2024
1.2.19 183 1/26/2024
1.2.17 225 1/24/2024
1.2.14 535 11/17/2023
1.2.12 239 11/10/2023
1.2.9 197 11/9/2023
1.2.7 235 11/8/2023
1.2.6 174 11/8/2023
1.2.3 334 10/27/2023
1.2.1 258 10/25/2023
1.1.79 273 10/10/2023
1.1.77 258 10/4/2023
1.1.75 508 8/8/2023
1.1.73 366 7/27/2023
1.1.71 231 7/27/2023
1.1.65 792 2/17/2023
1.1.63 524 1/24/2023
1.1.61 389 1/24/2023
1.1.59 456 1/24/2023
1.1.56 543 12/30/2022
1.1.54 431 12/28/2022
1.1.51 461 12/27/2022
1.1.47 851 10/26/2022
1.1.44 519 10/25/2022
1.1.41 513 10/24/2022
1.1.39 556 10/23/2022
1.1.36 566 10/10/2022
1.1.32 539 10/8/2022
1.1.29 605 9/22/2022
1.1.27 571 9/22/2022
1.1.25 566 9/22/2022
1.1.23 614 9/16/2022
1.1.21 623 9/15/2022
1.1.19 632 8/29/2022
1.1.17 655 8/6/2022
1.1.14 566 8/4/2022
1.1.12 535 8/3/2022
1.1.10 569 8/3/2022
1.1.8 564 8/3/2022
1.1.6 741 6/13/2022
1.1.4 633 6/8/2022
1.1.2 557 6/8/2022
1.1.1 603 5/30/2022
1.0.0 833 3/30/2022
1.0.0-preview.260 255 3/29/2022
1.0.0-preview.258 233 3/28/2022
1.0.0-preview.256 266 3/28/2022
1.0.0-preview.254 268 3/28/2022
1.0.0-preview.252 270 3/28/2022
1.0.0-preview.250 239 3/28/2022
1.0.0-preview.248 260 3/17/2022
1.0.0-preview.246 275 3/14/2022
1.0.0-preview.244 246 3/14/2022
1.0.0-preview.242 265 3/14/2022
1.0.0-preview.240 256 3/14/2022
1.0.0-preview.238 244 3/8/2022
1.0.0-preview.236 250 3/8/2022
1.0.0-preview.234 234 3/4/2022
1.0.0-preview.232 262 3/3/2022
1.0.0-preview.230 255 3/2/2022
1.0.0-preview.228 245 2/28/2022
1.0.0-preview.226 280 2/24/2022
1.0.0-preview.222 274 2/17/2022
1.0.0-preview.220 253 2/17/2022
1.0.0-preview.218 309 2/6/2022
1.0.0-preview.216 272 2/4/2022
1.0.0-preview.214 264 2/4/2022
1.0.0-preview.212 293 1/28/2022
1.0.0-preview.210 271 1/28/2022
1.0.0-preview.208 304 1/28/2022
1.0.0-preview.206 254 1/25/2022
1.0.0-preview.204 269 1/21/2022
1.0.0-preview.202 247 1/21/2022
1.0.0-preview.200 256 1/21/2022
1.0.0-preview.198 253 1/21/2022
1.0.0-preview.196 273 1/21/2022
1.0.0-preview.194 275 1/13/2022
1.0.0-preview.192 303 1/12/2022
1.0.0-preview.190 286 1/12/2022
1.0.0-preview.188 258 1/11/2022
1.0.0-preview.186 288 1/11/2022
1.0.0-preview.183 272 1/6/2022
1.0.0-preview.181 291 1/5/2022
1.0.0-preview.180 284 1/3/2022
1.0.0-preview.179 286 1/3/2022
1.0.0-preview.178 264 1/3/2022
1.0.0-preview.177 282 12/30/2021
1.0.0-preview.176 307 12/28/2021
1.0.0-preview.174 331 12/3/2021
1.0.0-preview.172 296 12/3/2021
1.0.0-preview.170 262 12/3/2021
1.0.0-preview.168 306 12/3/2021
1.0.0-preview.166 293 12/3/2021
1.0.0-preview.164 292 12/2/2021
1.0.0-preview.162 310 12/2/2021
1.0.0-preview.160 267 12/2/2021
1.0.0-preview.158 264 12/2/2021
1.0.0-preview.156 291 12/2/2021
1.0.0-preview.154 284 12/2/2021
1.0.0-preview.152 304 12/1/2021
1.0.0-preview.150 261 12/1/2021
1.0.0-preview.148 272 12/1/2021
1.0.0-preview.145 317 11/11/2021
1.0.0-preview.143 332 10/22/2021
1.0.0-preview.141 299 10/18/2021
1.0.0-preview.138 319 10/18/2021
1.0.0-preview.136 446 7/17/2021
1.0.0-preview.134 308 7/16/2021
1.0.0-preview.132 283 7/16/2021
1.0.0-preview.130 313 7/15/2021
1.0.0-preview.128 297 7/14/2021
1.0.0-preview.126 413 6/19/2021
1.0.0-preview.124 377 6/19/2021
1.0.0-preview.122 312 6/17/2021
1.0.0-preview.119 285 6/7/2021
1.0.0-preview.117 297 6/7/2021
1.0.0-preview.115 312 6/7/2021
1.0.0-preview.113 319 6/7/2021
1.0.0-preview.111 329 6/6/2021
1.0.0-preview.109 1,052 6/5/2021
1.0.0-preview.107 313 6/3/2021
1.0.0-preview.105 306 6/2/2021
1.0.0-preview.103 308 6/2/2021
1.0.0-preview.101 318 6/1/2021
1.0.0-preview.99 307 6/1/2021
1.0.0-preview.96 308 6/1/2021
1.0.0-preview.94 340 5/31/2021
1.0.0-preview.92 320 5/30/2021
1.0.0-preview.90 316 5/27/2021
1.0.0-preview.88 315 5/26/2021
1.0.0-preview.86 402 5/23/2021
1.0.0-preview.84 312 5/22/2021
1.0.0-preview.82 372 5/21/2021
1.0.0-preview.80 319 5/19/2021
1.0.0-preview.78 286 5/19/2021
1.0.0-preview.76 306 5/19/2021
1.0.0-preview.71 323 5/15/2021
1.0.0-preview.69 290 5/14/2021
1.0.0-preview.66 294 5/13/2021
1.0.0-preview.64 303 5/11/2021
1.0.0-preview.62 315 5/11/2021
1.0.0-preview.59 361 5/6/2021
1.0.0-preview.57 312 5/5/2021
1.0.0-preview.51 301 4/12/2021
1.0.0-preview.49 316 4/12/2021
1.0.0-preview.47 339 4/10/2021
1.0.0-preview.44 330 4/6/2021
1.0.0-preview.41 308 4/5/2021
1.0.0-preview.32 333 3/21/2021
1.0.0-preview.30 354 3/20/2021
1.0.0-preview.28 334 3/19/2021
1.0.0-preview.26 349 3/18/2021
1.0.0-preview.24 299 3/17/2021
1.0.0-preview.22 298 3/17/2021
1.0.0-preview.20 352 3/5/2021
1.0.0-preview.18 323 3/2/2021
1.0.0-preview.15 573 1/19/2021
1.0.0-preview.13 309 1/19/2021
1.0.0-preview.11 393 1/7/2021
1.0.0-preview.10 356 12/22/2020
1.0.0-preview.6 425 12/1/2020
1.0.0-preview.3 420 11/6/2020