Easy云盘总结篇-文件上传02

说在前面:此项目是跟着B站一位大佬写的,不分享源码,支持项目付费

文件预览

主要分视频和其他文件预览,但实现逻辑相同,只是请求路径有区别。

这段逻辑:

拿视频预览举例:

视频开始时,首先读取的文件并不是分片(0511006421),后面视频播放到结束,才是一个一个地加载分片文件播放。

所以,刚开始走else,通过fileId,userId找到文件,逐步将文件信息重定位到index.m3u8文件,也就是索引文件。索引文件里包含视频的时长分片等等信息。

然后视频加载,读取各个分片。核心逻辑就是处理路径。

创建目录


这段逻辑:

首先前端传来的filePid意味着,用户要在哪一层创建文件夹。

serviceImpl:

创建文件夹主要不能有同名。

目录文件夹信息


这段逻辑:

将path分级,获取到每一级文件夹的FileId,查到相应的文件夹后,同时这里展示的顺序要根据path里的层级顺序进行展示。

移动文件

当前示例文件如下图:

简化一下:

文件1

文件夹1

文件2

文件夹2(空)

这个逻辑有一点点复杂,有点绕。

首先按常规来说,我们想移动文件2,就会问你移到哪里去,这个目标文件夹不可能在文件2目前存放的路径(根/文件夹1),哪有原地移动的道理。所以,在移动之前,我们要进行目标文件夹的展示,给用户选择,用户只能选择除当前所在文件夹所在目录之外的文件夹,这个目标文件夹是可以在当前文件夹下,只是路径不同了(比如:根/文件夹1/文件夹2)。

比如说:

展示其他文件夹

移动文件


这段逻辑:

先进行各种特殊情况的判断处理。

然后就是移动文件,核心就是更改其父Id,而不是保存路径的修改(路径固定)。所以在移动文件时,就需要考虑到移动过去后,不能与目标文件夹的文件重名,需要进行重命名。

文件重命名

这里我当时的问题:为什么要查两遍文件?

为了防止并发情况下的重名问题,因为前面的 checkFileName 检查和更新操作之间可能有其他线程插入,导致重复,所以再次检查确保唯一性。

事务开启 ,任何一步失败(如二次检查发现重名)都会回滚,避免脏数据。

下载文件

在我们下载文件时,两种情况:1:在我们easy云盘页面直接下载 2:分享下载链接给他人下载

直接下载的情况,用户已经登录,浏览器有 session,所以服务器可以通过 session 验证用户身份。但分享下载时,他人可能未登录,需要通过链接中的参数(如文件 ID 和签名)来验证。而如果浏览器调用第三方插件(如迅雷),就无法获取 session,所以需要一个独立于 session 的验证方式,比如临时令牌或 code,这个 code 有时效性,确保安全。

所以我们下载文件实际需要两步:第一:先校验登录,生成一串有时效性的code;第二:用户拿到code就可以直接下载文件。

生成code

redis:

下载文件

通过这个方法,我们就把目标文件写入到了HTTP响应当中,实现了文件的下载。

相关推荐
爬山算法几秒前
Redis(156)Redis的延迟问题如何解决?
数据库·redis·缓存
v***91301 分钟前
Windows版Redis本地后台启动
数据库·windows·redis
梁bk3 分钟前
Redis 数据类型(上)String,List,Set
数据库·redis
xixixi777779 分钟前
剖析Agent(代理)攻击面
网络·学习·安全·架构·网络攻击模型·代理
i***132410 分钟前
【SpringBoot】单元测试实战演示及心得分享
spring boot·后端·单元测试
路边草随风15 分钟前
flink实现写orc对数据进行分目录(分区表)写入
java·大数据·flink
geekmice21 分钟前
通过账户信息操作加深对DTO,VO,BO理解
java
爬山算法22 分钟前
Redis(157)Redis的连接问题如何解决?
数据库·redis·bootstrap
r***013823 分钟前
Java进阶,时间与日期,包装类,正则表达式
java·mysql·正则表达式