<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/"><channel><title>OAuth | The .NET Blog</title><link>https://thedotnetblog.com/ru/tags/oauth/</link><description>Articles, tutorials and insights from the .NET community.</description><generator>Hugo</generator><language>ru</language><managingEditor>@thedotnetblog (The .NET Blog)</managingEditor><webMaster>@thedotnetblog</webMaster><lastBuildDate>Wed, 20 May 2026 00:00:00 +0000</lastBuildDate><atom:link href="https://thedotnetblog.com/ru/tags/oauth/index.xml" rel="self" type="application/rss+xml"/><item><title>У Вашего ИИ-Агента Проблема с Идентификацией (И Вот Шаблон, Который Её Решает)</title><link>https://thedotnetblog.com/ru/news/emiliano-montesdeoca/azd-least-privilege-ai-agents-oauth-token-pattern/</link><pubDate>Wed, 20 May 2026 00:00:00 +0000</pubDate><author>Emiliano Montesdeoca</author><guid>https://thedotnetblog.com/ru/news/emiliano-montesdeoca/azd-least-privilege-ai-agents-oauth-token-pattern/</guid><description>Новый шаблон azd от Curity и Microsoft показывает, как создавать ИИ-агентов, использующих краткосрочные токены OAuth с детально настроенными областями — чтобы агенты никогда не могли видеть данные, которые не должны видеть.</description><content:encoded>&lt;p&gt;Есть момент в каждом проекте ИИ-агента, который выглядит примерно так: демо работает идеально, агент интерпретирует естественный язык, вызывает нужные API, возвращает нужные данные. Затем вы начинаете думать о реальных пользователях.&lt;/p&gt;
&lt;p&gt;Что мешает сессии агента одного пользователя видеть данные другого пользователя? Что если агент будет обманут через инъекцию промпта? Что если он вызовет инструмент неожиданным образом?&lt;/p&gt;
&lt;p&gt;Это не крайние случаи. Это проектные решения, которые нужно принять перед запуском.&lt;/p&gt;
&lt;p&gt;Новый шаблон &lt;code&gt;azd&lt;/code&gt; от Curity и Microsoft даёт вам рабочий эталон именно для этой проблемы.&lt;/p&gt;
&lt;h2 id="основная-проблема-аутентификация--авторизация"&gt;Основная Проблема: Аутентификация ≠ Авторизация&lt;/h2&gt;
&lt;p&gt;Большинство примеров агентов хорошо справляются с аутентификацией пользователей. Они плохо справляются с авторизацией. Знание &lt;em&gt;кто&lt;/em&gt; является пользователем не говорит вам, &lt;em&gt;какие данные&lt;/em&gt; он должен видеть.&lt;/p&gt;
&lt;p&gt;Традиционное клиентское приложение делает предсказуемые вызовы API. ИИ-агент не является детерминированным — он интерпретирует естественный язык и решает, что вызывать. Он может быть творческим. Он также может ошибаться. И если он манипулируется через инъекцию промпта, вам нужны правила, которые не зависят от хорошего поведения ИИ.&lt;/p&gt;
&lt;p&gt;Решение, которое демонстрирует этот шаблон: &lt;strong&gt;краткосрочные токены, несущие именно правильную информацию для каждого перехода&lt;/strong&gt;.&lt;/p&gt;
&lt;h2 id="как-работает-цепочка-токенов"&gt;Как Работает Цепочка Токенов&lt;/h2&gt;
&lt;p&gt;Шаблон использует токены доступа OAuth 2.0 с обменом токенов для сужения разрешений на каждом шаге. Токен пользователя обменивается дважды, прежде чем достигнет MCP-сервера:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;Первый обмен&lt;/strong&gt; — сужает область применения и преобразует непрозрачный токен в JWT&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Второй обмен&lt;/strong&gt; — добавляет идентификацию агента и новую аудиторию для перехода к MCP-серверу&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;Как выглядит токен MCP-сервера:&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-json" data-lang="json"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;{&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="nt"&gt;&amp;#34;scope&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;stocks/read&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="nt"&gt;&amp;#34;sub&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;62c839b8...&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="nt"&gt;&amp;#34;aud&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;https://mcp.demo.example&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="nt"&gt;&amp;#34;customer_id&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;178&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="nt"&gt;&amp;#34;region&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;USA&amp;#34;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;&lt;code&gt;customer_id&lt;/code&gt; встроен в токен сервером авторизации, а не передаётся как параметр, которым управляет агент. API проверяет токен, а не инструкции агента.&lt;/p&gt;
&lt;p&gt;Это означает: даже если кто-то обманет агента, заставив его попытаться получить данные другого клиента, токен не авторизует это.&lt;/p&gt;
&lt;h2 id="что-развёртывает-шаблон"&gt;Что Развёртывает Шаблон&lt;/h2&gt;
&lt;p&gt;С несколькими командами &lt;code&gt;azd&lt;/code&gt; вы получаете:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Бэкенд-агент на Microsoft Foundry (C#, SDK Microsoft A2A и MCP)&lt;/li&gt;
&lt;li&gt;MCP-сервер, предоставляющий пример портфельного API&lt;/li&gt;
&lt;li&gt;Curity Identity Server в качестве сервера авторизации, наряду с Entra ID для аутентификации&lt;/li&gt;
&lt;li&gt;Внешние и внутренние API-шлюзы, обрабатывающие обмен токенов и журналирование аудита&lt;/li&gt;
&lt;li&gt;Bicep для всей инфраструктуры Azure: Container Apps, VNet, ACR, Azure AI Foundry, Key Vault, Azure SQL Database, хранилище&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;Весь шаблон поддаётся проверке и настройке.&lt;/p&gt;
&lt;h2 id="принцип-дизайна-достойный-заимствования"&gt;Принцип Дизайна, Достойный Заимствования&lt;/h2&gt;
&lt;p&gt;Даже если вы не используете Curity, шаблон можно перенести: &lt;strong&gt;агенты никогда не должны иметь постоянный доступ к API&lt;/strong&gt;. Каждое действие должно использовать краткосрочный токен с минимальной областью применения, необходимой для этого конкретного вызова, выданный для конкретной идентификации агента, несущий утверждения, которые API нужны для принятия решений об авторизации.&lt;/p&gt;
&lt;p&gt;Это устойчиво к творческим агентам, ошибкам и инъекции промпта теми способами, которыми «просто убедитесь, что агент не делает плохих вещей» никогда не будет.&lt;/p&gt;
&lt;h2 id="заключение"&gt;Заключение&lt;/h2&gt;
&lt;p&gt;Шаблоны безопасности для ИИ-агентов всё ещё разрабатываются в отрасли. Этот шаблон является одной из наиболее полных эталонных реализаций, которые я видел — он охватывает фактический поток авторизации, а не только аутентификацию.&lt;/p&gt;
&lt;p&gt;Оригинальный пост: &lt;a href="https://devblogs.microsoft.com/azure-sdk/azd-curity-least-privilege-ai-agents/"&gt;Least privilege AI agents: A new azd template from Curity and Microsoft&lt;/a&gt;&lt;/p&gt;</content:encoded></item></channel></rss>