0

0

Zeep 报错:Service not found - 解决方案

DDD

DDD

发布时间:2025-09-07 13:40:02

|

588人浏览过

|

来源于php中文网

原创

zeep 报错:service not found - 解决方案

正如摘要所说,本文旨在解决在使用 Zeep 库连接 Microsoft Dynamics 365 Business Central (BC) SOAP Endpoint 时遇到的 "Service not found" 错误。以下将详细分析问题并提供解决方案。

问题分析

在使用 Zeep 库调用 Business Central 的自定义 SOAP Endpoint 时,可能会遇到 zeep.exceptions.Fault: Service "Company Name/Codeunit/MyOperation" was not found! 错误。 尽管使用 python3 -m zeep 命令可以成功获取 WSDL 定义,表明服务本身是可访问的,但通过 Zeep 代码调用时却失败了。

可能原因

根据提供的上下文信息以及 GitHub issue 的讨论,问题的根源可能在于 Zeep 库本身存在的一个缺陷。Zeep 在处理某些 SOAP 服务时,可能会错误地构建请求的 URL,导致服务无法找到。

解决方案

该问题在 Zeep 的 GitHub 仓库中已被报告并解决,修复方案是升级 Zeep 库到最新版本。

奇布塔
奇布塔

基于AI生成技术的一站式有声绘本创作平台

下载
pip install zeep --upgrade

示例代码

以下是一个使用 Zeep 连接 Business Central SOAP Endpoint 的示例代码,确保将 BC_USER,BC_PASSWORD 和 url 替换为实际的值。

import os
from requests import Session
from requests.auth import HTTPBasicAuth

from zeep import Client
from zeep.transports import Transport

user = os.environ.get("BC_USER")
password = os.environ.get("BC_PASSWORD")

session = Session()
session.auth = HTTPBasicAuth(user, password)

url = "https://foo.bar/Company%20Name/Codeunit/MyOperation?WSDL" # ensure WSDL is appended

client = Client(url, transport=Transport(session=session))

try:
    result = client.service.MyOperation(serialNo="baz")
    print(result)
except Exception as e:
    print(f"An error occurred: {e}")

注意事项

  • WSDL URL: 确保提供的 URL 包含 ?WSDL 查询参数,以便 Zeep 能够正确解析服务的定义。
  • 身份验证: 使用 requests.Session 和 HTTPBasicAuth 来处理身份验证,确保提供正确的用户名和密码。
  • 异常处理: 使用 try...except 块来捕获潜在的异常,并打印有用的错误信息,方便调试。
  • 参数名称: 确保调用服务时使用的参数名称与 WSDL 定义中定义的参数名称完全匹配。
  • Zeep版本: 保持Zeep库为最新版本,以确保修复了已知的bug。

总结

当遇到 Zeep 报错 "Service not found" 时,首先应检查 URL 是否正确,包括是否包含 ?WSDL 参数。其次,确认身份验证配置正确。如果问题仍然存在,尝试升级 Zeep 库到最新版本。通过以上步骤,通常可以解决此问题,成功连接并调用 Business Central 的自定义 SOAP 服务。

相关专题

更多
session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

314

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

745

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

88

2025.08.19

github中文官网入口 github中文版官网网页进入
github中文官网入口 github中文版官网网页进入

github中文官网入口https://docs.github.com/zh/get-started,GitHub 是一种基于云的平台,可在其中存储、共享并与他人一起编写代码。 通过将代码存储在GitHub 上的“存储库”中,你可以: “展示或共享”你的工作。 持续“跟踪和管理”对代码的更改。

146

2026.01.21

vsd文件打开方法
vsd文件打开方法

vsd文件打开方法有使用Microsoft Visio软件、使用Microsoft Visio查看器、转换为其他格式等。想了解更多vsd文件相关内容,可以阅读本专题下面的文章。

484

2023.10.30

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

8

2026.01.22

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

51

2026.01.21

三角洲入口地址合集
三角洲入口地址合集

本专题整合了三角洲入口地址合集,阅读专题下面的文章了解更多详细内容。

27

2026.01.21

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

354

2026.01.21

热门下载

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

精品课程

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

共4课时 | 13.9万人学习

Django 教程
Django 教程

共28课时 | 3.4万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

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

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