目錄
一、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 進行了訓練和分類。
四 接入前的準備工作
- .net core(8)
- 創建智能體
- 獲取憑證--我們這里要使用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 和 Payloadvar 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");}