0

0

Azure文档智能服务:解决“密钥认证禁用”错误及替代方案

碧海醫心

碧海醫心

发布时间:2025-09-18 10:56:14

|

1010人浏览过

|

来源于php中文网

原创

Azure文档智能服务:解决“密钥认证禁用”错误及替代方案

在使用Azure文档智能服务Python SDK时,遇到AuthenticationTypeDisabled错误通常表示Azure资源本身禁用了基于API密钥的认证方式。这不是代码逻辑错误,而是资源配置或组织安全策略所致。解决此问题需要检查Azure门户中的资源认证设置,或考虑采用更安全的Azure Active Directory (AAD) 认证方式,并在必要时联系Azure管理员获取相应权限。

azure文档智能服务(document intelligence,原名form recognizer)是一个强大的云服务,用于从文档中提取文本、键值对、表格和结构化数据。开发者通常通过其python sdk与服务进行交互,其中认证是连接到服务的第一步。

1. 问题描述:密钥认证失败

当尝试使用Azure文档智能服务的端点(endpoint)和API密钥(key)进行认证时,可能会遇到以下错误信息:

azure.core.exceptions.HttpResponseError: (AuthenticationTypeDisabled) Key based authentication is disabled for this resource.
Code: AuthenticationTypeDisabled
Message: Key based authentication is disabled for this resource.

此错误明确指出,当前资源已禁用基于API密钥的认证类型。这意味着即使提供的API密钥是正确的,服务也不会接受它,因为它根本没有启用这种认证机制。

以下是导致此错误的典型Python代码示例:

from azure.ai.formrecognizer import DocumentAnalysisClient
from azure.core.credentials import AzureKeyCredential

# 请替换为您的实际端点和密钥
endpoint = "https://your-resource-name.cognitiveservices.azure.com/"
key = "YOUR_API_KEY" # 此处应填入您的API密钥

def format_bounding_region(bounding_regions):
    if not bounding_regions:
        return "N/A"
    return ", ".join("Page #{}: {}".format(region.page_number, format_polygon(region.polygon)) for region in bounding_regions)

def format_polygon(polygon):
    if not polygon:
        return "N/A"
    return ", ".join(["[{}, {}]".format(p.x, p.y) for p in polygon])

def analyze_general_documents():
    # 示例文档URL
    docUrl = "https://raw.githubusercontent.com/Azure-Samples/cognitive-services-REST-api-samples/master/curl/form-recognizer/sample-layout.pdf"

    # 初始化文档分析客户端
    document_analysis_client = DocumentAnalysisClient(endpoint=endpoint, credential=AzureKeyCredential(key))

    # 开始分析文档
    poller = document_analysis_client.begin_analyze_document_from_url(
            "prebuilt-document", docUrl)
    result = poller.result()

    # ... 后续处理结果的代码 ...
    print("文档分析完成。")

if __name__ == "__main__":
    analyze_general_documents()

2. 错误分析:AuthenticationTypeDisabled 的根本原因

AuthenticationTypeDisabled错误并非代码语法或逻辑问题。它直接来源于Azure文档智能服务资源的配置。在Azure中,资源可以配置多种认证方式,包括基于API密钥和基于Azure Active Directory (AAD) 的认证。当此错误发生时,通常意味着:

  • 资源配置策略: 您的组织或订阅可能配置了严格的安全策略,默认禁用或强制禁用API密钥认证,以强制使用更安全的AAD认证。
  • 手动禁用: 资源管理员可能在Azure门户中手动禁用了API密钥认证。
  • 权限不足: 作为用户,您可能没有足够的权限来修改资源的认证设置,或者无法使用当前环境中配置的密钥。

值得注意的是,代码中 DocumentAnalysisClient(endpoint=endpoint, credential=AzureKeyCredential(key)) 的写法在API密钥认证启用时是完全正确的。

3. 解决方案与建议

解决此问题主要有以下几个方向:

3.1 验证并修改Azure资源配置(如果允许)

如果您的权限允许,或者您可以联系到Azure管理员,请按照以下步骤检查并修改文档智能服务资源的认证设置:

  1. 登录Azure门户: 访问 portal.azure.com
  2. 导航到文档智能服务资源: 在搜索栏中输入您的文档智能服务资源名称,并导航到该资源的概览页面。
  3. 检查认证设置: 在资源菜单中查找与“身份验证”、“密钥”或“网络”相关的设置。不同的Azure服务和版本可能位置略有不同。通常,您会在“资源管理”或“安全”部分找到管理API密钥的选项,以及可能存在的认证类型开关。
  4. 启用密钥认证: 如果发现密钥认证被禁用,并且您的组织策略允许,请尝试启用它。
  5. 重新生成密钥: 确保您使用的密钥是最新且有效的。

重要提示: 在企业环境中,强烈建议遵循组织的安全策略。如果策略要求禁用API密钥认证,请不要随意启用。

arXiv Xplorer
arXiv Xplorer

ArXiv 语义搜索引擎,帮您快速轻松的查找,保存和下载arXiv文章。

下载

3.2 采用Azure Active Directory (AAD) 认证(推荐)

Azure Active Directory (AAD) 认证是更安全、更灵活的认证方式,特别适用于企业级应用。当API密钥认证被禁用时,使用AAD认证是最佳实践。

要使用AAD认证,您需要安装 azure-identity 库,并使用 DefaultAzureCredential。DefaultAzureCredential 会尝试通过多种方式(如环境变量、托管标识、Azure CLI、Visual Studio Code等)获取凭据。

步骤:

  1. 安装必要的库:

    pip install azure-identity
  2. 修改Python代码: 将 AzureKeyCredential 替换为 DefaultAzureCredential。

    from azure.ai.formrecognizer import DocumentAnalysisClient
    from azure.core.credentials import AzureKeyCredential # 仍然可以保留,但不再用于初始化
    from azure.identity import DefaultAzureCredential # 导入DefaultAzureCredential
    
    endpoint = "https://your-resource-name.cognitiveservices.azure.com/"
    # key = "YOUR_API_KEY" # 不再直接使用API密钥
    
    def format_bounding_region(bounding_regions):
        # ... (与之前相同) ...
        if not bounding_regions:
            return "N/A"
        return ", ".join("Page #{}: {}".format(region.page_number, format_polygon(region.polygon)) for region in bounding_regions)
    
    def format_polygon(polygon):
        # ... (与之前相同) ...
        if not polygon:
            return "N/A"
        return ", ".join(["[{}, {}]".format(p.x, p.y) for p in polygon])
    
    def analyze_general_documents():
        docUrl = "https://raw.githubusercontent.com/Azure-Samples/cognitive-services-REST-api-samples/master/curl/form-recognizer/sample-layout.pdf"
    
        # 使用DefaultAzureCredential进行认证
        credential = DefaultAzureCredential()
        document_analysis_client = DocumentAnalysisClient(endpoint=endpoint, credential=credential)
    
        poller = document_analysis_client.begin_analyze_document_from_url(
                "prebuilt-document", docUrl)
        result = poller.result()
    
        # ... 后续处理结果的代码 ...
        print("文档分析完成。")
    
    if __name__ == "__main__":
        analyze_general_documents()
  3. 配置本地环境以使用AAD认证:

    • Azure CLI: 在终端运行 az login 进行登录。DefaultAzureCredential 会自动检测并使用您的CLI凭据。
    • 环境变量: 设置 AZURE_CLIENT_ID, AZURE_TENANT_ID, AZURE_CLIENT_SECRET (适用于服务主体) 或 AZURE_USERNAME, AZURE_PASSWORD (不推荐用于生产环境)。
    • 托管标识: 如果您的代码运行在Azure虚拟机、Azure应用服务等支持托管标识的环境中,DefaultAzureCredential 会自动利用这些标识。

3.3 联系Azure管理员

如果您不确定如何配置Azure资源,或者没有权限进行更改,最直接有效的方法是联系您的Azure管理员或IT团队。他们可以帮助您:

  • 确认资源认证策略。
  • 授予您必要的权限。
  • 指导您如何使用正确的认证方法(例如,提供服务主体的凭据)。

4. 总结与注意事项

  • 错误性质: AuthenticationTypeDisabled 是一个资源配置错误,而非代码语法错误。您提供的Python代码在API密钥认证启用时是正确的。
  • 安全性考量: 许多组织出于安全考虑会禁用API密钥认证,并倾向于使用AAD认证。AAD提供了更精细的访问控制、更好的审计能力和更安全的凭据管理。
  • 调试思路: 当遇到此类认证错误时,首先应检查Azure门户中的资源配置,其次考虑切换到推荐的AAD认证方式。

通过理解此错误的原因并采取相应的解决策略,您可以有效地连接到Azure文档智能服务并利用其强大的功能。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

718

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

627

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

744

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

617

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1236

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

575

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

700

2023.08.11

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 0.6万人学习

Django 教程
Django 教程

共28课时 | 2.7万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号