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);
第七步:释放缓冲区
第八步:检查文件是否全部完成上传
文章图片
文件夹扫描类
文章图片
存储路径生成类
文章图片
好了,到此就全部结束了,如果有疑问或批评,欢迎评论和私信,我们一起成长一起学习。
最后放一张实现的效果图
文章图片
后端代码逻辑大部分是相同的,目前能够支持MySQL,Oracle,SQL。在使用前需要配置一下数据库,可以参考我写的这篇文章:http://blog.ncmem.com/wordpress/2019/08/07/java超大文件上传与下载/
推荐阅读
- 如何在Mac中的文件选择框中打开系统隐藏文件夹
- ssh生成公钥秘钥
- iview|iview upload 动态改变上传参数
- Spring|Spring Cloud Feign实现文件上传下载的示例代码
- 文件上传与Koa2
- thinkphp3.2下实现阿里云视频点播实例(客户端JavaScript上传)
- 智汀云盘-开发指南iOS(文件夹加密逻辑)
- 微信小程序上传图片的方法
- 命令行上传小程序版本至微信后台
- 如何将图片上传到七牛云平台()