0

0

如何处理SOAP with Attachments (SwA)中的XML上传

畫卷琴夢

畫卷琴夢

发布时间:2026-01-21 11:20:53

|

907人浏览过

|

来源于php中文网

原创

SwA上传失败主因是Content-Type配置错误:必须用multipart/related包装,主XML部分Content-Type须为text/xml或application/soap+xml,且start-info参数需显式指定,各part的Content-ID须含尖括号并严格匹配SOAP中cid引用。

如何处理soap with attachments (swa)中的xml上传

SwA上传失败时常见的Content-Type错误

SwA不是普通XML POST,必须用multipart/related包装,且主XML部分的Content-Type必须是text/xmlapplication/soap+xml,不能是application/xml。常见错误是直接把SOAP XML当纯文本POST,导致服务端解析出Invalid MIME structureMissing start-info parameter

  • start-info参数必须显式指定,例如:Content-Type: multipart/related; type="text/xml"; start=""; boundary="uuid:12345"
  • 每个part需带Content-ID头,格式为(尖括号不可省略)
  • 附件part的Content-Transfer-Encoding建议用base64,避免二进制乱码

Python中用requests构造SwA请求的关键步骤

标准requests.post()不支持原生SwA,需手动拼接multipart body。核心是控制boundary、start-info和各part的headers顺序。

import requests

soap_xml = '''

  
    
      
    
  
'''

with open("report.pdf", "rb") as f:
    pdf_data = f.read()

boundary = "uuid:abc123"
start = ""

body = (
    f"--{boundary}\r\n"
    'Content-Type: text/xml; charset=utf-8\r\n'
    f'Content-Transfer-Encoding: 8bit\r\n'
    f'Content-ID: {start}\r\n\r\n'
    f"{soap_xml}\r\n"
    f"--{boundary}\r\n"
    'Content-Type: application/pdf\r\n'
    'Content-Transfer-Encoding: base64\r\n'
    'Content-ID: \r\n\r\n'
    + base64.b64encode(pdf_data).decode() + "\r\n"
    f"--{boundary}--\r\n"
)

headers = {
    "Content-Type": f'multipart/related; type="text/xml"; start="{start}"; boundary="{boundary}"',
    "SOAPAction": '"http://example.com/UploadDocument"'
}

response = requests.post("https://api.example.com/soap", headers=headers, data=body)

Java(Apache Axis2)里AttachmentUtils的典型误用

Axis2自带org.apache.axis2.attachments.Attachments,但很多人直接传入FileDataSource而忽略Content-ID一致性。关键点在于:SOAP body中引用的cid:必须与附件part的Content-ID完全匹配(包括大小写和空格)。

虎课网
虎课网

虎课网是超过1800万用户信赖的自学平台,拥有海量设计、绘画、摄影、办公软件、职业技能等优质的高清教程视频,用户可以根据行业和兴趣爱好,自主选择学习内容,每天免费学习一个...

下载
  • 不要用new DataHandler(new FileDataSource("x.pdf"))后直接addAttachment()——它会自动生成随机Content-ID,无法与SOAP中硬编码对齐
  • 正确做法是先创建javax.activation.DataHandler,再调用setContentType("application/pdf")setContentID("")
  • Axis2默认启用SwA,但若服务端返回HTTP 415 Unsupported Media Type,检查是否启用了messageBuilder配置:application/soap+xml对应org.apache.axis2.builder.SOAPBuilder

调试SwA请求时必须检查的三个原始响应头

服务端拒绝SwA请求时,HTTP状态码往往掩盖了真实问题。真正线索藏在响应头里:

  • Content-Type是否返回multipart/related?如果不是,说明服务端未识别SwA,可能因start-info缺失或boundary不匹配
  • X-SOAP-Error(某些厂商自定义头)常含Invalid attachment reference: cid:xxx,意味着SOAP body里的cid:没在附件part中找到对应Content-ID
  • Connectionclose且无Content-Length,大概率是multipart body末尾少了一个--{boundary}--,导致服务端等待更多数据超时

SwA的麻烦不在逻辑,而在每个header字段的字面精确性——少一个尖括号、多一个空格、大小写错位,都会让整个请求静默失败。

相关专题

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

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

769

2023.06.15

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

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

661

2023.07.20

python能做什么
python能做什么

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

764

2023.07.25

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

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

639

2023.07.31

python教程
python教程

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

1325

2023.08.03

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

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

549

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相关的文章、下载、课程内容,供大家免费下载体验。

709

2023.08.11

Java编译相关教程合集
Java编译相关教程合集

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

5

2026.01.21

热门下载

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

精品课程

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

共4课时 | 9.5万人学习

Django 教程
Django 教程

共28课时 | 3.3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

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

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