0

0

Python的xmlrpc库怎么用 XML-RPC客户端和服务端

畫卷琴夢

畫卷琴夢

发布时间:2025-12-27 08:28:02

|

542人浏览过

|

来源于php中文网

原创

Python的xmlrpc库提供轻量级RPC实现,基于XML和HTTP,适合简单跨语言通信;客户端用ServerProxy调用远程方法,服务端需注册函数并支持基础类型,推荐ThreadingXMLRPCServer并发。

python的xmlrpc库怎么用 xml-rpc客户端和服务端

Python 的 xmlrpc 库(即 xmlrpc.clientxmlrpc.server)是标准库中轻量级的远程过程调用(RPC)实现,适合简单跨语言通信或内部工具集成。它基于 XML 编码和 HTTP 传输,虽不如 REST 或 gRPC 现代,但部署简单、无需额外依赖。

XML-RPC 客户端:调用远程方法

使用 xmlrpc.client.ServerProxy 连接服务端,像调用本地函数一样调用远程方法。

基本用法示例:

import xmlrpc.client

连接服务端(假设服务运行在 https://www.php.cn/link/fcbb3a1c04ec11f1506563c26ca63774

proxy = xmlrpc.client.ServerProxy('https://www.php.cn/link/fcbb3a1c04ec11f1506563c26ca63774')

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

调用远程函数(如 add、get_user)

result = proxy.add(3, 5) # 返回 8 user = proxy.get_user(123) # 返回字典,如 {'id': 123, 'name': 'Alice'}

支持列表、字典、整数、字符串、布尔值、None、datetime、bytes(需 base64 编码)

proxy.echo({'msg': 'hello', 'count': 2})

注意点:

  • URL 必须带协议(http://https://),否则报错
  • 服务端未启动或网络不通时,首次调用会抛出 ConnectionRefusedErrorxmlrpc.client.ProtocolError
  • 若服务端返回结构复杂(如嵌套类实例),客户端只收到字典/列表等基础类型 —— XML-RPC 不支持任意 Python 对象序列化
  • 如需超时控制,可传入 transport 参数自定义(见下文进阶用法)

XML-RPC 服务端:发布可调用函数

Python 提供两种常用服务端:单线程的 SimpleXMLRPCServer(Python 3.9+ 已弃用)和推荐的 xmlrpc.server.SimpleXMLRPCServer(兼容旧版写法);新项目建议用 ThreadingXMLRPCServer 支持并发。

简易服务端示例:

RoomGPT
RoomGPT

使用AI为每个人创造梦想的房间

下载
from xmlrpc.server import SimpleXMLRPCServer
from xmlrpc.server import SimpleXMLRPCRequestHandler

仅允许 /RPC2 路径访问(可选安全限制)

class RequestHandler(SimpleXMLRPCRequestHandler): rpc_paths = ('/RPC2',)

创建服务端(监听 localhost:8000)

server = SimpleXMLRPCServer(('localhost', 8000), requestHandler=RequestHandler) server.register_introspection_functions() # 启用 system.listMethods 等调试方法

注册函数(可直接注册普通函数)

def add(x, y): return x + y

def get_user(user_id): return {'id': user_id, 'name': 'Test User', 'active': True}

server.register_function(add, 'add') server.register_function(get_user, 'get_user')

启动服务(阻塞式)

print("XML-RPC server running on https://www.php.cn/link/fcbb3a1c04ec11f1506563c26ca63774/RPC2") server.serve_forever()

关键细节:

  • 必须显式调用 register_function() 才能让客户端发现并调用该函数
  • register_introspection_functions() 开启内省能力(如 system.listMethods),方便调试
  • 默认不支持多线程,高并发场景请改用 ThreadingXMLRPCServer(继承自同名类,用法一致)
  • 函数参数和返回值受限于 XML-RPC 类型系统(不支持 set、tuple、自定义类等)

进阶技巧:超时、认证与自定义类型

客户端设置超时:

import xmlrpc.client

class TimeoutTransport(xmlrpc.client.Transport): def init(self, timeout=10, *args, *kwargs): self.timeout = timeout super().init(args, **kwargs)

def make_connection(self, host):
    conn = super().make_connection(host)
    conn.timeout = self.timeout
    return conn

proxy = xmlrpc.client.ServerProxy( 'https://www.php.cn/link/fcbb3a1c04ec11f1506563c26ca63774', transport=TimeoutTransport(timeout=5) )

基础认证(HTTP Basic Auth):

  • 服务端需配合 Web 服务器(如 Nginx/Apache)做认证,或自行在 handler 中解析 Authorization
  • 客户端 URL 写成 http://user:pass@localhost:8000/RPC2 即可自动携带凭证(注意密码需 URL 编码)

处理 bytes 和 datetime:

  • bytes 会被自动 base64 编码传输,客户端接收后仍是 bytes
  • datetime.datetime 对象可直接传递,服务端和客户端均能正确识别(前提是双方都用 Python xmlrpc 实现)

常见问题与替代建议

典型报错:

  • xmlrpc.client.Fault:服务端抛出异常,错误信息在 faultString
  • xmlrpc.client.ProtocolError:HTTP 状态非 200(如 404、500)、响应非 XML 格式
  • ExpatError:服务端返回了非法 XML(常见于日志打印干扰响应体)

是否还该用 XML-RPC?

  • 适合:内网小工具、遗留系统对接、教学演示、极简 API(无 JSON/HTTPS/路由需求)
  • 不推荐:新项目对外 API、需要 RESTful 设计、需 OpenAPI 文档、要求高性能或流式传输
  • 现代替代:Flask/FastAPI + JSON + HTTP(更通用)、gRPC(强类型+高效)、ZeroMQ(去中心化)

不复杂但容易忽略 —— 把好类型边界、加好超时、打开 introspection,就能稳定跑起来。

相关专题

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

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

708

2023.06.15

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

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

625

2023.07.20

python能做什么
python能做什么

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

736

2023.07.25

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

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

616

2023.07.31

python教程
python教程

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

1234

2023.08.03

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

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

547

2023.08.04

python eval
python eval

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

573

2023.08.04

scratch和python区别
scratch和python区别

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

695

2023.08.11

虚拟号码教程汇总
虚拟号码教程汇总

本专题整合了虚拟号码接收验证码相关教程,阅读下面的文章了解更多详细操作。

25

2025.12.25

热门下载

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

精品课程

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

共4课时 | 0.6万人学习

Django 教程
Django 教程

共28课时 | 2.5万人学习

SciPy 教程
SciPy 教程

共10课时 | 0.9万人学习

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

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