A crude but basically usable fastdfs client based on asyncio
Project description
Async FastDFS Client Usage Guide
This project implements asynchronous file upload and download for FastDFS.
This document explains how to use Async_Fdfs_Client to perform local file upload/download and FastAPI-based upload/download.
First install dependencies:
pip install aiofdfs
1. Uploading and Downloading Local Files
In a pure script environment, you can directly use the asynchronous methods provided by Async_Fdfs_Client to upload and download files from FastDFS.
First, initialize the configuration:
from aiofdfs import FastDfsConf
def get_fdfs_conf():
return FastDfsConf(
tracker_servers=['192.168.0.50:22122'],
connect_timeout=3,
network_timeout=3,
# The index of the storage directory. If not set or set to -1, no control is applied.
# If set to a value >= 0, the upload directory is strictly controlled.
store_path_index=1
)
The following example demonstrates local file upload and download using unit tests.
1.1. File Upload
@pytest.mark.asyncio
async def test_upload_file():
conf = get_fdfs_conf()
async with Async_Fdfs_Client(conf) as fdfs_client:
# Local file to upload
local_file = 'E:/demo.zip'
ret = await fdfs_client.upload_by_filename(local_file)
print(ret)
Example response:
{
"group_name": "group1",
"file_id": "group1/M01/00/00/xxxxxx.zip",
"file_name": "demo.zip",
"file_size": "20MB",
"storage_ip": "192.168.0.50"
}
1.2. File Download
@pytest.mark.asyncio
async def test_download_file():
conf = get_fdfs_conf()
async with Async_Fdfs_Client(conf) as fdfs_client:
# Path to save the downloaded file
local_file_name = 'E:/demo.zip'
remote_file_id = 'group1/M01/00/00/xxxxxx.zip'
ret = await fdfs_client.download_to_file(local_file_name, remote_file_id)
print(ret)
Example output:
{
'file_id': 'group1/M01/00/00/xxxxxx.zip',
# Local file path
'content': 'E:/demo.zip',
'download_size': '20MB',
'storage_ip': b'192.168.0.50'
}
2. Integrating with FastAPI for Upload and Download
This section provides APIs that are closer to real-world business scenarios and can be used directly in service applications.
Initialize the client:
from aiofdfs import FastDfsConf, Async_Fdfs_Client
def get_fdfs_conf():
return FastDfsConf(
tracker_servers=['192.168.0.50:22122'],
connect_timeout=3,
network_timeout=3,
# The index of the storage directory. If not set or set to -1, no control is applied.
# If set to a value >= 0, the upload directory is strictly controlled.
store_path_index=1
)
# Initialize client
fdfs_client = Async_Fdfs_Client(get_fdfs_conf())
2.1. File Upload API
@app.post("/upload")
async def upload(file: UploadFile = File(...)):
result = await fdfs_client.upload_by_upload_file(file)
return result
Example response:
{
"group_name": "group1",
"file_id": "group1/M01/00/04/xxxxxx.pdf",
"file_name": "example.pdf",
"file_size": "100KB",
"storage_ip": "192.168.0.50"
}
2.2. File Download API
from urllib.parse import quote
@app.get("/download")
async def download(file_id: str):
meta_data = await fdfs_client.get_meta_data(file_id)
file_name = meta_data.get("OriginFileName")
file_size = meta_data.get("OriginFileSize")
quoted_filename = quote(file_name)
headers = {
"Content-Disposition": f"attachment; filename*=UTF-8''{quoted_filename}",
"Content-Length": str(file_size)
}
return StreamingResponse(
fdfs_client.download_to_generator(file_id),
headers=headers,
media_type="application/octet-stream"
)
This allows the browser or client to download the file directly.
3. REST Client Test Script (VSCode)
The VS Code REST Client extension can be used to quickly test the API.
3.1. File Upload
###
POST http://localhost:8000/upload
Content-Type: multipart/form-data; boundary=----WebKitFormBoundary7MA4YWxkTrZu0gW
------WebKitFormBoundary7MA4YWxkTrZu0gW
Content-Disposition: form-data; name="file"; filename="example.pdf"
Content-Type: application/pdf
< E:\demo\example.pdf
------WebKitFormBoundary7MA4YWxkTrZu0gW
Content-Disposition: form-data; name="json_data"
{
"demo": "hello"
}
------WebKitFormBoundary7MA4YWxkTrZu0gW--
3.2. File Download
###
GET http://localhost:8000/download?file_id=group1/M01/00/04/xxxxxx.pdf
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file aiofdfs-0.1.25.tar.gz.
File metadata
- Download URL: aiofdfs-0.1.25.tar.gz
- Upload date:
- Size: 27.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cbd6de23f4405db8a9605b0579eff73b8c057649ba514cd22c9d0fd1250e5eb2
|
|
| MD5 |
b520ab006fdf4b0c4ec92c07e8f326ae
|
|
| BLAKE2b-256 |
95a81d03c8c1811168f11f2061924e7b20523e678831c5374c426c1637e993d4
|
File details
Details for the file aiofdfs-0.1.25-py3-none-any.whl.
File metadata
- Download URL: aiofdfs-0.1.25-py3-none-any.whl
- Upload date:
- Size: 31.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
da686659cc1e17e2cee783f03bf254e09179686a9fd9352edb6a386e16bc9b5e
|
|
| MD5 |
cb76745fa245c89360efd79031bdb4f9
|
|
| BLAKE2b-256 |
5f251aaaa6609a01165101506976c1999bf479824964727249c08023a0977ac0
|