0

0

XML文件如何通过SoapClient调用 PHP调用SOAP接口

煙雲

煙雲

发布时间:2026-02-28 11:09:45

|

384人浏览过

|

来源于php中文网

原创

soapclient 不直接读取 xml 文件,仅通过 wsdl 或非 wsdl 模式生成/发送 soap 请求;复用已有 xml 需重写 __dorequest() 或改用 curl 直接发送。

xml文件如何通过soapclient调用 php调用soap接口

PHP 的 SoapClient 不直接读 XML 文件

你手头有个 xxx.xml,想“用它调用 SOAP 接口”——这本身是个误解。SoapClient 不解析或加载外部 XML 请求体;它根据 WSDL(或手动配置)生成符合 SOAP 协议的请求,底层自动序列化参数、拼装信封。所谓“用 XML 调用”,实际只有两种可行路径:一是让 SoapClient 生成请求后拦截/替换为你的 XML,二是绕过 SoapClient 直接发 HTTP POST。

常见错误现象:Fatal error: Uncaught SoapFault exception 或返回 HTTP 500,但服务端日志显示“无效的 SOAP Envelope”,往往是因为手动拼的 XML 缺少命名空间、SOAP-ENV:Envelope 结构错位,或编码不匹配。

  • WSDL 模式下,SoapClient 会严格校验参数类型和结构,传入任意 XML 字符串会直接报 SOAP-ERROR: Encoding: object has no 'xxx' property
  • 非 WSDL 模式(即构造时传 NULL 作第一个参数)可跳过 WSDL 校验,但必须手动指定 locationuri,否则请求发不到正确地址
  • XML 中的命名空间前缀(如 ns1:)必须与服务端期望完全一致,大小写敏感,漏一个冒号就失败

__doRequest() 拦截并注入自定义 XML

这是最贴近“用已有 XML 调用”的方案:继承 SoapClient,重写 __doRequest(),在发送前把默认生成的 XML 替换为你自己的。

使用场景:你已调试好一份能被服务端接受的 XML(比如用 SoapUI 测试通过),现在想在 PHP 中复用它,同时保留 SoapClient 的连接管理、SSL 处理等能力。

立即学习PHP免费学习笔记(深入)”;

关键点在于:重写方法必须返回服务端响应的原始 XML 字符串,不能做任何 DOM 解析或修改,否则 SoapClient 内部解析会失败。

aspx1财付通支付接口源码
aspx1财付通支付接口源码

本支付接口的特点,主要是用xml文件来记录订单详情和支付详情。代码比较简单,只要将里面的商户号、商户key换成你自己的,将回调url换成你的网站,就可以使用了。通过这个实例也可以很好的了解一般在线支付接口的基本工作原理。其中的pay.config文件记录的是支付详情,order.config是订单详情

下载
  • 构造子类时,__soapCall() 的第一个参数(方法名)可以是任意字符串(如 'dummy'),因为真实请求体已被替换
  • 你的 XML 必须包含完整的 SOAP-ENV:Envelope,且根节点的 xmlns:SOAP-ENV 声明要和服务端 WSDL 一致(常为 http://schemas.xmlsoap.org/soap/envelope/http://www.w3.org/2003/05/soap-envelope
  • 如果服务端要求 Content-Type: text/xml; charset=utf-8,需在 __doRequest() 中显式设置,PHP 默认可能发 application/soap+xml
class CustomSoapClient extends SoapClient
{
    private $customXml;

    public function __construct($wsdl, $options, $xml)
    {
        parent::__construct($wsdl, $options);
        $this->customXml = $xml;
    }

    public function __doRequest($request, $location, $action, $version, $oneWay = 0)
    {
        $headers = [
            "POST {$location} HTTP/1.1",
            "Content-Type: text/xml; charset=utf-8",
            "SOAPAction: {$action}",
            "Content-Length: " . strlen($this->customXml),
        ];
        $response = $this->sendHttpRequest(implode("\r\n", $headers) . "\r\n\r\n" . $this->customXml, $location);
        return $response;
    }

    private function sendHttpRequest($data, $url)
    {
        $ch = curl_init();
        curl_setopt($ch, CURLOPT_URL, $url);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
        curl_setopt($ch, CURLOPT_POST, true);
        curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
        curl_setopt($ch, CURLOPT_HTTPHEADER, ['Expect:']);
        $result = curl_exec($ch);
        curl_close($ch);
        return $result;
    }
}

不用 SoapClient,直接 cURL 发送 XML

如果你的 XML 已验证有效,且不需要 WSDL 解析、类型映射、故障重试等高级功能,直接 cURL 更轻量、更可控。

性能影响:省去 SoapClient 初始化开销(尤其是 WSDL 解析),但失去内置的 SOAP 错误码映射(如把 SOAP-FAULT 自动转成 SoapFault 异常)。

容易踩的坑集中在 HTTP 头和编码:

  • SOAPAction 头不是可选的——某些老服务(尤其 .NET ASMX)强制校验,值必须和 WSDL 中 soap:operationsoapAction 属性一致,空字符串或缺失都会拒收
  • XML 字符串必须是 UTF-8 编码,且声明中写 <?xml version="1.0" encoding="UTF-8"?>;如果源 XML 是 GBK,mb_convert_encoding($xml, 'UTF-8', 'GBK') 必须做
  • cURL 默认启用 Expect: 100-continue,部分 SOAP 服务不支持,需加 curl_setopt($ch, CURLOPT_HTTPHEADER, ['Expect:']) 清空

WSDL 地址返回 404 或解析失败怎么办

很多企业 SOAP 接口的 WSDL 是内网地址、带鉴权,或动态生成(如 ?wsdl 后缀被防火墙拦截)。此时硬依赖 SoapClient($wsdl) 必然失败。

解决思路不是“怎么修 WSDL”,而是绕过它:

  • 用浏览器或 curl -v http://example.com/service?wsdl 确认能否拿到完整 XML;拿不到就别走 WSDL 模式
  • 非 WSDL 模式下,location 必须是真实的 SOAP 端点 URL(通常是 http://...,不是 ?wsdl 地址),uri 是目标命名空间(看 WSDL 的 targetNamespace,或抓包看请求里 xmlns:tns="..."
  • 如果连 WSDL 都看不到,唯一办法是联系对接方索要接口文档,或用 Wireshark 抓其他客户端发出的真实请求,反推命名空间和动作名

真正麻烦的永远不是语法,而是服务端对命名空间、SOAP 版本(1.1 vs 1.2)、HTTP 头的隐性要求——这些几乎从不写在文档里,只能靠抓包比对。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

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

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

248

2023.09.22

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

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

927

2024.03.01

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

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

1936

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2112

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1141

2024.11.28

curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

452

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

183

2023.10.30

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

391

2023.10.18

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

0

2026.02.28

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 12.6万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

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

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