java+上传大视频文件断点续传

java+上传大视频文件断点续传,java上传大视频文件断点续传,java上传大视频文件,java上传大文件断点续传,java上传大文件,java分片上传大文件,java分块上传大文件,java上传文件夹,java批量上传大文件,java批量上传文件夹,

java大文件10G,50G,100G上传下载,JSP大文件10G,50G,100G上传下载,JAVA大文件10G,50G,100G上传下载,断点续传。

一般这么大的文件不用HTML的一次性上传,而是采用分块,分片,分段,分割,切割技术上传。

JAVA话一般是负责后端的逻辑,比如文件初始化,文件块上传,合并,存储等。

前端的话用JSP,VUE2,VUE3,React,HTML5,JS,JQ都行。这个都无所谓。

痛点就是刷新继续,批量上传,批量下载。网上能够做到批量下载,文件夹下载的,搜了一下,几乎没有,全部都是讲的上传,基本上都是用的HTML5的API,也就是Chrome的API,关键是这个API不支持IE。在政府单位用不了。还有一些企业也不用了。

客户现在系统的电脑用的好好的,你不可能让他升级吧,而且也不能随便升。客户要保证现有系统稳定运行。

网上一般的做法都是用的HTML5的API,也就是chrome提供的API,能够满足基本需求,但是还是有痛点,chrome限制死了,固定死了无法扩展,每个域名只允许5个TCP连接,导致了速度有上限,你也无法修改和扩展。然后就是浏览器也只能用chrome,用户用了IE就不行了,用户现有的系统跑在IE上,也不能换。

我们也用过webuploader,上传小文件体验还可以,上传大文件经常会出问题,体验不太好。

进度信息容易丢失,用户关闭网页,刷新网页,关闭浏览器,重启浏览器,关闭电脑,重启电脑后,进度信息都会丢失,无解,没办法。扩展性还是差了点。

传大文件,超大文件,文件数量多的话,前端就卡,网页反应慢,容易死,崩溃,在配置较差的电脑或者配置一般的电脑上这个痛点体现的非常明显。

下载,网上找到的资料一般都是讲上传的,很少讲下载的。

下载示例:

https://gitee.com/xproer/up6-jsp-eclipse/tree/6.5.40/

 

工程

NOSQL

NOSQL示例不需要任何配置,可以直接访问测试

创建数据表

选择对应的数据表脚本,这里以SQL为例

修改数据库连接信息

访问页面进行测试

文件存储路径

up6/upload/年/月/日/guid/filename


 

  


相关问题:
1.javax.servlet.http.HttpServlet错误
2.项目无法发布到tomcat
3.md5计算完毕后卡住
4.服务器找不到config.json文件

相关参考:

文件保存位置

源码工程文档:泽优上传下载-源码版-工程文档.pdf

源码报价单:泽优上传下载-源码版-2024.pdf

OEM版报价单:泽优上传下载-OEM版-2024.pdf

控件源码下载:https://drive.weixin.qq.com/s?k=ACoAYgezAAwbdKCskc

  • 25
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java的HttpClient库可以用于实现HTTP文件上传,而断点续传则是通过在请求头中添加"Range"字段来实现的。下面是一个简单的Java代码示例,演示了如何使用HttpClient库实现HTTP大文件的断点续传上传: ```java import java.io.IOException; import java.io.InputStream; import java.io.RandomAccessFile; import org.apache.http.HttpEntity; import org.apache.http.HttpResponse; import org.apache.http.client.HttpClient; import org.apache.http.client.methods.HttpPost; import org.apache.http.entity.FileEntity; import org.apache.http.impl.client.DefaultHttpClient; public class HttpResumeUpload { public static void main(String[] args) throws IOException { String url = "http://example.com/upload"; String filePath = "/path/to/file"; int bufferSize = 1024 * 1024; // 每次上传的字节数 RandomAccessFile file = new RandomAccessFile(filePath, "r"); long fileSize = file.length(); HttpClient client = new DefaultHttpClient(); HttpPost post = new HttpPost(url); post.setHeader("Range", String.format("bytes=%d-%d", 0, bufferSize - 1)); // 设置上传起始位置 post.setHeader("Content-Length", String.valueOf(bufferSize)); // 设置上传数据长度 HttpEntity entity = new FileEntity(file.getFD(), 0, bufferSize); post.setEntity(entity); HttpResponse response = client.execute(post); int statusCode = response.getStatusLine().getStatusCode(); if (statusCode == 206) { // 部分上传成功 InputStream inputStream = response.getEntity().getContent(); byte[] buffer = new byte[1024]; int bytesRead = 0; while ((bytesRead = inputStream.read(buffer)) != -1) { // 处理服务器返回的响应数据 } post.setHeader("Range", String.format("bytes=%d-%d", bufferSize, fileSize - 1)); // 设置下一次上传起始位置 post.setHeader("Content-Length", String.valueOf(fileSize - bufferSize)); // 设置下一次上传数据长度 entity = new FileEntity(file.getFD(), bufferSize, fileSize - bufferSize); post.setEntity(entity); response = client.execute(post); statusCode = response.getStatusLine().getStatusCode(); // 处理服务器返回的响应数据 } else if (statusCode == 200) { // 全部上传成功 // 处理服务器返回的响应数据 } file.close(); client.getConnectionManager().shutdown(); } } ``` 在上面的代码中,我们首先打开待上传的文件,然后通过HttpClient库发送一个HTTP POST请求,请求的内容是文件的一部分数据。如果服务器返回206状态码,表示部分数据上传成功,我们就从服务器返回的响应中读取剩下的数据,然后设置下一次上传的起始位置和长度,再次发送HTTP POST请求。如果服务器返回200状态码,表示全部数据上传成功,我们就可以关闭文件和HTTP客户端了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值