java+struts上传文件夹文件

这里只写后端的代码,基本的思想就是,前端将文件分片,然后每次访问上传接口的时候,向后端传入参数:当前为第几块文件,和分片总数
下面直接贴代码吧,一些难懂的我大部分都加上注释了:
上传文件实体类:
看得出来,实体类中已经有很多我们需要的功能了,还有实用的属性。如MD5秒传的信息。

publicclassFileInf {public FileInf(){}publicStringid=""; publicStringpid=""; publicStringpidRoot=""; /*** 表示当前项是否是一个文件夹项。*/publicbooleanfdTask=false; ///// 是否是文件夹中的子文件/// publicbooleanfdChild=false; /*** 用户ID。与第三方系统整合使用。*/publicintuid=0; /*** 文件在本地电脑中的名称*/publicStringnameLoc=""; /*** 文件在服务器中的名称。*/publicStringnameSvr=""; /*** 文件在本地电脑中的完整路径。示例:D:\Soft\QQ2012.exe */publicStringpathLoc=""; /*** 文件在服务器中的完整路径。示例:F:\\ftp\\uer\\md5.exe*/publicStringpathSvr=""; /*** 文件在服务器中的相对路径。示例:/www/web/upload/md5.exe*/publicStringpathRel=""; /*** 文件MD5*/publicStringmd5=""; /*** 数字化的文件长度。以字节为单位,示例:120125*/publiclonglenLoc=0; /*** 格式化的文件尺寸。示例:10.03MB*/publicStringsizeLoc=""; /*** 文件续传位置。*/publiclongoffset=0; /*** 已上传大小。以字节为单位 */publiclonglenSvr=0; /*** 已上传百分比。示例:10%*/publicStringperSvr="0%"; publicbooleancomplete=false; publicDatePostedTime = newDate(); publicbooleandeleted=false; /*** 是否已经扫描完毕,提供给大型文件夹使用,大型文件夹上传完毕后开始扫描。*/publicbooleanscaned=false; }

首先是文件数据接收逻辑,负责接收控件上传的文件块数据,然后写到服务器的文件中。控件已经提供了块的索引,大小,MD5和长度信息,我们可以根据需要来灵活进行处理,也可以将文件块的数据保存到分布式存储系统中。


文件初始化部分


第一步:获取RandomAccessFile,随机访问文件类的对象
第二步:调用RandomAccessFile的getChannel()方法,打开文件通道 FileChannel,这块逻辑可以优化,如果以后有分布式存储需求,可以改为分布式存储,减轻单台服务器的压力。
public class FileBlockWriter {public FileBlockWriter(){} public void CreateFile(String pathSvr,long lenLoc){try{File ps = new File(pathSvr); PathTool.createDirectory(ps.getParent()); RandomAccessFile raf = new RandomAccessFile(pathSvr, "rw"); raf.setLength(lenLoc); //fix:以原始大小创建文件raf.close(); } catch (IOException e) {// TODO Auto-generated catch blocke.printStackTrace(); }}public void write(long offset,String pathSvr,FileItem block){try{InputStream stream = block.getInputStream(); byte[] data = https://www.it610.com/article/new byte[(int)block.getSize()]; stream.read(data); stream.close(); RandomAccessFile raf = new RandomAccessFile(pathSvr,"rw"); raf.seek(offset); raf.write(data); raf.close(); } catch (IOException e) {// TODO Auto-generated catch blocke.printStackTrace(); }}}

第三步:获取当前是第几个分块,计算文件的最后偏移量
【java+struts上传文件夹文件】第四步:获取当前文件分块的字节数组,用于获取文件字节长度
第五步:使用文件通道FileChannel类的 map()方法创建直接字节缓冲器MappedByteBuffer
第六步:将分块的字节数组放入到当前位置的缓冲区内mappedByteBuffer.put(byte[] b);
第七步:释放缓冲区
第八步:检查文件是否全部完成上传
java+struts上传文件夹文件
文章图片

文件夹扫描类
java+struts上传文件夹文件
文章图片


存储路径生成类
java+struts上传文件夹文件
文章图片

好了,到此就全部结束了,如果有疑问或批评,欢迎评论和私信,我们一起成长一起学习。
最后放一张实现的效果图
java+struts上传文件夹文件
文章图片

后端代码逻辑大部分是相同的,目前能够支持MySQL,Oracle,SQL。在使用前需要配置一下数据库,可以参考我写的这篇文章:http://blog.ncmem.com/wordpress/2019/08/07/java超大文件上传与下载/

    推荐阅读