繁难服务器


表构造

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

服务端部署:

  1. 采纳docker容器形式进行部署,挂载主机目录,mysql同样放入容器中
  2. 日志文件采纳自定义logback-spring.xml,依照info和error级别进行按天输入
  3. 定时删除日志,每隔30天主动删除

    #!/bin/bashfind /root/upload/log/ -mtime +30 -name "*.log" -exec rm -rf {} \;

    每天凌晨2点删除30天内的日志

    0 2 * * * /project/upload/deleted.sh
  1. 日志输入,docker挂载主机目录,按天数输入,过滤error
  2. 在线地址:在线地址

服务端

文件上传:/itdfq/upload POST

留神
  1. 单词文件最大不能超过5MB
  2. 不限度格局上传
  3. 上传后保留于 服务器:/project/upload/data,会在data文件夹下主动创立文件夹进行保留,命名格局为yyyyMMdd,保留地址能够再yml文件中进行配置
  4. 上传文件之后,会返回一个code
测试
  1. 抉择一个txt上传,应用postMan进行申请

数据库信息如下:

服务器保留地址如下:

查看文件信息:/itdfq/getByCode GET

  1. 通过code能够获取到文件的原始名字,类型等等相干信息
    举例

文件下载:/itdfq/downByCode GET

  1. 参数为code,String类型,由上传时返回
  2. 浏览器关上能够间接进行下载
    举例

客户端

  1. 客户端次要应用jdk自带工具封装了http申请
  2. 在ClientTest进行单元测试

    我的项目地址

    码云