跳到主要内容

读取一个文件(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"}(请求路径是目录)
  • 通过接口流式读取设备脚本文件 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 以后的版本可用