詳解如何在Java中使用阿里云對(duì)象存儲(chǔ)OSS
一、開始之前
在使用阿里云對(duì)象存儲(chǔ) OSS 之前,我們需要進(jìn)行一些準(zhǔn)備工作:
創(chuàng)建阿里云賬號(hào),并開通 OSS 服務(wù)。
在控制臺(tái)中創(chuàng)建一個(gè) Bucket,并記錄 Bucket 的名稱、Endpoint、AccessKeyId 和 AccessKeySecret。
下載并安裝阿里云 SDK,然后在項(xiàng)目中添加相關(guān)依賴。

二、上傳文件
在 Java 中使用阿里云對(duì)象存儲(chǔ) OSS 實(shí)現(xiàn)文件上傳非常簡(jiǎn)單,我們只需要通過(guò) OSSClient 對(duì)象調(diào)用相應(yīng)的 API 即可。下面是一個(gè)示例代碼:
public static void uploadFile(String endpoint, String accessKeyId, String accessKeySecret, String bucketName, String objectName, String filePath) {
// 創(chuàng)建 OSSClient 對(duì)象
OSSClient ossClient = new OSSClient(endpoint, accessKeyId, accessKeySecret);
try {
// 判斷 Bucket 是否存在,如果不存在則創(chuàng)建
if (!ossClient.doesBucketExist(bucketName)) {
ossClient.createBucket(bucketName);
}
// 上傳文件
ossClient.putObject(bucketName, objectName, new File(filePath));
} catch (Exception e) {
e.printStackTrace();
} finally {
// 關(guān)閉 OSSClient
ossClient.shutdown();
}
}在上面的代碼中,我們首先創(chuàng)建了一個(gè) OSSClient 對(duì)象,然后判斷 Bucket 是否存在,如果不存在則創(chuàng)建。最后,我們通過(guò) putObject 方法上傳文件。
三、斷點(diǎn)續(xù)傳
如果需要上傳大文件,我們可以使用斷點(diǎn)續(xù)傳來(lái)提高上傳的速度和可靠性。阿里云對(duì)象存儲(chǔ) OSS 提供了分塊上傳和斷點(diǎn)續(xù)傳的功能,可以通過(guò) OSSClient 對(duì)象調(diào)用相應(yīng)的 API 來(lái)實(shí)現(xiàn)。下面是一個(gè)示例代碼:
public static void uploadBigFile(String endpoint, String accessKeyId, String accessKeySecret, String bucketName, String objectName, String filePath) {
// 創(chuàng)建 OSSClient 對(duì)象
OSSClient ossClient = new OSSClient(endpoint, accessKeyId, accessKeySecret);
try {
// 判斷 Bucket 是否存在,如果不存在則創(chuàng)建
if (!ossClient.doesBucketExist(bucketName)) {
ossClient.createBucket(bucketName);
}
// 設(shè)置分塊大小為1MB
long partSize = 1024 * 1024L;
// 初始化分塊上傳
InitiateMultipartUploadResult initiateMultipartUploadResult = ossClient.initiateMultipartUpload(bucketName, objectName);
// 獲取 UploadId
String uploadId = initiateMultipartUploadResult.getUploadId();
// 獲取文件大小
File file = new File(filePath);
long fileSize = file.length();
// 計(jì)算分塊數(shù)
int partCount = (int) (fileSize / partSize);
if (fileSize % partSize != 0) {
partCount++;
}
// 初始化 PartETag 數(shù)組
List<PartETag> partETags = new ArrayList<>();
// 分塊上傳
for (int i = 0; i < partCount; i++) {
// 計(jì)算分塊大小和起始位置
long startPos = i * partSize;
long curPartSize = Math.min(partSize, fileSize - startPos);
FileInputStream inputStream = new FileInputStream(file);
inputStream.skip(startPos);
// 上傳分塊
UploadPartRequest uploadPartRequest = new UploadPartRequest();
uploadPartRequest.setBucketName(bucketName);
uploadPartRequest.setKey(objectName);
uploadPartRequest.setUploadId(uploadId);
uploadPartRequest.setInputStream(inputStream);
uploadPartRequest.setPartSize(curPartSize);
uploadPartRequest.setPartNumber(i + 1);
UploadPartResult uploadPartResult = ossClient.uploadPart(uploadPartRequest);
// 將 PartETag 添加到數(shù)組中
partETags.add(uploadPartResult.getPartETag());
// 關(guān)閉文件流
inputStream.close();
}
// 完成分塊上傳
CompleteMultipartUploadRequest completeMultipartUploadRequest = new CompleteMultipartUploadRequest(bucketName, objectName, uploadId, partETags);
ossClient.completeMultipartUpload(completeMultipartUploadRequest);
} catch (Exception e) {
e.printStackTrace();
} finally {
// 關(guān)閉 OSSClient
ossClient.shutdown();
}
}在上面的代碼中,我們通過(guò) initiateMultipartUpload 方法初始化分塊上傳,并獲取 UploadId。然后,我們計(jì)算分塊數(shù),并遍歷分塊進(jìn)行上傳。最后,通過(guò) completeMultipartUpload 方法完成分塊上傳。
四、文件下載
在 Java 中使用阿里云對(duì)象存儲(chǔ) OSS 實(shí)現(xiàn)文件下載也很簡(jiǎn)單,我們只需要通過(guò) OSSClient 對(duì)象調(diào)用相應(yīng)的 API 即可。下面是一個(gè)示例代碼:
public static void downloadFile(String endpoint, String accessKeyId, String accessKeySecret, String bucketName, String objectName, String savePath) {
// 創(chuàng)建 OSSClient 對(duì)象
OSSClient ossClient = new OSSClient(endpoint, accessKeyId, accessKeySecret);
try {
// 下載文件
ossClient.getObject(new GetObjectRequest(bucketName, objectName), new File(savePath));
} catch (Exception e) {
e.printStackTrace();
} finally {
// 關(guān)閉 OSSClient
ossClient.shutdown();
}
}在上面的代碼中,我們首先創(chuàng)建了一個(gè) OSSClient 對(duì)象,然后通過(guò) getObject 方法下載文件到本地。
五、小結(jié)一下
以上就是在 Java 中使用阿里云對(duì)象存儲(chǔ) OSS 的基本操作,包括簡(jiǎn)單上傳文件、斷點(diǎn)續(xù)傳和文件下載。阿里云對(duì)象存儲(chǔ) OSS 擁有著高可靠性、高擴(kuò)展性和低成本等優(yōu)勢(shì),在互聯(lián)網(wǎng)開發(fā)中得到了廣泛應(yīng)用。希望本文能夠幫助讀者更好的利用阿里云對(duì)象存儲(chǔ) OSS,提高數(shù)據(jù)存儲(chǔ)和訪問(wèn)效率。
到此這篇關(guān)于詳解如何在Java中使用阿里云對(duì)象存儲(chǔ)OSS的文章就介紹到這了,更多相關(guān)Java對(duì)象存儲(chǔ)OSS內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
設(shè)計(jì)模式之責(zé)任鏈模式_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要為大家詳細(xì)介紹了設(shè)計(jì)模式之責(zé)任鏈模式的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08
Java系統(tǒng)變量參數(shù)獲取設(shè)置System.getProperties()的方法
這篇文章主要介紹了Java系統(tǒng)變量參數(shù)System.getProperties()獲取設(shè)置方法,文末給大家提到了Systm.getenv()與System.getProperties()區(qū)別,需要的朋友可以參考下2022-01-01
Springboot 整合 Java DL4J 實(shí)現(xiàn)醫(yī)學(xué)影像診斷功能介紹
本文介紹如何利用SpringBoot整合Java Deeplearning4j實(shí)現(xiàn)醫(yī)學(xué)影像診斷功能,重點(diǎn)介紹了卷積神經(jīng)網(wǎng)絡(luò)在處理醫(yī)學(xué)影像中的應(yīng)用,以及如何進(jìn)行數(shù)據(jù)預(yù)處理、模型構(gòu)建、訓(xùn)練與預(yù)測(cè),提供了詳細(xì)的代碼實(shí)現(xiàn)和單元測(cè)試方法,目的是輔助醫(yī)生更準(zhǔn)確快速地進(jìn)行疾病診斷2024-10-10
詳解RabbitMQ中死信隊(duì)列和延遲隊(duì)列的使用詳解
這篇文章主要為大家介紹了RabbitMQ中死信隊(duì)列和延遲隊(duì)列的原理與使用,這也是Java后端面試中常見的問(wèn)題,感興趣的小伙伴可以了解一下2022-05-05
談?wù)凧ava中對(duì)象,類和this,super,static關(guān)鍵字的使用
對(duì)象:對(duì)象是類的一個(gè)實(shí)例,有狀態(tài)和行為。類:類是一個(gè)模板,它描述一類對(duì)象的行為和狀態(tài)。本文就來(lái)和大家聊聊Java中對(duì)象,類和關(guān)鍵字的使用,需要的可以參考一下2022-08-08
GC調(diào)優(yōu)實(shí)戰(zhàn)之高分配速率High?Allocation?Rate
這篇文章主要為大家介紹了GC調(diào)優(yōu)之高分配速率High?Allocation?Rate的實(shí)戰(zhàn)示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-01-01

