Stažení objektu blob pomocí JavaScriptu nebo TypeScriptu
Tento článek ukazuje, jak stáhnout objekt blob pomocí klientské knihovny azure Storage pro JavaScript. Data objektů blob si můžete stáhnout do různých cílů, včetně místní cesty k souboru, datového proudu nebo textového řetězce.
Požadavky
- Příklady v tomto článku předpokládají, že už máte projekt nastavený tak, aby fungoval s klientskou knihovnou Azure Blob Storage pro JavaScript. Další informace o nastavení projektu, včetně instalace balíčku, importu modulů a vytvoření autorizovaného klientského objektu pro práci s datovými prostředky, najdete v tématu Začínáme se službou Azure Blob Storage a JavaScriptem.
- Autorizační mechanismus musí mít oprávnění k provedení operace stahování. Další informace najdete v pokynech k autorizaci pro následující operaci rozhraní REST API:
Stažení objektu blob
Ke stažení objektu blob můžete použít některou z následujících metod:
- BlobClient.download
- BlobClient.downloadToBuffer (k dispozici pouze v Node.js runtime)
- BlobClient.downloadToFile (k dispozici pouze v modulu runtime Node.js)
Stažení do cesty k souboru
Následující příklad stáhne objekt blob pomocí cesty k souboru s metodou BlobClient.downloadToFile . Tato metoda je k dispozici pouze v modulu runtime Node.js:
async function downloadBlobToFile(containerClient, blobName, localFilePath) {
const blobClient = containerClient.getBlobClient(blobName);
await blobClient.downloadToFile(localFilePath);
}
Stažení jako streamu
Následující příklad stáhne objekt blob vytvořením objektu Node.js zapisovatelného streamu a následným propojením do tohoto datového proudu pomocí metody BlobClient.download .
async function downloadBlobAsStream(containerClient, blobName, writableStream) {
const blobClient = containerClient.getBlobClient(blobName);
const downloadResponse = await blobClient.download();
downloadResponse.readableStreamBody.pipe(writableStream);
}
Stažení do řetězce
Následující Node.js příklad stáhne objekt blob do řetězce pomocí metody BlobClient.download . V Node.js vrací data objektů blob v objektu readableStreamBody
blob .
async function downloadBlobToString(containerClient, blobName) {
const blobClient = containerClient.getBlobClient(blobName);
const downloadResponse = await blobClient.download();
const downloaded = await streamToBuffer(downloadResponse.readableStreamBody);
console.log('Downloaded blob content:', downloaded.toString());
}
function streamToBuffer(readableStream) {
return new Promise((resolve, reject) => {
const chunks = [];
readableStream.on('data', (data) => {
chunks.push(data instanceof Buffer ? data : Buffer.from(data));
});
readableStream.on('end', () => {
resolve(Buffer.concat(chunks));
});
readableStream.on('error', reject);
});
}
Pokud pracujete s JavaScriptem v prohlížeči, vrátí se data objektů blob v objektu blob s příslibem BlobBody. Další informace najdete v příkladu použití prohlížečů na webu BlobClient.download.
Zdroje informací
Další informace o tom, jak stáhnout objekty blob pomocí klientské knihovny služby Azure Blob Storage pro JavaScript, najdete v následujících zdrojích informací.
Ukázky kódu
Prohlédněte si ukázky kódu z tohoto článku (GitHub):
Stažení do souboru pro JavaScript nebo TypeScript
Stažení streamu pro JavaScript nebo TypeScript
Stažení do řetězce pro JavaScript nebo TypeScript
Operace rozhraní REST API
Sada Azure SDK pro JavaScript obsahuje knihovny, které jsou postavené na rozhraní Azure REST API a umožňují interakci s operacemi rozhraní REST API prostřednictvím známých paradigmat JavaScriptu. Metody klientské knihovny pro stahování objektů blob používají následující operaci rozhraní REST API:
- Získání objektu blob (REST API)
Prostředky klientské knihovny
Související obsah
- Tento článek je součástí příručky pro vývojáře služby Blob Storage pro JavaScript nebo TypeScript. Další informace najdete v úplném seznamu článků příručky pro vývojáře v tématu Sestavení aplikace JavaScript/TypeScript.