简易文件服务器
简易服务器
表结构
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进行单元测试
本文来自博客园,作者:钦同学,转载请注明原文链接:https://www.cnblogs.com/itdfq/articles/15763398.html

浙公网安备 33010602011771号