0

0

SOAP是什么 如何用XML构建Web服务消息

畫卷琴夢

畫卷琴夢

发布时间:2026-01-25 09:13:50

|

219人浏览过

|

来源于php中文网

原创

SOAP是用XML定义的标准化消息协议,核心结构为Envelope、Header、Body三要素缺一不可,严格依赖命名空间、层级和编码规范,手写XML有助于排查生成器无法覆盖的底层兼容性问题。

soap是什么 如何用xml构建web服务消息

SOAP 是一种用 XML 写成的、有固定结构的网络消息协议,不是“一种 Web 服务”,而是“怎么把 Web 服务调用打包成消息”的标准方式。它靠 EnvelopeHeaderBody 这三块强制结构保证不同系统能统一解析——不是靠人读得懂,而是靠机器按规则校验。

SOAP 消息必须长这样:三要素缺一不可

一个合法的 SOAP 请求 XML 不是随便套个 soap:Envelope 标签就行,命名空间、嵌套层级、甚至是否带 XML 声明都有硬性限制:

  • Envelope 必须是根元素,且声明 xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" —— 错写成 http://www.w3.org/2003/05/soap-envelope(SOAP 1.2)会导致 .NET 客户端直接拒绝解析
  • Header 可省略,但一旦出现,所有中间节点(比如 API 网关)若看到 mustUnderstand="1" 属性却无法处理,就必须返回 Fault 中断流程
  • Body 内不能直接放业务数据,必须包裹在服务定义的操作名标签里,例如 GetUserRequest,且该标签需声明业务命名空间(如 xmlns="http://example.com/user"),否则 Java JAX-WS 会反序列化失败
  • 严禁出现 处理指令或 DTD 声明 —— 即使工具自动生成了,也得手动删掉,否则 Axis2 报错 org.xml.sax.SAXParseException: Content is not allowed in prolog

手写 SOAP XML 的典型错误场景

很多开发者以为“照着 WSDL 改几个值就行”,结果卡在 HTTP 200 但 Body 返回空或 Fault。常见原因:

  • WSDL 里定义的是 tns:UserId,你写了 UserId —— 缺少命名空间前缀,服务端当成未知字段丢弃
  • 参数类型是 xsd:dateTime,你传了 "2026-01-14"(没带时间+时区),Java CXF 直接抛 XMLGregorianCalendar 解析异常
  • HTTP Header 没设 Content-Type: text/xml; charset=utf-8,或漏了 SOAPAction(老式 ASP.NET ASMX 服务强制要求)
  • 用 Python requests.post() 发送时,把 XML 当字符串传给 data=,却忘了加 headers={"Content-Type": "text/xml"},导致服务端当普通表单处理

用 Python requests 手动发一个可用的 SOAP 请求

不依赖 zeep 或 suds,只用最简依赖验证通路是否跑通(调试阶段极有用):

图星人
图星人

好用的AI生图工具,百万免费商用图库

下载


  
    
      1001
    
  

发送代码:

import requests

url = "https://www.php.cn/link/8aecd51d6d87cc8f1ceed1134cc06934" headers = { "Content-Type": "text/xml; charset=utf-8", "SOAPAction": '"https://www.php.cn/link/52d4d7e63ba0b34da02046be3a5ab5d3"' # 注意引号和动作URI } response = requests.post(url, data=soap_xml_string.encode("utf-8"), headers=headers) print(response.status_code) print(response.text) # 查看原始响应,别急着 xml.etree.ElementTree 解析

为什么现在还值得学手写 SOAP XML?

因为真实故障往往发生在生成器“看不见”的地方:

  • WSDL 自动生成的客户端把 xs:decimal 转成 Python float,精度丢失后银行系统拒收;手写 XML 可控地传 "123.4500" 字符串
  • 网关需要在 Header 插入 WS-Security 时间戳和签名,zeep 默认不支持,必须手动拼接
  • 某政务系统要求 Body 内操作名首字母小写(getUserRequest),但 WSDL 工具一律转大写,只能绕过代理手写

真正难的从来不是语法,而是服务端对 XML 结构、命名空间、编码细节的隐式要求——这些只在你亲手构造并逐字比对响应时才会暴露。

相关专题

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

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

773

2023.06.15

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

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

684

2023.07.20

python能做什么
python能做什么

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

766

2023.07.25

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

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

719

2023.07.31

python教程
python教程

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

1425

2023.08.03

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

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

570

2023.08.04

python eval
python eval

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

579

2023.08.04

scratch和python区别
scratch和python区别

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

751

2023.08.11

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

25

2026.01.23

热门下载

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

精品课程

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

共4课时 | 19.3万人学习

Django 教程
Django 教程

共28课时 | 3.5万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

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

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