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数量超过这个限制时,最新的会覆盖最早的等等。

307

2023.10.17

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

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

732

2023.10.18

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

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

88

2025.08.19

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

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

479

2023.10.30

php与html混编教程大全
php与html混编教程大全

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

1

2026.01.13

PHP 高性能
PHP 高性能

本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

5

2026.01.13

MySQL数据库报错常见问题及解决方法大全
MySQL数据库报错常见问题及解决方法大全

本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

6

2026.01.13

PHP 文件上传
PHP 文件上传

本专题整合了PHP实现文件上传相关教程,阅读专题下面的文章了解更多详细内容。

5

2026.01.13

PHP缓存策略教程大全
PHP缓存策略教程大全

本专题整合了PHP缓存相关教程,阅读专题下面的文章了解更多详细内容。

3

2026.01.13

热门下载

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

精品课程

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

共4课时 | 0.6万人学习

Django 教程
Django 教程

共28课时 | 3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.1万人学习

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

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