Сервер MCP на C# для структуры/схемы базы данных SQL (в Visual Studio) для Github CopilotC#

Место общения программистов C#
Ответить
Anonymous
 Сервер MCP на C# для структуры/схемы базы данных SQL (в Visual Studio) для Github Copilot

Сообщение Anonymous »

У меня есть проект, реализующий сервер MCP на C#, скажем, этот проект называется A. A получает структуру базы данных SQL (имена таблиц, первичные ключи, внешние ключи и имена столбцов) и отвечает большим объектом JSON (через HTTPS). A работает на внутреннем тестовом сервере компании.
У меня есть другой проект (называемый B) на моем локальном компьютере, в котором есть этот файл .mcp.json в папке решения (см. код).
Теперь, если я спрошу Github Copilot в B, какие таблицы/столбцы есть в базе данных, он ответит, что не может установить соединение с сервером MCP. Как я могу это исправить?
Если я использую cmd на своем локальном компьютере с помощью этой команды:
curl -k https://URL/mcp/schema -H "Content-Type": application/json" -H "Authorization: Bearer Token"

Сервер MCP отвечает объектом JSON.
Вот моя конечная точка сервера MCP (внутри Program.cs):
app.MapGet("/mcp/schema", async (IConfiguration config, HttpRequest request) =>
{
var expectedToken = config["Mcp:AuthToken"];
if (!string.IsNullOrWhiteSpace(expectedToken))
{
var auth = request.Headers.Authorization.ToString();
if (auth != $"Bearer {expectedToken}")
return Results.Unauthorized();
}

var cs = config.GetConnectionString("Db");
if (string.IsNullOrEmpty(cs))
return Results.Problem("Database connection string 'Db' is not configured.");

try
{
var fullSchema = await SqlSchema.GetFullSchemaAsync(cs);
return Results.Json(fullSchema, new JsonSerializerOptions { WriteIndented = true });
}
catch (Exception ex)
{
return Results.Problem(ex.Message);
}
});

{
"servers": {
"dbschema": {
"type": "http",
"url": "https://URL/mcp/schema",
"headers": {
"Authorization": "Bearer Token"
}
}
}
}


Подробнее здесь: https://stackoverflow.com/questions/798 ... udio-for-g
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»