跳到主要内容

写入一个文件(RAW)

流式写入

  • 接口描述

    PUT /write_file?filename=[URL编码的文件名] HTTP/1.1

    [文件数据]
    • 直接接收文件字节流(非 base64 编码),适用于大文件上传
    • 若目标文件已存在会被覆盖
  • 可能的返回

    • 成功:HTTP 204,无响应体
    • 失败:
      • HTTP 400 + {"message":"invalid path"}(未提供 filename 或路径非法)
      • HTTP 404 + {"message":"invalid path"}(无法创建目标路径)
      • HTTP 500 + {"message":"…"}
  • 通过接口流式写入内容到设备脚本文件 Python 3.x 示例(需要 requests 模块):

    # -*- coding: utf-8 -*-
    import requests

    with open("r:/123.lua", "rb") as f:
    resp = requests.put("http://192.168.31.72:46952/write_file", params={"filename": "lua/scripts/123.lua"}, data=f, timeout=30)

    print(resp.status_code, resp.reason) # 成功时 204 No Content
    if resp.status_code != 204:
    print(resp.text)

Base64 写入

  • 接口描述

    POST /write_file HTTP/1.1

    {"filename":"文件名","data":"内容的 base64 编码字符串"}
  • 可能的返回

    {"code":0,"message":"操作成功"}
    {"code":4,"message":"无法写入文件"}
  • 通过接口写入内容到设备脚本文件 Python 3.x 示例(需要 requests 模块):

    # -*- coding: utf-8 -*-
    import base64
    import requests

    with open('r:/123.lua', 'rb') as f: # 脚本文件路径,直接读取字节
    resp = requests.post(
    "http://192.168.31.72:46952/write_file",
    json={
    "filename": "lua/scripts/123.lua",
    "data": base64.b64encode(f.read()).decode('utf-8') # 直接对字节做 base64 编码
    },
    timeout=30,
    )

    print(resp.status_code, resp.reason) # 成功时 200 OK
    print(resp.text)

说明

  • 该接口文件操作的根目录为 /var/mobile/Media/1ferver/
  • 流式写入 接口 2025-07-11 以后的版本可用