读取一个文件(RAW)
流式读取
-
接口描述
GET /read_file?filename=[URL编码的文件名] HTTP/1.1- 可选查询参数
md5=1:在响应头添加Content-MD5(Base64)
- 可选查询参数
-
可能的返回
- 成功:HTTP 200,响应体为文件内容字节流(非 base64 编码)
- 失败:
- HTTP 404 +
{"message":"File not found"}(文件不存在或未传 filename) - HTTP 415 +
{"message":"File is a directory"}(请求路径是目录)
- HTTP 404 +
-
通过接口流式读取设备脚本文件 Python 3.x 示例(需要 requests 模块):
# -*- coding: utf-8 -*-
import requests
with requests.get(
"http://192.168.31.72:46952/read_file",
params={"filename": "lua/scripts/123.lua", "md5": 1},
stream=True,
timeout=30,
) as r:
r.raise_for_status()
with open("r:/123.lua", "wb") as f:
for chunk in r.iter_content(chunk_size=8192):
if chunk:
f.write(chunk)
print("Content-MD5:", r.headers.get("Content-MD5"))
Base64 读取
-
接口描述
POST /read_file HTTP/1.1
{"filename":"文件名"} -
可能的返回
{"code":0,"message":"操作成功","data":"文件内容的 base64 编码字符串"}{"code":4,"message":"无法读取文件"}{"code":8,"message":"参数错误"} -
通过接口从设备读取脚本文件 Python 3.x 示例(需要 requests 模块):
# -*- coding: utf-8 -*-
import base64
import requests
resp = requests.post(
"http://192.168.31.72:46952/read_file",
json={"filename": "lua/scripts/123.lua"},
timeout=30,
)
print(resp.status_code, resp.reason) # 成功时 200 OK
if resp.status_code == 200:
ret = resp.json()
print(ret.get("message"))
if ret.get("code") == 0:
print(base64.b64decode(ret["data"]).decode("utf-8")) # 解码 base64 数据并显式解码为 UTF-8
else:
print(resp.text)
说明
- 该接口文件操作的根目录为
/var/mobile/Media/1ferver/ - 流式读取 接口
2025-07-11以后的版本可用