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
<h1>连接服务端(假设服务运行在 <a href="https://www.php.cn/link/fcbb3a1c04ec11f1506563c26ca63774">https://www.php.cn/link/fcbb3a1c04ec11f1506563c26ca63774</a>)</h1><p>proxy = xmlrpc.client.ServerProxy('<a href="https://www.php.cn/link/fcbb3a1c04ec11f1506563c26ca63774">https://www.php.cn/link/fcbb3a1c04ec11f1506563c26ca63774</a>')</p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/00968c3c2c15" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">Python免费学习笔记(深入)</a>”;</p><h1>调用远程函数(如 add、get_user)</h1><p>result = proxy.add(3, 5)  # 返回 8
user = proxy.get_user(123)  # 返回字典,如 {'id': 123, 'name': 'Alice'}</p><h1>支持列表、字典、整数、字符串、布尔值、None、datetime、bytes(需 base64 编码)</h1><p>proxy.echo({'msg': 'hello', 'count': 2})
</p>

注意点:

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

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

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

简易服务端示例:

知鹿匠
知鹿匠

知鹿匠教师AI工具,新课标教案_AI课件PPT_作业批改

下载
from xmlrpc.server import SimpleXMLRPCServer
from xmlrpc.server import SimpleXMLRPCRequestHandler
<h1>仅允许 /RPC2 路径访问(可选安全限制)</h1><p>class RequestHandler(SimpleXMLRPCRequestHandler):
rpc_paths = ('/RPC2',)</p><h1>创建服务端(监听 localhost:8000)</h1><p>server = SimpleXMLRPCServer(('localhost', 8000), requestHandler=RequestHandler)
server.register_introspection_functions()  # 启用 system.listMethods 等调试方法</p><h1>注册函数(可直接注册普通函数)</h1><p>def add(x, y):
return x + y</p><p>def get_user(user_id):
return {'id': user_id, 'name': 'Test User', 'active': True}</p><p>server.register_function(add, 'add')
server.register_function(get_user, 'get_user')</p><h1>启动服务(阻塞式)</h1><p>print("XML-RPC server running on <a href="https://www.php.cn/link/fcbb3a1c04ec11f1506563c26ca63774/RPC2">https://www.php.cn/link/fcbb3a1c04ec11f1506563c26ca63774/RPC2</a>")
server.serve_forever()
</p>

关键细节:

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

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

客户端设置超时:

import xmlrpc.client
<p>class TimeoutTransport(xmlrpc.client.Transport):
def <strong>init</strong>(self, timeout=10, *args, *<em>kwargs):
self.timeout = timeout
super().<strong>init</strong>(</em>args, **kwargs)</p><pre class="brush:php;toolbar:false;">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,就能稳定跑起来。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

245

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

520

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

588

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

244

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

630

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3613

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

53

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

67

2026.01.13

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

4

2026.03.04

热门下载

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

精品课程

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

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.7万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.8万人学习

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

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