做一个文档管理系统,使用AWSS3 ,上传到minio。查了一些资料,入了一些坑。
使用AWSS3文件文件上传分为2步
step1:获取上传url
step2: 根据url上传文件
如果返回的multipart=false,使用PUT方法上传文件即可
如果multipart=true,则需要分段上传
分段上传的步骤:
保留每一个分段返回的Etag值,同时在所有分段上传完成后调用结束接口结束上传
step1: 获取文件uploadId
`get /api/object-multiupload-url?name=1.wmv`
step2: 获取每个分段上传的url
step3: 根据step2的url上传每个分段
每个分段会返回一个Etag, 在最后一步需要用到
step4: 完成分段上传(合并分段)
但是!我在代码上没有实现这些步骤,并不知道根据url上传文件是什么意思,url返回来是一个ip端口参数等等的长串。后来发现示例代码上拿到这个url是使用AWS的命令行工具执行的,所以他说使用PUT方法上传。个人以为这个url只供命令行使用,代码只能通过别的方法实现。具体代码实现找到了代码实现:
import com.amazonaws.AmazonServiceException;
import com.amazonaws.SdkClientException;
import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.regions.Regions;
import com.amazonaws.services.s3.AmazonS3;
import com.amazonaws.services.s3.AmazonS3ClientBuilder;
import com.amazonaws.services.s3.model.*;
import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
public class LowLevelMultipartUpload {
public static void main(String[] args) throws IOException {
Regions clientRegion = Regions.DEFAULT_REGION;
String bucketName = "*** Bucket name ***";
String keyName = "*** Key name ***";
String filePath = "*** Path to file to upload ***";
File file = new File(filePath);
long contentLength = file.length();
long partSize = 5 * 1024 * 1024; // Set part size to 5 MB.
try {
AmazonS3 s3Client = AmazonS3ClientBuilder.standard()
.withRegion(clientRegion)
.withCredentials(new ProfileCredentialsProvider())
.build();
// Create a list of ETag objects. You retrieve ETags for each object part uploaded,
// then, after each individual part has been uploaded, pass the list of ETags to
// the request to complete the upload.
List<PartETag> partETags = new ArrayList<PartETag>();
// Initiate the multipart upload.
InitiateMultipartUploadRequest initRequest = new InitiateMultipartUploadRequest(bucketName, keyName)