首页
/ Azure AI Projects SDK 认证方式变更详解:从连接字符串到端点URL

Azure AI Projects SDK 认证方式变更详解:从连接字符串到端点URL

2025-07-03 17:28:36作者:郁楠烈Hubert

背景介绍

Azure AI Projects SDK 近期经历了从1.0.0-beta.5到1.0.0-beta.7版本的重大变更,其中最显著的变化是认证方式的调整。这一变更影响了所有使用该SDK进行AI项目开发的开发者,特别是那些需要从客户端直接连接Azure AI Agent Service的应用场景。

认证方式的历史演变

在早期版本中,开发者使用连接字符串进行认证,格式如下:

eastus.api.azureml.ms;12345678-abcd-1234-9fc6-62780b3d3e05;my-resource-group;my-project-name

对应的代码实现为:

const projectClient = AIProjectClient.fromConnectionString(connectionString, new DefaultAzureCredential());

而在新版本中,认证方式改为使用完整的端点URL:

const endpoint = "https://eastus.api.azureml.ms/agents/v1.0/subscriptions/12345678-abcd-1234-9fc6-62780b3d3e05/resourceGroups/my-resource-group/providers/Microsoft.MachineLearningServices/workspaces/my-project-name";
const projectClient = AIProjectClient.fromEndpoint(endpoint, DefaultAzureCredential());

新认证方式详解

端点URL的构造方法

端点URL的结构遵循特定模式,开发者需要了解如何从已知参数构建:

https://<region>.api.azureml.ms/agents/v1.0/subscriptions/<subscription-id>/resourceGroups/<resource-group-name>/providers/Microsoft.MachineLearningServices/workspaces/<project-name>

其中关键参数包括:

  • region:部署区域,如eastus、swedencentral等
  • subscription-id:Azure订阅ID
  • resource-group-name:资源组名称
  • project-name:项目/工作区名称

客户端认证实践

对于Node.js后端应用,推荐使用DefaultAzureCredential:

const endpoint = "构造的端点URL";
const projectClient = new AIProjectClient(endpoint, new DefaultAzureCredential());

对于浏览器端应用,需要使用InteractiveBrowserCredential:

const clientId = "应用注册的客户端ID";
const tenantId = "租户ID";
const agentsEndpoint = "构造的端点URL";

const options = {
  clientId,
  authorityHost: `https://login.microsoftonline.com/${tenantId}`,
  redirectUri: window.location.origin + "/aiproject-auth-callback.html",
};

const credential = new InteractiveBrowserCredential(options);
const agentsClient = new AgentsClient(agentsEndpoint, credential);

常见问题解决方案

1. 端点URL不工作的问题

开发者反馈多种端点格式尝试失败后,经验证有效的格式包括:

https://ai.azure.com/api/<region>/agents/v1.0/subscriptions/<sub-id>/resourcegroups/<rg-name>/providers/Microsoft.MachineLearningServices/workspaces/<workspace-name>

2. 前端打包问题

使用azure-ai-projects包在前端项目中会导致打包体积显著增加(约7MB),并可能产生兼容性警告。替代方案是直接使用azure-ai-agents包,可将体积控制在350KB左右。

3. 流式处理与轮询

新版SDK支持两种处理方式:

  • 轮询方式:通过定期检查运行状态
  • 流式处理:更高效的实时通信方式(但当前版本可能存在反序列化问题)

最佳实践建议

  1. 明确项目类型:区分AI Foundry项目与基于Hub的项目,它们使用不同的端点结构

  2. 环境变量管理:统一使用AZURE_AI_PROJECT_ENDPOINT_STRING环境变量存储端点URL

  3. 包选择策略

    • 后端服务:使用azure-ai-projects
    • 前端应用:优先考虑azure-ai-agents
  4. 错误处理:实现完善的错误捕获和重试机制,特别是对于网络不稳定的客户端场景

未来展望

随着Azure AI服务的持续演进,开发者应关注:

  • 官方文档的定期更新
  • SDK版本的兼容性说明
  • 新功能的发布公告
  • 社区反馈的常见问题解决方案

通过理解这些认证变更和技术细节,开发者可以更顺畅地在各种应用场景中集成Azure AI Projects服务,构建强大的AI驱动型应用。

登录后查看全文
热门项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
162
2.05 K
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
146
191
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
60
16
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
198
279
apintoapinto
基于golang开发的网关。具有各种插件,可以自行扩展,即插即用。此外,它可以快速帮助企业管理API服务,提高API服务的稳定性和安全性。
Go
22
0
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
950
556
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
96
15
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
346
1.33 K