<?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/de/tags/oauth/</link><description>Articles, tutorials and insights from the .NET community.</description><generator>Hugo</generator><language>de</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/de/tags/oauth/index.xml" rel="self" type="application/rss+xml"/><item><title>Ihr KI-Agent Hat ein Identitätsproblem (Und Hier ist die Vorlage, die Es Löst)</title><link>https://thedotnetblog.com/de/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/de/news/emiliano-montesdeoca/azd-least-privilege-ai-agents-oauth-token-pattern/</guid><description>Eine neue azd-Vorlage von Curity und Microsoft zeigt, wie man KI-Agenten erstellt, die kurzlebige OAuth-Token mit feingranularen Scopes verwenden — damit Agenten niemals Daten sehen können, die sie nicht sehen sollten.</description><content:encoded>&lt;p&gt;Es gibt einen Moment in jedem KI-Agenten-Projekt, der ungefähr so läuft: Die Demo funktioniert perfekt, der Agent interpretiert natürliche Sprache, ruft die richtigen APIs auf, gibt die richtigen Daten zurück. Dann fangen Sie an, über echte Benutzer nachzudenken.&lt;/p&gt;
&lt;p&gt;Was hindert die Agenten-Session eines Benutzers daran, die Daten eines anderen Benutzers zu sehen? Was passiert, wenn der Agent durch Prompt-Injektion ausgetrickst wird? Was passiert, wenn er ein Tool auf unerwartete Weise aufruft?&lt;/p&gt;
&lt;p&gt;Das sind keine Randfälle. Das sind Designentscheidungen, die Sie vor dem Deployment treffen müssen.&lt;/p&gt;
&lt;p&gt;Eine neue &lt;code&gt;azd&lt;/code&gt;-Vorlage von Curity und Microsoft gibt Ihnen eine funktionsfähige Referenz für genau dieses Problem.&lt;/p&gt;
&lt;h2 id="das-kernproblem-authentifizierung--autorisierung"&gt;Das Kernproblem: Authentifizierung ≠ Autorisierung&lt;/h2&gt;
&lt;p&gt;Die meisten Agenten-Beispiele behandeln die Benutzerauthentifizierung gut. Sie behandeln die Autorisierung schlecht. Zu wissen, &lt;em&gt;wer&lt;/em&gt; der Benutzer ist, sagt Ihnen nicht, &lt;em&gt;welche Daten&lt;/em&gt; er sehen sollte.&lt;/p&gt;
&lt;p&gt;Eine traditionelle Client-Anwendung macht vorhersehbare API-Aufrufe. Ein KI-Agent ist nicht-deterministisch — er interpretiert natürliche Sprache und entscheidet, was er aufruft. Er kann kreativ sein. Er kann auch falsch liegen. Und wenn er durch Prompt-Injektion manipuliert wird, brauchen Sie Regeln, die nicht davon abhängen, dass die KI sich gut verhält.&lt;/p&gt;
&lt;p&gt;Die Lösung, die diese Vorlage demonstriert: &lt;strong&gt;Kurzlebige Token, die genau die richtigen Informationen für jeden Hop tragen&lt;/strong&gt;.&lt;/p&gt;
&lt;h2 id="wie-die-token-kette-funktioniert"&gt;Wie die Token-Kette Funktioniert&lt;/h2&gt;
&lt;p&gt;Die Vorlage verwendet OAuth 2.0-Zugriffstoken mit Token-Austausch, um Berechtigungen bei jedem Schritt einzuschränken. Ein Benutzer-Token wird zweimal ausgetauscht, bevor es den MCP-Server erreicht:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;Erster Austausch&lt;/strong&gt; — schränkt den Scope ein und konvertiert das opake Token in ein JWT&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Zweiter Austausch&lt;/strong&gt; — fügt die Agenten-Identität und eine neue Zielgruppe für den MCP-Server-Hop hinzu&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;So sieht das MCP-Server-Token aus:&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;Die &lt;code&gt;customer_id&lt;/code&gt; ist vom Autorisierungsserver in das Token eingebettet, nicht als Parameter übergeben, den der Agent kontrolliert. Die API prüft das Token, nicht die Anweisungen des Agenten.&lt;/p&gt;
&lt;p&gt;Das bedeutet: Selbst wenn jemand den Agenten dazu verleitet, die Daten eines anderen Kunden abzurufen, wird das Token dies nicht autorisieren.&lt;/p&gt;
&lt;h2 id="was-die-vorlage-deployt"&gt;Was die Vorlage Deployt&lt;/h2&gt;
&lt;p&gt;Mit ein paar &lt;code&gt;azd&lt;/code&gt;-Befehlen erhalten Sie:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Einen Backend-Agenten auf Microsoft Foundry (C#, Microsoft A2A und MCP SDKs)&lt;/li&gt;
&lt;li&gt;Einen MCP-Server, der eine Beispiel-Portfolio-API exponiert&lt;/li&gt;
&lt;li&gt;Curity Identity Server als Autorisierungsserver, zusammen mit Entra ID für die Authentifizierung&lt;/li&gt;
&lt;li&gt;Externe und interne API-Gateways, die Token-Austausch und Audit-Logging verwalten&lt;/li&gt;
&lt;li&gt;Bicep für die gesamte Azure-Infrastruktur: Container Apps, VNet, ACR, Azure AI Foundry, Key Vault, Azure SQL Database, Speicher&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;Das gesamte Muster ist inspizierbar und anpassbar.&lt;/p&gt;
&lt;h2 id="das-designprinzip-das-es-wert-ist-übernommen-zu-werden"&gt;Das Designprinzip, das Es Wert Ist, Übernommen zu Werden&lt;/h2&gt;
&lt;p&gt;Auch wenn Sie Curity nicht verwenden, ist das Muster übertragbar: &lt;strong&gt;Agenten sollten niemals permanenten API-Zugriff haben&lt;/strong&gt;. Jede Aktion sollte ein kurzlebiges Token mit dem minimalen Scope verwenden, der für diesen spezifischen Aufruf benötigt wird, ausgestellt für die spezifische Agenten-Identität, mit den Claims, die die API benötigt, um Autorisierungsentscheidungen zu treffen.&lt;/p&gt;
&lt;p&gt;Das hält gegen kreative Agenten, Fehler und Prompt-Injektion stand, wie es &amp;ldquo;Stellen Sie einfach sicher, dass der Agent keine schlechten Dinge tut&amp;rdquo; niemals tun wird.&lt;/p&gt;
&lt;h2 id="fazit"&gt;Fazit&lt;/h2&gt;
&lt;p&gt;Sicherheitsmuster für KI-Agenten werden in der Industrie noch ausgearbeitet. Diese Vorlage ist eine der vollständigsten Referenzimplementierungen, die ich gesehen habe — sie deckt den tatsächlichen Autorisierungsfluss ab, nicht nur die Authentifizierung.&lt;/p&gt;
&lt;p&gt;Originalbeitrag: &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>