0

0

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

煙雲

煙雲

发布时间:2026-01-25 10:10:57

|

226人浏览过

|

来源于php中文网

原创

Python的xmlrpc库基于XML和HTTP实现轻量级RPC,服务端用xmlrpc.server(原SimpleXMLRPCServer),支持线程安全与introspection;客户端用ServerProxy调用远程方法,需注意路径、方法名及类型限制。

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

Python 的 xmlrpc 库(标准库中的 xmlrpc.clientxmlrpc.server)用于实现轻量级的远程过程调用(RPC),基于 XML 编码和 HTTP 传输。它适合简单服务交互,无需复杂协议或依赖第三方包。

XML-RPC 服务端:用 SimpleXMLRPCServer(Python 3.12+ 已弃用,推荐用 xmlrpc.server)

Python 3.3+ 中,SimpleXMLRPCServer 已移入 xmlrpc.server 模块,且支持线程安全(默认单线程,可搭配 ThreadingMixIn 支持并发)。

示例服务端(支持加法、获取时间):

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

from xmlrpc.server import SimpleXMLRPCServer
from xmlrpc.server import SimpleXMLRPCRequestHandler
import datetime
<h1>可选:限制只响应特定路径(增强安全性)</h1><p>class RequestHandler(SimpleXMLRPCRequestHandler):
rpc_paths = ('/RPC2',)</p><p>def add(x, y):
return x + y</p><p>def get_time():
return datetime.datetime.now().isoformat()</p><h1>创建服务器,监听本地 8000 端口</h1><p>server = SimpleXMLRPCServer(('localhost', 8000), requestHandler=RequestHandler)
server.register_function(add, 'calc.add')
server.register_function(get_time, 'system.time')</p><h1>可选:注册内置系统方法(如 system.listMethods)</h1><p>server.register_introspection_functions()</p><p>print("XML-RPC server running on <a href="https://www.php.cn/link/464d0b9d99efb7a4595380d03b7ea164">https://www.php.cn/link/464d0b9d99efb7a4595380d03b7ea164</a>")
try:
server.serve_forever()
except KeyboardInterrupt:
print("\nShutting down server.")

说明:

PatentPal专利申请写作
PatentPal专利申请写作

AI软件来为专利申请自动生成内容

下载
  • register_function(func, name) 将函数暴露为远程可调用方法,name 是客户端调用时用的名称(如 calc.add
  • register_introspection_functions() 启用 system.listMethodssystem.methodHelp 等调试方法
  • 若需多线程处理并发请求,可继承 ThreadingMixIn
from socketserver import ThreadingMixIn
<p>class ThreadedXMLRPCServer(ThreadingMixIn, SimpleXMLRPCServer):
pass</p><p>server = ThreadedXMLRPCServer(('localhost', 8000'))

XML-RPC 客户端:用 xmlrpc.client.ServerProxy

客户端通过 URL 创建代理对象,像调用本地函数一样调用远程方法。

import xmlrpc.client
<h1>连接服务端(注意路径 /RPC2 必须和服务端一致)</h1><p>proxy = xmlrpc.client.ServerProxy('<a href="https://www.php.cn/link/464d0b9d99efb7a4595380d03b7ea164">https://www.php.cn/link/464d0b9d99efb7a4595380d03b7ea164</a>')</p><h1>调用远程方法(自动序列化/反序列化)</h1><p>result = proxy.calc.add(10, 20)
print("10 + 20 =", result)  # 输出:10 + 20 = 30</p><p>time_str = proxy.system.time()
print("Server time:", time_str)</p><h1>查看可用方法(需服务端启用了 introspection)</h1><p>methods = proxy.system.listMethods()
print("Available methods:", methods)

关键点:

  • URL 必须包含完整路径(如 /RPC2),否则会返回 404
  • 方法名按点号层级调用(proxy.calc.add 对应服务端注册的 'calc.add'
  • 支持基本类型:int、float、str、bool、list、dict、datetime(自动转为 ISO 格式字符串)、None
  • 不支持自定义类、函数、字节流等;二进制数据需用 xmlrpc.client.Binary 包装

传输二进制数据(如图片、文件内容)

XML-RPC 原生不支持 raw bytes,需用 Binary 类封装:

# 服务端增加方法
def upload_data(data_bin):
    data = data_bin.data  # 获取 bytes
    print(f"Received {len(data)} bytes")
    return len(data)
<p>server.register_function(upload_data, 'file.upload')</p><h1>客户端调用</h1><p>with open('test.bin', 'rb') as f:
binary_data = xmlrpc.client.Binary(f.read())
proxy.file.upload(binary_data)

常见问题与注意事项

  • Python 版本差异:Python 3.12+ 已完全移除 SimpleXMLRPCServer 别名,必须从 xmlrpc.server 导入
  • 异常处理:网络错误或服务端异常会抛出 xmlrpc.client.FaultConnectionError,建议 try/except 包裹调用
  • 编码限制:所有字符串必须是 UTF-8 兼容(Python str 默认满足),含控制字符可能失败
  • 性能与替代方案:XML-RPC 解析较慢,不适用于高频或大数据量场景;现代项目更倾向 REST(Flask/FastAPI)或 gRPC

不复杂但容易忽略:确保服务端和客户端使用相同路径、方法名大小写一致、参数类型在 XML-RPC 支持范围内。调试时先用 system.listMethods 确认接口可达。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
Python Flask框架
Python Flask框架

本专题专注于 Python 轻量级 Web 框架 Flask 的学习与实战,内容涵盖路由与视图、模板渲染、表单处理、数据库集成、用户认证以及RESTful API 开发。通过博客系统、任务管理工具与微服务接口等项目实战,帮助学员掌握 Flask 在快速构建小型到中型 Web 应用中的核心技能。

106

2025.08.25

Python Flask Web框架与API开发
Python Flask Web框架与API开发

本专题系统介绍 Python Flask Web框架的基础与进阶应用,包括Flask路由、请求与响应、模板渲染、表单处理、安全性加固、数据库集成(SQLAlchemy)、以及使用Flask构建 RESTful API 服务。通过多个实战项目,帮助学习者掌握使用 Flask 开发高效、可扩展的 Web 应用与 API。

81

2025.12.15

Python FastAPI异步API开发_Python怎么用FastAPI构建异步API
Python FastAPI异步API开发_Python怎么用FastAPI构建异步API

Python FastAPI 异步开发利用 async/await 关键字,通过定义异步视图函数、使用异步数据库库 (如 databases)、异步 HTTP 客户端 (如 httpx),并结合后台任务队列(如 Celery)和异步依赖项,实现高效的 I/O 密集型 API,显著提升吞吐量和响应速度,尤其适用于处理数据库查询、网络请求等耗时操作,无需阻塞主线程。

28

2025.12.22

Python 微服务架构与 FastAPI 框架
Python 微服务架构与 FastAPI 框架

本专题系统讲解 Python 微服务架构设计与 FastAPI 框架应用,涵盖 FastAPI 的快速开发、路由与依赖注入、数据模型验证、API 文档自动生成、OAuth2 与 JWT 身份验证、异步支持、部署与扩展等。通过实际案例,帮助学习者掌握 使用 FastAPI 构建高效、可扩展的微服务应用,提高服务响应速度与系统可维护性。

253

2026.02.06

css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

595

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

108

2025.10.23

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

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

1949

2024.04.01

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

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

2119

2024.08.01

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 5万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

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

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