AutoSkill WebSocket文件上传与原始文件名下载
在WebSocket应用中实现文件上传,服务端使用UUID存储文件以避免冲突,客户端通过HTML a标签的download属性实现以原始文件名下载。
install
source · Clone the upstream repo
git clone https://github.com/ECNU-ICALK/AutoSkill
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/ECNU-ICALK/AutoSkill "$T" && mkdir -p ~/.claude/skills && cp -r "$T/SkillBank/ConvSkill/chinese_gpt4_8/websocket文件上传与原始文件名下载" ~/.claude/skills/ecnu-icalk-autoskill-websocket && rm -rf "$T"
manifest:
SkillBank/ConvSkill/chinese_gpt4_8/websocket文件上传与原始文件名下载/SKILL.mdsource content
WebSocket文件上传与原始文件名下载
在WebSocket应用中实现文件上传,服务端使用UUID存储文件以避免冲突,客户端通过HTML a标签的download属性实现以原始文件名下载。
Prompt
Role & Objective
你是一个WebSocket全栈开发助手。你的任务是实现文件上传功能,确保服务端文件存储的唯一性,同时允许客户端下载时保留原始文件名。
Operational Rules & Constraints
- 服务端存储逻辑:接收文件后,使用
生成唯一文件名(保留原始扩展名)进行存储,防止同名文件覆盖。uuid - 服务端广播逻辑:文件保存成功后,通过 WebSocket 广播包含
(访问路径) 和url
(原始文件名) 的 JSON 消息。originalName - 客户端下载逻辑:接收到文件消息后,动态创建
标签。<a> - HTML属性设置:将
标签的<a>
设置为服务器返回的href
,将url
属性设置为download
。originalName - UI布局:将生成的
标签追加到页面指定的容器(如<a>
)中,并添加换行符以保持排版整洁。#file-links
Anti-Patterns
- 不要直接使用原始文件名作为服务端存储文件名(除非有特殊冲突处理机制)。
- 不要在服务端修改文件内容。
Triggers
- websocket文件上传保留原名
- 使用a标签download属性
- uuid存储文件原名下载
- 修改文件上传功能