/ Diretório / Playground / C# SDK
● Oficial modelcontextprotocol ⚡ Instantâneo

C# SDK

por modelcontextprotocol · modelcontextprotocol/csharp-sdk

Build MCP servers and clients in .NET — official SDK co-maintained by the MCP team and Microsoft.

The official modelcontextprotocol/csharp-sdk. Write MCP servers with attributes like [McpServerToolType] and [McpServerTool], or build clients that connect to any MCP server. Integrates naturally with .NET dependency injection, logging, and hosting.

Por que usar

Principais recursos

Demo ao vivo

Como fica na prática

csharp-sdk.replay ▶ pronto
0/0

Instalar

Escolha seu cliente

~/Library/Application Support/Claude/claude_desktop_config.json  · Windows: %APPDATA%\Claude\claude_desktop_config.json
{
  "mcpServers": {
    "csharp-sdk": {
      "command": "dotnet",
      "args": [
        "run",
        "--project",
        "./MyMcpServer"
      ]
    }
  }
}

Abra Claude Desktop → Settings → Developer → Edit Config. Reinicie após salvar.

~/.cursor/mcp.json · .cursor/mcp.json
{
  "mcpServers": {
    "csharp-sdk": {
      "command": "dotnet",
      "args": [
        "run",
        "--project",
        "./MyMcpServer"
      ]
    }
  }
}

Cursor usa o mesmo esquema mcpServers que o Claude Desktop. Config de projeto vence a global.

VS Code → Cline → MCP Servers → Edit
{
  "mcpServers": {
    "csharp-sdk": {
      "command": "dotnet",
      "args": [
        "run",
        "--project",
        "./MyMcpServer"
      ]
    }
  }
}

Clique no ícone MCP Servers na barra lateral do Cline, depois "Edit Configuration".

~/.codeium/windsurf/mcp_config.json
{
  "mcpServers": {
    "csharp-sdk": {
      "command": "dotnet",
      "args": [
        "run",
        "--project",
        "./MyMcpServer"
      ]
    }
  }
}

Mesmo formato do Claude Desktop. Reinicie o Windsurf para aplicar.

~/.continue/config.json
{
  "mcpServers": [
    {
      "name": "csharp-sdk",
      "command": "dotnet",
      "args": [
        "run",
        "--project",
        "./MyMcpServer"
      ]
    }
  ]
}

O Continue usa um array de objetos de servidor em vez de um map.

~/.config/zed/settings.json
{
  "context_servers": {
    "csharp-sdk": {
      "command": {
        "path": "dotnet",
        "args": [
          "run",
          "--project",
          "./MyMcpServer"
        ]
      }
    }
  }
}

Adicione em context_servers. Zed recarrega automaticamente ao salvar.

claude mcp add csharp-sdk -- dotnet run --project ./MyMcpServer

Uma linha só. Verifique com claude mcp list. Remova com claude mcp remove.

Casos de uso

Usos do mundo real: C# SDK

Build an MCP server in .NET that exposes your existing services

👤 C#/.NET engineers with internal APIs ⏱ ~45 min intermediate

Quando usar: You're on .NET and want to expose business logic to agents without a rewrite.

Pré-requisitos
  • .NET 8+ SDKdotnet --version
Fluxo
  1. Create the project
    dotnet new console -n MyMcpServer. Add ModelContextProtocol NuGet. Use the minimal hosting template for MCP.✓ Copiado
    → csproj + Program.cs with MCP hosted service
  2. Add a tool
    Create a static class with [McpServerToolType]. Add a method GetOrder(string id) decorated with [McpServerTool(Description="...")] that calls my existing OrderService via DI.✓ Copiado
    → Tool compiles, description comes from attribute
  3. Test with the inspector
    Run the server as stdio. Launch the MCP Inspector via npx @modelcontextprotocol/inspector dotnet run. Call GetOrder.✓ Copiado
    → Tool invocation returns order JSON

Resultado: A compiled, typed MCP server reusing your existing .NET services and DI container.

Armadilhas
  • Tool methods that are instance methods on a class need DI to work — Register the owning class in the ServiceCollection; the SDK resolves through DI
  • Async methods without proper cancellation tokens hang at shutdown — Accept CancellationToken ct as the last parameter on every tool — SDK injects it

Build a .NET console app that uses MCP servers

👤 C# devs building internal automation ⏱ ~30 min intermediate

Quando usar: You want deterministic .NET code (not an LLM loop) that calls MCP servers — e.g., a scheduled job that uses github + filesystem MCPs.

Fluxo
  1. Add the client package
    Create a console app. Reference ModelContextProtocol client. Add a config pointing at a stdio server (e.g. npx -y @modelcontextprotocol/server-github).✓ Copiado
    → Client builds
  2. Connect and call
    Start the client, list tools, call list_repositories with my org name. Print the result.✓ Copiado
    → Repos printed to console
  3. Wrap as a scheduled job
    Turn this into a Worker Service that runs nightly. Log metrics via ILogger.✓ Copiado
    → Worker runs via dotnet run and schedules cleanly

Resultado: MCP as a library, not just a chat plugin — works inside any .NET process.

Armadilhas
  • Stdio servers take time to start, first call times out — Initialize the client at app startup and reuse; don't spawn per-call

Serve an MCP endpoint from an ASP.NET Core app

👤 .NET platform engineers ⏱ ~60 min advanced

Quando usar: You want the MCP server hosted inside an existing ASP.NET Core service, behind the same auth and ingress.

Pré-requisitos
  • Existing ASP.NET Core app or willingness to start onedotnet new web
Fluxo
  1. Add MCP services + endpoint
    In Program.cs, builder.Services.AddMcpServer().WithToolsFromAssembly(). Then app.MapMcp('/mcp').✓ Copiado
    → /mcp endpoint responds to SSE handshake
  2. Share auth with the rest of the app
    Put the /mcp endpoint behind my existing JWT bearer auth middleware. Verify unauth'd requests get 401.✓ Copiado
    → 401 unauth, 200 auth
  3. Deploy and connect
    Deploy. Wire a teammate's Claude Desktop via mcp-remote https://myapp.com/mcp with their JWT.✓ Copiado
    → Team members see tools

Resultado: MCP alongside your existing API in one deploy with one auth story.

Armadilhas
  • Kestrel buffers SSE responses behind a reverse proxy — Disable response buffering; ensure IIS/nginx/Cloudflare in front also disable buffering for /mcp
Combine com: cloud-run

Combinações

Combine com outros MCPs para 10× de alavancagem

csharp-sdk + cloud-run

Deploy .NET MCP server on Cloud Run alongside other microservices

Containerize my .NET MCP server (mcr.microsoft.com/dotnet/aspnet base), deploy to Cloud Run with a min-instance=1 for cold-start mitigation.✓ Copiado
csharp-sdk + fastmcp

Comparison for polyglot shops — different SDKs, same protocol

Our team has both Python and .NET services. Use FastMCP for Python APIs and csharp-sdk for .NET APIs — both behind one ContextForge gateway.✓ Copiado

Ferramentas

O que este MCP expõe

FerramentaEntradasQuando chamarCusto
[McpServerToolType] attribute on a class Mark classes whose methods should be exposed free
[McpServerTool(Description)] attribute on a method Each method you want agents to call free
AddMcpServer() / WithToolsFromAssembly() fluent builder Program.cs at startup free
MapMcp('/path') ASP.NET endpoint ASP.NET hosting only free
IMcpClient stdio or SSE transport config Client-side usage free

Custo e limites

O que custa rodar

Cota de API
None — this is an SDK
Tokens por chamada
No framework overhead beyond MCP protocol
Monetário
Free, MIT licensed
Dica
Use .NET's built-in logging and HealthChecks to catch problems before they balloon in prod

Segurança

Permissões, segredos, alcance

Armazenamento de credenciais: Standard .NET: user-secrets for dev, environment variables or Key Vault for prod
Saída de dados: Whatever your tools reach

Solução de problemas

Erros comuns e correções

Tool not appearing in inspector

WithToolsFromAssembly() only scans the executing assembly. For tools in referenced libraries, pass the Assembly explicitly: WithTools(typeof(MyTools).Assembly).

DI can't resolve my service in a tool method

Tool types must be registered in the container. Add builder.Services.AddScoped<OrderService>() before AddMcpServer.

ASP.NET MapMcp returns 404

You mapped after app.Run() — move MapMcp before Run. Also check the path doesn't conflict with other endpoints.

JSON serialization fails on enums

SDK uses System.Text.Json; add [JsonStringEnumConverter] on your enums or configure globally.

Alternativas

C# SDK vs. outros

AlternativaQuando usarTroca
FastMCP (Python)You're OK picking up Python — richer example ecosystemDifferent language; team skill dependent
TypeScript MCP SDKNode / TS shopSimilar DX, language choice

Mais

Recursos

📖 Leia o README oficial no GitHub

🐙 Ver issues abertas

🔍 Ver todos os 400+ servidores MCP e Skills