XML-RPC 是一个具体协议标准,非通用方法,需严格遵循 methodCall 结构、九种固定类型及传输规则,现代已基本弃用,仅存于遗留系统。

XML-RPC 不是“用 XML 进行远程过程调用”的通用方法,而是一个**具体协议标准**,有固定结构、方法名约定和传输规则。它早已被主流服务弃用,仅在遗留系统(如旧版 WordPress、某些嵌入式设备 API)中可见。
XML-RPC 的请求必须符合 methodCall 格式
客户端不能随便发一段 XML 就算调用;必须包裹在 根元素下,并严格包含 和 。参数类型也受限:只支持 string、i4、int、boolean、double、dateTime.iso8601、base64、array、struct 九种,没有 null、undefined、NaN 或自定义对象。
- 错误示例:
—— 这只是普通 XML,不是 XML-RPC 请求123 Alice - 正确结构:
metaWeblog.newPost 1 title Hello
Python 中用 xmlrpc.client 调用最稳妥
手动拼 XML 容易出错,且要处理 HTTP 头(Content-Type: text/xml、Content-Length)、编码、超时等细节。标准库 xmlrpc.client 自动完成序列化、HTTP POST、响应解析,还内置类型映射(如 Python datetime → dateTime.iso8601)。
- 必须用
ServerProxy初始化,URL 后缀通常为/RPC2或/xmlrpc.php - 方法调用直接写成
proxy.method_name(arg1, arg2),不需手动构造 XML - 服务器返回的
struct自动转为 Pythondict,array转为list - 遇到
Fault异常(如xmlrpc.client.Fault:)说明服务端拒绝,不是网络问题
import xmlrpc.clientproxy = xmlrpc.client.ServerProxy('https://www.php.cn/link/499a3f88156bb6321e00d0ff0ab55041') try: post_id = proxy.metaWeblog.newPost( '1', # blog_id 'admin', 'password', { 'title': 'First Post', 'description': '
Hello world
' }, True # publish ) print(f'Posted: {post_id}') except xmlrpc.client.Fault as e: print(f'Server error: {e.faultString}') # 直接拿到错误描述
Android配合WebService访问远程数据库 中文WORD版下载采用HttpClient向服务器端action请求数据,当然调用服务器端方法获取数据并不止这一种。WebService也可以为我们提供所需数据,那么什么是webService呢?,它是一种基于SAOP协议的远程调用标准,通过webservice可以将不同操作系统平台,不同语言,不同技术整合到一起。 实现Android与服务器端数据交互,我们在PC机器java客户端中,需要一些库,比如XFire,Axis2,CXF等等来支持访问WebService,但是这些库并不适合我们资源有限的android手机客户端,
常见失败原因不是 XML 写错,而是协议/认证层面卡住
90% 的“XML-RPC 调用失败”其实和 XML 无关,而是以下几类问题:
- HTTP 状态码非 200:比如 Nginx 返回 405(Method Not Allowed),因为 XML-RPC 只允许 POST,但服务器配置了拒绝 POST 到该路径
- SSL/TLS 不兼容:旧服务只支持 TLS 1.0/1.1,现代 Python 默认禁用;需显式设置
context=ssl.create_default_context(ssl.Purpose.CLIENT_AUTH)并降级 - 认证方式不匹配:WordPress XML-RPC 需用户密码,但有些系统要求 App Password 或 OAuth token,直接传账号密码会 403
-
防火墙或 CDN 拦截:Cloudflare 默认屏蔽
POST /xmlrpc.php(防爆破),需在 WAF 规则中放行
XML-RPC 的真正难点不在“怎么写 XML”,而在确认目标服务是否真接受它、用什么认证、走哪条路径、以及如何让现代客户端绕过 TLS 或代理限制。一旦握手成功,后续调用反而比 REST 更机械——毕竟连 URL 路由都省了,全靠 methodName 字符串分发。










