当前位置: 首页 > news >正文

壁纸管理 API 文档

壁纸管理 API 文档

环境:Python 3.9+Flask 2.xPyMySQL 1.x
运行:python app.py
监听:http://0.0.0.0:5000

通用响应格式

{"code": 200,       // 业务码:200 成功,201 创建成功,400 参数错误,404 资源不存在,500 服务器错误"message": "success","data": {...},     // 具体数据"total": 10        // 部分列表接口返回
}

1. 健康检查

GET /health

测试服务是否存活。

响应示例

{"status":"ok","message":"API is running"}

2. 壁纸列表

GET /api/wallpapers

返回全部壁纸,按创建时间倒序。

响应示例

{"code": 200,"message": "success","data": [{"wallpaper_id": 1,"title": "星空","category_name": "宇宙","file_url": "https://example.com/full/1.jpg","preview_url": "https://example.com/preview/1.jpg","resolution": "3840x2160","file_size": 2048000,"uploader_name": "admin","status": "active","view_count": 1024,"download_count": 256,"like_count": 128,"create_time": "2025-07-25 14:30:00"}],"total": 1
}

3. 壁纸详情

GET /api/wallpapers/int:wallpaper_id

响应示例

{"code": 200,"message": "success","data": { ...单条壁纸对象... }
}

4. 新增壁纸

POST /api/wallpapers

Body(JSON)

字段类型必填说明
titlestring壁纸标题
category_namestring分类名称
file_urlstring原图地址
preview_urlstring预览图地址
resolutionstring分辨率,如 1920x1080
file_sizeint文件大小(字节)
uploader_namestring×上传者
statusstring×状态,默认 pending

响应示例

{"code": 201,"message": "壁纸添加成功","data": { "wallpaper_id": 12 }
}

5. 修改壁纸

PUT /api/wallpapers/int:wallpaper_id

Body(JSON)
只需传要更新的字段,支持:titlecategory_namefile_urlpreview_urlresolutionfile_sizeuploader_namestatus

响应示例

{ "code": 200, "message": "壁纸更新成功" }

6. 删除壁纸

DELETE /api/wallpapers/int:wallpaper_id

响应示例

{ "code": 200, "message": "壁纸删除成功" }

7. 分类列表

GET /api/categories

响应示例

{"code": 200,"message": "success","data": ["宇宙", "动漫", "风景"]
}

8. 根据分类获取壁纸

GET /api/wallpapers/category/<category_name>

响应示例
与「壁纸列表」格式相同,仅筛选对应分类。


9. 更新统计信息

PUT /api/wallpapers/int:wallpaper_id/stats

Body(JSON)

字段类型说明
view_countint本次浏览增量
download_countint本次下载增量
like_countint本次点赞增量

可单独或组合传递;值为增量而非绝对值。

响应示例

{ "code": 200, "message": "统计信息更新成功" }

状态码说明

HTTP业务 code场景说明
200200成功
201201创建成功
400400参数缺失或格式错误
404404指定壁纸不存在
500500服务器内部异常

常见错误示例

{ "code": 400, "message": "title 是必填字段" }{ "code": 404, "message": "壁纸不存在" }

数据库表结构(参考)

CREATE TABLE wallpapers (wallpaper_id INT AUTO_INCREMENT PRIMARY KEY,title VARCHAR(255) NOT NULL,category_name VARCHAR(64),file_url VARCHAR(512),preview_url VARCHAR(512),resolution VARCHAR(32),file_size BIGINT,uploader_name VARCHAR(64),status ENUM('pending','active','banned') DEFAULT 'pending',view_count INT DEFAULT 0,download_count INT DEFAULT 0,like_count INT DEFAULT 0,create_time DATETIME DEFAULT CURRENT_TIMESTAMP
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

可直接将以上 Markdown 保存为 API.md,放入项目根目录,即可作为接口文档使用。

http://www.dtcms.com/a/298765.html

相关文章:

  • 测试实时性内核参数配置
  • 如何阅读字节码文件
  • Arrays 工具类详解
  • 在线事务型的业务、实时分析类业务、离线处理类型的业务
  • C语言————原码 补码 反码 (超绝详细解释)
  • 【循环语句,求100内能被6整除的和】
  • 群晖 File Station:集中浏览与管理 NAS 文件的工具
  • 60个Java与Spring核心知识点详解
  • [Java恶补day46] 整理模板·考点九【二叉树最近公共祖先】
  • 跨境电商流量密码:自养号测评采购技术,低成本撬动高转化
  • agent含义、起源、定义、分类、应用场景以及未来趋势
  • 机器学习入门
  • 从 “能打” 到 “顶尖”:DeepSeek-V3 后训练拆解,微调 + 强化学习如何让大模型脱胎换骨?
  • html+js列表分页功能封装
  • Kubernetes服务发布进阶
  • GPT - 5被曝将在8月初发布!并同步推出mini、nano版
  • 如何评估一个RWA项目的可信度?关键指标解析
  • dart使用
  • 在DolphinScheduler执行Python问题小记
  • 关于linux运维 出现高频的模块认知
  • 基于多种主题分析、关键词提取算法的设计与实现【TF-IDF算法、LDA、NMF分解、BERT主题模型】
  • Nginx 限流
  • Model Control Protocol 三层架构设计,三种传输方式,完成MCP项目构建实现工具调试,多维度评价指标检测多工具多资源调用的鲁棒性和稳健性
  • MyBatisPlus(一)简介与基本CRUD
  • Logcat日志分析
  • SpringBoot 获取请求参数的常用注解
  • 自由学习记录(73)
  • 地铁逃生
  • 注意力机制的使用说明01
  • RNN模型数学推导过程(笔记)