問題描述
檢視Java Storage SDK,想找一個 uploadWithResponse 的示例程式碼,但是透過全網搜尋,結果沒有任何有幫助的程式碼。使用最近ChatGPT來尋求答案,得到非常有格式的內容:
問:java azure storage account to use uploadWithResponse |
答:To use the
<dependency> <groupId>com.azure</groupId> <artifactId>azure-storage-blob</artifactId> <version>12.14.2</version> </dependency>
import com.azure.storage.blob.BlobClient; import com.azure.storage.blob.BlobContainerClient; import com.azure.storage.blob.BlobServiceClient; import com.azure.storage.blob.BlobServiceClientBuilder;
String connectionString = "your_connection_string"; BlobServiceClient blobServiceClient = new BlobServiceClientBuilder().connectionString(connectionString).buildClient();
String containerName = "your_container_name"; String blobName = "your_blob_name"; BlobContainerClient containerClient = blobServiceClient.getBlobContainerClient(containerName); BlobClient blobClient = containerClient.getBlobClient(blobName);
import com.azure.storage.blob.models.BlobUploadFromFileOptions; import java.nio.file.Path; import java.nio.file.Paths; Path filePath = Paths.get("path/to/your/file"); BlobUploadFromFileOptions options = new BlobUploadFromFileOptions(filePath); blobClient.uploadWithResponse(options, null, null);
This will upload the file to the specified blob in the Azure Blob Storage container. Remember to replace the placeholders with your actual connection string, container name, blob name, and file path. |
繼續追問:BlobParallelUploadOptions with string content |
答:(前面4步的答案一樣,第五步的內容為)
String content = "your_string_content"; InputStream inputStream = new ByteArrayInputStream(content.getBytes(StandardCharsets.UTF_8)); long blockSize = 100 * 1024L; // 100 KB int maxConcurrency = 5; ParallelTransferOptions parallelTransferOptions = new ParallelTransferOptions(blockSize, maxConcurrency); BlobParallelUploadOptions options = new BlobParallelUploadOptions(inputStream).setParallelTra |
在繼續問:如何使用 “To avoid overwriting, pass "*" to setIfNoneMatch(String ifNoneMatch). how to use the setifnonematch” |
答:(前面4步的答案一樣,第五步的內容為)
BlobUploadOptions options = new BlobUploadOptions() .setInputStream(inputStream) .setLength((long) content.length()) .setHttpHeaders(new BlobHttpHeaders().setContentType("text/plain")) .setRequestConditions(new BlobRequestConditions().setIfNoneMatch("*"));
blobClient.uploadWithResponse(options, null, null); This will upload the string content to the specified blob in the Azure Blob Storage container only if the blob does not already exist. If the blob exists, the upload will fail with a |
問題解答
根據ChatGPT提供的三部分資訊,透過人力拼接和測試。得到了成功執行的uploadWithResponse程式碼:
uploadWithResponse示例程式碼
String storageConnectionString = "DefaultEndpointsProtocol=https;AccountName=***************"; String containerName = "******************"; String fileName = "******************"; BlobServiceClient blobServiceClient = new BlobServiceClientBuilder() .connectionString(storageConnectionString) .buildClient(); BlobContainerClient containerClient = blobServiceClient.createBlobContainer(containerName); BlobClient blobClient = containerClient.getBlobClient(fileName);
//準備content並且初始化blob parallel upload options物件
String content = "Test to append new content into exists blob! by blogs lu bian liang zhan deng "; InputStream inputStream = new ByteArrayInputStream(content.getBytes(StandardCharsets.UTF_8)); BlobParallelUploadOptions options = new BlobParallelUploadOptions(inputStream, content.getBytes().length); options.setRequestConditions(new BlobRequestConditions().setIfNoneMatch("*")); Response<BlockBlobItem> rsp = blobClient.uploadWithResponse(options, null, null); if(rsp.getStatusCode()==201) { System.out.println("append content successful........"); }
說明:
1) content 中為需要寫入Blob的內容
2) 把string轉換為以UTF_8編碼的input stream
3) 根據 input stream來初始化 blob paralle upload options物件
4) 設定 Request Conditions,當不需要重寫的時候,可以使用 setIfNoneMatch("*")。如果操作的檔案存在,則會出現 Status code 409, BlobAlreadyExistss 提示。
5) 呼叫upload with response方法,獲取返回值,如果 返回值得status code為 201,表示Storage Account接受了這次 blob 內容的改動。
執行效果展示圖
參考資料
BlobClient Class:https://learn.microsoft.com/en-us/java/api/com.azure.storage.blob.BlobClient?view=azure-java-stable
BlobRequestConditions Class:https://learn.microsoft.com/en-us/java/api/com.azure.storage.blob.models.blobrequestconditions?view=azure-java-stable#com-azure-storage-blob-models-blobrequestconditions-setifnonematch(java-lang-string)
適用於 Java 的 Azure Blob 儲存客戶端庫 : https://docs.azure.cn/zh-cn/storage/blobs/storage-quickstart-blobs-java?tabs=powershell%2Cmanaged-identity%2Croles-azure-portal%2Csign-in-azure-cli#upload-blobs-to-a-container