

喜讯:国内、香港、海外云服务器租用特惠活动,2核/4G/10M仅需31元每月,点击抢购>>>
点击这里注册天翼云特邀VIP帐号,立即体验天翼云对象存储>>>
天翼云对象存储(经典版)I型API参考-断点续传
通过MultipleUpload类以及文件上传请求UploadFileRequest类,实现基于分段上传的断点续传的功能。
参数设置
名称 | 描述 |
EnableCheckpoint | 是否开启断点续传功能。 取值: l true:开启; l false:关闭。 默认值为false。 |
PartSize | 每个分段的大小partSize,若partSize小于5MiB,则会将partSize调整至5MiB。 默认:5MiB |
UploadFile | 上传的本地文件路径。 |
checkpointFile | 记录本地分片上传结果的文件。如果未指定checkpointFile,默认为uploadFile.ucp,与上传的本地文件同路径。 |
objectMetadata | 文件的元数据。 |
ProgressListener | 上传状态监听器。 |
TaskNum | 分片上传并发线程数,默认为1,最多为1000。 |
用checkpointFile来记录所有分片的状态。上传过程中的进度信息会保存在该文件中,如果某一分片上传失败,再次上传时会根据文件中记录的点继续上传。上传完成后,该文件会被删除。checkpointfile默认与待上传的本地文件同目录,为uploadFile.ucp。
Java代码上传示例
public static void multiUpload(AmazonS3 ossClient) {
try {
String bucketName = "testbucketnamexxx";
String key = "object_test1.pdf";
String uploadFile = "D:\tmp\2.txt";
//通过UploadFileRequest设置多个参数
UploadFileRequest request = new UploadFileRequest(bucketName, key);
//上传的本地文件
request.setUploadFile(uploadFile);
//分片上传并发线程数,默认为1,最多为1000
request.setTaskNum(2);
//每个分片的大小,默认5MiB,若partSize小于5MiB,除了最后一个分片以外,会将partSize调整至5MiB
request.setPartSize(5 * 1024 * 1024);
//开启断点续传功能,默认关闭
request.setEnableCheckpoint(true);
//记录本地分片上传结果的文件。开启断点续传功能时需要设置此参数,上传过程中的进度信息会保存在该文件中,如果某一分片上传失败,再次上传时会根据文件中记录的点继续上传。
//上传完成后,该文件会被删除。默认与待上传的本地文件同目录,为uploadFile.ucp
// request.setCheckpointFile("<yourCheckpointFile>");
MultipleUpload multiUpload = new MultipleUpload(request, ossClient);
//断点续传上传
CompleteMultipartUploadResult result = multiUpload.upload();
//System.out.println("location: "+result.getLocation());
System.out.println("Upload complete. Upload object name: " + result.getKey());
} catch (AmazonServiceException ase) {
System.out.println("Caught an AmazonServiceException, which means your request made it " + "to OOS, but was rejected with an error response for some reason.");
System.out.println("Error Message: " + ase.getMessage());
System.out.println("HTTP Status Code: " + ase.getStatusCode());
System.out.println("OOS Error Code: " + ase.getErrorCode());
System.out.println("Request ID: " + ase.getRequestId());
} catch (AmazonClientException ace) {
System.out.println("Caught an AmazonClientException, which means the client encountered "
+ "a serious internal problem while trying to communicate with OOS, "
+ "such as not being able to access the network.");
System.out.println("Error Message: " + ace.getMessage());
}
}
推荐:TOP云智能建站优惠活动,仅880元即可搭建一个后台管理五端合一的智能网站(PC网站、手机网站、百度智能小程序、微信小程序、支付宝小程序),独享百度搜索SEO优势资源,让你的网站不仅有颜值有排面,更有排名,可以实实在在为您带来效益,请点击进入TOP云智能建站>>>,或咨询在线客服了解详情。


湘公网安备43019002001857号
备案号:
客服1