0

0

Web Service上传附件 SOAP带附件的XML传输协议

星降

星降

发布时间:2026-02-12 09:26:02

|

241人浏览过

|

来源于php中文网

原创

MTOM是SOAP上传附件的唯一标准方案,它将二进制附件分离为独立MIME part,XML仅保留xop:Include引用;需WSDL声明mtom="true"、客户端服务端均启用MTOM并配置对应拦截器或编码方式,缺一不可。

web service上传附件 soap带附件的xml传输协议

SOAP 上传附件时,MTOM 是唯一靠谱的选择

不用 MTOM,硬塞二进制进 XML 字符串(比如 base64),基本等于自找麻烦:体积膨胀约 33%,解析慢,内存爆得快,服务端还可能直接拒收超长 text 节点。SOAP 协议本身不传文件,MTOM(Message Transmission Optimization Mechanism)才是 W3C 标准里专门干这事的机制——它把附件抽成独立的二进制 part,XML 只留个 xop:Include 引用。

实操建议:

  • 客户端和服务端必须同时启用 MTOM,光一端开没用;检查 WSDL 里有没有 mtom="true"type="application/xop+xml"
  • Java Axis2 / CXF 默认关 MTOM,得显式设 binding.setMTOMEnabled(true);.NET 的 BasicHttpBinding 要配 messageEncoding="Mtom"
  • 别手动拼 multipart/related 请求体——所有主流 SOAP 库(如 Python 的 zeep、Java 的 jaxws-ri)都内置 MTOM 支持,调用时传 bytesFile 对象即可,库自动拆包

Attachment 在 SOAP 消息里根本不存在

这是最常被文档带偏的点:WSDL 和 SOAP 规范里压根没有叫 Attachment 的元素或类型。所谓“附件”,只是 MTOM 封装后 HTTP body 里的一个独立 MIME part,XML 正文里只出现类似这样的占位符:。如果你在 XML 中硬加了个 ... 节点,那只是普通字符串字段,不是附件。

常见错误现象:

  • 服务端收到的是 base64 编码的长字符串,而不是原始文件流
  • 用 Wireshark 抓包发现 HTTP body 是纯文本 XML,没看到 multipart/related boundary
  • WSDL 中 xs:base64Binary 类型字段被当成普通参数传,实际走的是 XML 内联编码,不是 MTOM

Python zeep 传文件必须用 requests 会话 + MTOM 绑定

zeep 默认用 httpx,但 MTOM 支持依赖底层 HTTP client 对 multipart 的正确构造。requests 更稳,且需手动指定传输绑定。

Visily
Visily

适合每个人的UI设计工具,支持草图转原型图、截图转线框图以及文生图

下载

实操建议:

  • 创建 client 时传 transport=Transport(session=requests.Session())
  • 确保 WSDL 地址返回的 binding 包含 mtom="true",否则 zeep 会 fallback 到文本模式
  • 调用方法时,附件字段直接传 open("file.pdf", "rb").read()io.BytesIO(data),别转成 base64 字符串
  • 如果报错 ValueError: Cannot serialize bytes object,说明 zeep 没识别出 MTOM,回头检查 WSDL 或强制指定 plugins=[WsdlPlugin()]

Java CXF 客户端收不到附件?先看 AttachmentInInterceptor 是否注册

CXF 默认不解析入站的 MTOM part,需要显式加拦截器,否则 javax.activation.DataHandler 字段永远是 null。

关键配置点:

  • 客户端代码里加:client.getOutInterceptors().add(new org.apache.cxf.interceptor.AttachmentOutInterceptor());
  • 服务端对应要加:server.getInInterceptors().add(new org.apache.cxf.interceptor.AttachmentInInterceptor());
  • 如果用 Spring 配置,确认 cxf.xml 里有
  • 调试时打印 message.getAttachments(),为空就说明拦截器没生效,跟 WSDL 或 binding 无关
事情说清了就结束。MTOM 不是开关,是整条链路的契约——WSDL、binding、client、server、HTTP 层,缺一不可。最容易被忽略的是服务端拦截器和客户端传输绑定的匹配,这两个点卡住,其他全对也白搭。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

120

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

77

2026.01.26

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

243

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

685

2024.03.01

session失效的原因
session失效的原因

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

325

2023.10.17

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

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

771

2023.10.18

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

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

96

2025.08.19

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1926

2024.04.01

2026春节习俗大全
2026春节习俗大全

本专题整合了2026春节习俗大全,阅读专题下面的文章了解更多详细内容。

180

2026.02.11

热门下载

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

精品课程

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

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