繁难服务器
表构造
CREATE TABLE `upload` (`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(64) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL COMMENT '文件名字',
`code` varchar(32) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL COMMENT 'UUID',
`size` int(11) NOT NULL COMMENT '文件大小',
`type` varchar(32) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL COMMENT '文件类型',
`save_address` varchar(255) CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL COMMENT '文件保留地址',
`add_time` datetime NOT NULL,
`update_time` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
`deleted_id` int(11) NOT NULL DEFAULT '0',
PRIMARY KEY (`id`),
UNIQUE KEY `id_deleted` (`id`,`deleted_id`) USING BTREE,
UNIQUE KEY `code_deleted` (`code`,`deleted_id`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4
服务端部署:
- 采纳 docker 容器形式进行部署,挂载主机目录,mysql 同样放入容器中
- 日志文件采纳自定义 logback-spring.xml,依照 info 和 error 级别进行按天输入
-
定时删除日志, 每隔 30 天主动删除
#!/bin/bash find /root/upload/log/ -mtime +30 -name "*.log" -exec rm -rf {} \;
每天凌晨 2 点删除 30 天内的日志
0 2 * * * /project/upload/deleted.sh
- 日志输入,docker 挂载主机目录,按天数输入,过滤 error
- 在线地址:在线地址
服务端
文件上传:/itdfq/upload POST
留神
- 单词文件最大不能超过 5MB
- 不限度格局上传
- 上传后保留于 服务器:/project/upload/data,会在 data 文件夹下主动创立文件夹进行保留,命名格局为 yyyyMMdd, 保留地址能够再 yml 文件中进行配置
- 上传文件之后,会返回一个 code
测试
- 抉择一个 txt 上传,应用 postMan 进行申请
数据库信息如下:
服务器保留地址如下:
查看文件信息:/itdfq/getByCode GET
- 通过 code 能够获取到文件的原始名字,类型等等相干信息
举例
文件下载:/itdfq/downByCode GET
- 参数为 code,String 类型,由上传时返回
- 浏览器关上能够间接进行下载
举例
客户端
- 客户端次要应用 jdk 自带工具封装了 http 申请
-
在 ClientTest 进行单元测试
我的项目地址
码云