<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Dapr AI .NET SDK on Dapr 文档库</title><link>https://v1-18.docs.dapr.io/zh-hans/developing-applications/sdks/dotnet/dotnet-ai/</link><description>Recent content in Dapr AI .NET SDK on Dapr 文档库</description><generator>Hugo</generator><language>zh-hans</language><atom:link href="https://v1-18.docs.dapr.io/zh-hans/developing-applications/sdks/dotnet/dotnet-ai/index.xml" rel="self" type="application/rss+xml"/><item><title>Dapr AI 客户端</title><link>https://v1-18.docs.dapr.io/zh-hans/developing-applications/sdks/dotnet/dotnet-ai/dotnet-ai-conversation-usage/</link><pubDate>Mon, 01 Jan 0001 00:00:00 +0000</pubDate><guid>https://v1-18.docs.dapr.io/zh-hans/developing-applications/sdks/dotnet/dotnet-ai/dotnet-ai-conversation-usage/</guid><description>&lt;p>Dapr AI 客户端包使您能够与 Dapr sidecar 提供的 AI 功能进行交互。&lt;/p>
&lt;h2 id="生命周期的管理">生命周期的管理&lt;/h2>
&lt;p>&lt;code>DaprConversationClient&lt;/code> 是专门用于与 Dapr conversation API 交互的客户端版本。它可以与 &lt;code>DaprClient&lt;/code> 和其他 Dapr 客户端一起注册而不会出现问题。&lt;/p>
&lt;p>它通过 TCP 套接字与 Dapr sidecar 通信，以便访问网络资源。&lt;/p>
&lt;p>为了获得最佳性能，建议创建一个长期存在的 &lt;code>DaprConversationClient&lt;/code> 实例，并在整个应用程序中共享使用。&lt;code>DaprConversationClient&lt;/code> 实例是线程安全的，适合共享。&lt;/p>
&lt;p>这可以通过依赖注入来实现。注册方法支持以单例、作用域实例或瞬态（每次注入时重新创建）的方式进行注册，但也可以利用 &lt;code>IConfiguration&lt;/code> 或其他注入服务中的值进行注册，这在每个类中从头创建客户端时是不切实际的。&lt;/p>
&lt;p>避免为每个操作都创建一个新的 &lt;code>DaprConversationClient&lt;/code>。&lt;/p>
&lt;h2 id="通过-daprconversationclientbuilder-配置-daprconversationclient">通过 DaprConversationClientBuilder 配置 DaprConversationClient&lt;/h2>
&lt;p>可以通过在 &lt;code>DaprConversationClientBuilder&lt;/code> 类上调用方法来配置 &lt;code>DaprConversationClient&lt;/code>，然后调用 &lt;code>.Build()&lt;/code> 来创建客户端。每个 &lt;code>DaprConversationClient&lt;/code> 的设置是独立的，并且在调用 &lt;code>.Build()&lt;/code> 后无法更改。&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" style="background-color:#f8f8f8;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-cs" data-lang="cs">&lt;span style="display:flex;">&lt;span>&lt;span style="color:#204a87;font-weight:bold">var&lt;/span> &lt;span style="color:#000">daprConversationClient&lt;/span> &lt;span style="color:#000;font-weight:bold">=&lt;/span> &lt;span style="color:#204a87;font-weight:bold">new&lt;/span> &lt;span style="color:#000">DaprConversationClientBuilder&lt;/span>&lt;span style="color:#000;font-weight:bold">()&lt;/span>
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#000;font-weight:bold">.&lt;/span>&lt;span style="color:#000">UseDaprApiToken&lt;/span>&lt;span style="color:#000;font-weight:bold">(&lt;/span>&lt;span style="color:#4e9a06">&amp;#34;abc123&amp;#34;&lt;/span>&lt;span style="color:#000;font-weight:bold">)&lt;/span> &lt;span style="color:#8f5902;font-style:italic">// 指定用于验证到其他 Dapr sidecar 的 API 令牌&lt;/span>
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#000;font-weight:bold">.&lt;/span>&lt;span style="color:#000">Build&lt;/span>&lt;span style="color:#000;font-weight:bold">();&lt;/span>
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>&lt;code>DaprConversationClientBuilder&lt;/code> 包含以下设置：&lt;/p>
&lt;ul>
&lt;li>Dapr sidecar 的 HTTP 端点&lt;/li>
&lt;li>Dapr sidecar 的 gRPC 端点&lt;/li>
&lt;li>用于配置 JSON 序列化的 &lt;code>JsonSerializerOptions&lt;/code> 对象&lt;/li>
&lt;li>用于配置 gRPC 的 &lt;code>GrpcChannelOptions&lt;/code> 对象&lt;/li>
&lt;li>用于验证请求到 sidecar 的 API 令牌&lt;/li>
&lt;li>用于创建 SDK 使用的 &lt;code>HttpClient&lt;/code> 实例的工厂方法&lt;/li>
&lt;li>用于在向 sidecar 发出请求时使用的 &lt;code>HttpClient&lt;/code> 实例的超时&lt;/li>
&lt;/ul>
&lt;p>SDK 将读取以下环境变量来配置默认值：&lt;/p></description></item><item><title>如何在 .NET SDK 中创建和使用 Dapr AI 会话</title><link>https://v1-18.docs.dapr.io/zh-hans/developing-applications/sdks/dotnet/dotnet-ai/dotnet-ai-conversation-howto/</link><pubDate>Mon, 01 Jan 0001 00:00:00 +0000</pubDate><guid>https://v1-18.docs.dapr.io/zh-hans/developing-applications/sdks/dotnet/dotnet-ai/dotnet-ai-conversation-howto/</guid><description>&lt;h2 id="前提条件">前提条件&lt;/h2>
&lt;ul>
&lt;li>已安装 &lt;a href="https://dotnet.microsoft.com/download/dotnet/6.0">.NET 6&lt;/a>、&lt;a href="https://dotnet.microsoft.com/download/dotnet/8.0">.NET 8&lt;/a> 或 &lt;a href="https://dotnet.microsoft.com/download/dotnet/9.0">.NET 9&lt;/a>&lt;/li>
&lt;li>&lt;a href="https://docs.dapr.io/getting-started/install-dapr-cli/">Dapr CLI&lt;/a>&lt;/li>
&lt;li>&lt;a href="https://docs.dapr.io/getting-started/install-dapr-selfhost">已初始化的 Dapr 环境&lt;/a>&lt;/li>
&lt;/ul>


&lt;div class="alert alert-primary" role="alert">
&lt;h4 class="alert-heading">注意事项&lt;/h4>

 .NET 6 是此版本中 Dapr .NET SDK 包的最低支持版本。仅 .NET 8 和 .NET 9 将在 Dapr v1.16 及更高版本中得到支持。

&lt;/div>

&lt;h2 id="安装">安装&lt;/h2>
&lt;p>要开始使用 Dapr AI .NET SDK 客户端，请从 NuGet 安装 &lt;a href="https://www.nuget.org/packages/Dapr.AI">Dapr.AI 包&lt;/a>：&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" style="background-color:#f8f8f8;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-sh" data-lang="sh">&lt;span style="display:flex;">&lt;span>dotnet add package Dapr.AI
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>&lt;code>DaprConversationClient&lt;/code> 通过 TCP 套接字形式维护对网络资源的访问，用于与 Dapr sidecar 通信。&lt;/p>
&lt;h3 id="依赖注入">依赖注入&lt;/h3>
&lt;p>&lt;code>AddDaprAiConversation()&lt;/code> 方法将注册 Dapr 客户端到 ASP.NET Core 的依赖注入中，这是使用此包的推荐方法。此方法接受一个可选的选项委托，用于配置 &lt;code>DaprConversationClient&lt;/code>，以及一个 &lt;code>ServiceLifetime&lt;/code> 参数，允许您为注册的服务指定不同的生命周期，而不是默认的 &lt;code>Singleton&lt;/code> 值。&lt;/p>
&lt;p>以下示例假设所有默认值均可接受，并足以注册 &lt;code>DaprConversationClient&lt;/code>：&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" style="background-color:#f8f8f8;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-csharp" data-lang="csharp">&lt;span style="display:flex;">&lt;span>&lt;span style="color:#000">services&lt;/span>&lt;span style="color:#000;font-weight:bold">.&lt;/span>&lt;span style="color:#000">AddDaprAiConversation&lt;/span>&lt;span style="color:#000;font-weight:bold">();&lt;/span>
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>可选的配置委托用于通过在 &lt;code>DaprConversationClientBuilder&lt;/code> 上指定选项来配置 &lt;code>DaprConversationClient&lt;/code>，如下例所示：&lt;/p></description></item></channel></rss>