.net core 项目快速接入Coze智能体-开箱即用-全局说明

目录

一、Coze智能体的核心价值

二、开箱即用-效果如下

三 流程与交互设计

为什么要分析意图,而不是全部交由AI处理。

四 接入前的准备工作

五:代码实现----字节Coze 签署 JWT和获取Token


.net core 项目快速接入Coze智能体-开箱即用

.net core快速实现AI智能聊天功能

.net core快速实现AI智能聊天功能-设计

一、Coze智能体的核心价值


字节跳动推出的新一代AI开发平台,Coze支持开发者快速构建智能体并发布为API服务。其核心优势包括:

多模态能力:支持文本、图像、视频等数据处理
零代码插件集成:内置必应搜索、头条新闻等插件,增强智能体功能
[理解为字节跳动版的GPT]

二、开箱即用-效果如下

三 流程与交互设计

下面关健内容是单独写文章说明。没写要想了解的可留言


1用户+内容---提交
2是否新用户
3创建会话/使用之前会话
4分析意图/内部/外部-----可选(特定业务处理)
5内部意图约定与回复--前端处理-----可选
6发起对话-----调用大模型/智能体
7等对话结果
8回复话内容
---记录交互日志(用于跟踪与分析 是否合理)
--优化意图
--优化智能体/完善智能体

9TTS 文字转语音---.net windows下的实现

10 STT 语音转文字  ---.net windows下的实现

为什么要分析意图,而不是全部交由AI处理。

1我们是使用在线在AI,所有交互都是要收费的

2AI处理是要时间的,当我们有特定的业务要处理时,可以直接根据用户对话直接处理

3内部处理高效

我们这里使用Microsoft.ML 进行了训练和分类。

四 接入前的准备工作

  1. .net core(8)
  2. 创建智能体
  3. 获取凭证--我们这里要使用JWT的授权(要区分不同用户的会话)扣子扣子是新一代 AI 大模型智能体开发平台。整合了插件、长短期记忆、工作流、卡片等丰富能力,扣子能帮你低门槛、快速搭建个性化或具备商业价值的智能体,并发布到豆包、飞书等各个平台。https://www.coze.cn/open/docs/developer_guides/oauth_jwt

五:代码实现----字节Coze 签署 JWT和获取Token

一个用户一个token[其实使用同一个---因为我们有自行维护了]

 /// <summary>
 /// 获取token(传入用户ID)
 /// </summary>
 /// <param name="username"></param>
 /// <returns></returns>
 public static async Task<string> AccessToken(string username = "hcrain")
 {
     var t = CozeDto.GetToken(username);
     if (t.IsNotEmptyOrNull())
     {
         return t;
     }
     var jwt = GenerateJwt(CozeDto.privateKeyPem, username);
     t = await GetAccessTokenAsync(jwt);
     Console.WriteLine($"{username}:{t}");
     CozeDto.AddToken(new cozetokes { access_time = DateTime.Now, access_token = t, userName = username });
     return t;
 }
 /// <summary>
 /// 签署jwt(转入用户ID)
 /// </summary>
 /// <param name="privateKeyPem"></param>
 /// <param name="username"></param>
 /// <returns></returns>
 private static string GenerateJwt(string privateKeyPem, string username = "hcrain")
 {
     // 解析 PEM 格式私钥
     var rsa = RSA.Create();
     rsa.ImportFromPem(privateKeyPem);

     // 配置 Header 和 Payload
     var securityKey = new RsaSecurityKey(rsa);
     var credentials = new SigningCredentials(securityKey, SecurityAlgorithms.RsaSha256);

     var now = DateTime.UtcNow;
     var payload = new JwtPayload
     {
         { "iat", new DateTimeOffset(now).ToUnixTimeSeconds() },
         { "exp", new DateTimeOffset(now.AddMinutes(10)).ToUnixTimeSeconds() },
         { "jti", Guid.NewGuid().ToString() },
         { "session_name",username },
         { "aud", "api.coze.cn" },
         { "iss", "你的应用ID/你的应用ID/你的应用ID" }
     };

     var header = new JwtHeader(credentials)
     {
         { "kid", "你的应用公钥/你的应用公钥/你的应用公钥" }
     };

     var token = new JwtSecurityToken(header, payload);
     return new JwtSecurityTokenHandler().WriteToken(token);
 }


 /// <summary>
 /// 获取token
 /// </summary>
 /// <param name="jwt"></param>
 /// <returns></returns>
 /// <exception cref="Exception"></exception>
 public static async Task<string> GetAccessTokenAsync(string jwt)
 {
     using var _httpClient = new HttpClient();
     var request = new HttpRequestMessage(HttpMethod.Post, CozeDto.Ulr + "api/permission/oauth2/token");
     request.Headers.Authorization = new System.Net.Http.Headers.AuthenticationHeaderValue("Bearer", jwt);

     var content = new
     {
         duration_seconds = 86399,
         grant_type = "urn:ietf:params:oauth:grant-type:jwt-bearer"
     };

     request.Content = new StringContent(
         JsonSerializer.Serialize(content),
         Encoding.UTF8,
         "application/json");

     var response = await _httpClient.SendAsync(request);
     response.EnsureSuccessStatusCode();

     var responseContent = await response.Content.ReadAsStringAsync();
     var tokenResponse = JsonSerializer.Deserialize<TokenResponse>(responseContent);

     return tokenResponse?.access_token ?? throw new Exception("Failed to get access token");
 }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值