写入一个文件(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":"…"}
- HTTP 400 +
-
通过接口流式写入内容到设备脚本文件 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以后的版本可用