Compartilhar via


Copiar um blob de uma URL de objeto de origem com JavaScript

Este artigo mostra como copiar um blob de uma URL de objeto de origem usando a biblioteca de clientes do Armazenamento do Azure para JavaScript. Você pode copiar um blob de uma origem dentro da mesma conta de armazenamento, de uma origem em uma conta de armazenamento diferente ou de qualquer objeto acessível recuperado por meio de uma solicitação HTTP GET em um URL específico.

Os métodos da biblioteca de clientes abordados neste artigo usam as operações de API REST Colocar um Blob do URL e Colocar um Bloco do URL. Esses métodos são os preferidos para cenários de cópia sempre que você desejar transferir dados para uma conta de armazenamento e tiver um URL para o objeto de origem. Para as operações de cópia em que você deseja o agendamento assíncrono, confira Copiar um blob com agendamento assíncrono usando JavaScript.

Pré-requisitos

  • Os exemplos neste artigo pressupõem que você já tenha um projeto configurado para trabalhar com a biblioteca de clientes do Armazenamento de Blobs do Azure para JavaScript. Para saber mais sobre a configuração do seu projeto, incluindo a instalação de pacotes, a importação de módulos e a criação de um objeto cliente autorizado para trabalhar com recursos de dados, confira Introdução ao Armazenamento de Blobs do Azure e o JavaScript.
  • O mecanismo de autorização deve ter permissões para executar uma operação de cópia. Para saber mais, consulte as diretrizes de autorização para as seguintes operações de API REST:

Sobre a cópia de blobs de um URL de objeto de origem

A operação Put Blob From URL cria um novo blob de blocos em que o conteúdo do blob é lido de um URL específico. A operação é executada de forma síncrona.

A origem pode ser qualquer objeto recuperável por meio de uma solicitação HTTP GET padrão no URL específico. Isso inclui blobs de blocos, blobs de acréscimo, blobs de páginas, instantâneos de blob, versões de blob ou qualquer objeto acessível dentro ou fora do Azure.

Quando o objeto de origem é um blob de blocos, todo o conteúdo do blob confirmado é copiado. No entanto, a lista de blocos não é preservada e os blocos não confirmados não são copiados. O conteúdo do blob de destino é idêntico ao conteúdo do blob de origem, mas a lista de blocos confirmados não é preservada.

O blob de destino é sempre um blob de blocos, podendo ser um blob de blocos existente ou um novo blob de blocos criado pela operação. O conteúdo de um blob existente é substituído pelo conteúdo do novo blob.

A operação Put Blob From URL sempre copia o blob de origem inteiro. Não há suporte para a cópia de um intervalo de bytes ou um conjunto de blocos. Para executar atualizações parciais no conteúdo de um blob de blocos usando um URL de origem, use a API Colocar um Bloco do URL junto com Colocar uma Lista de Blocos.

Para saber mais sobre a operação Put Blob From URL, incluindo limitações de tamanho e considerações de cobrança do blob, confira Comentários sobre Colocar um Blob do URL.

Copiar um blob de um URL de objeto de origem

Esta seção fornece uma visão geral dos métodos fornecidos pela biblioteca de clientes do Armazenamento do Azure para JavaScript para executar uma operação de cópia a partir de uma URL de objeto de origem.

Os métodos a seguir encapsulam a operação de API REST Colocar um Blob do URL e criam um novo blob de blocos em que o conteúdo do blob é lido de um URL específico:

Esses métodos são os preferidos para cenários nos quais você desejar transferir dados para uma conta de armazenamento e tiver um URL para o objeto de origem.

Para objetos grandes, você pode optar por trabalhar com blocos individuais. Os métodos a seguir encapsulam a operação de API REST Colocar um Bloco da URL. Esses métodos criam um novo bloco a ser confirmado como parte de um blob sempre que o conteúdo for lido de uma URL de origem:

Copiar um blob de uma origem no Azure

Se você estiver copiando um blob de uma origem no Azure, o acesso ao blob de origem poderá ser autorizado através do Microsoft Entra ID, de uma assinatura de acesso compartilhado (SAS) ou de uma chave de conta.

O exemplo a seguir mostra um cenário para a cópia de um blob de origem no Azure:

async function copyFromSourceInAzure(sourceBlob, destinationBlob) {
  // Get the source blob URL and create the destination blob
  await destinationBlob.syncUploadFromURL(sourceBlob.url);
}

O método syncUploadFromURL também pode aceitar um parâmetro BlockBlobSyncUploadFromURLOptions para especificar outras opções para a operação.

Copiar um blob de uma origem fora do Azure

Você pode executar uma operação de cópia em qualquer objeto de origem que possa ser recuperado por meio da solicitação HTTP GET em um URL específico, incluindo objetos acessíveis fora do Azure. O exemplo a seguir mostra um cenário para copiar um blob de um URL de objeto de origem acessível.

async function copyFromExternalSource(sourceUrl, destinationBlob) {
  // Create the destination blob from the source URL
  await destinationBlob.syncUploadFromURL(sourceUrl);
}

Recursos

Para saber mais sobre como copiar blobs usando a biblioteca de clientes do Armazenamento de Blobs do Azure para JavaScript, consulte os recursos a seguir.

Operações da API REST

O SDK do Azure para JavaScript contém bibliotecas que se baseiam na API REST do Azure, permitindo a interação com as operações de API REST por meio de paradigmas conhecidos do JavaScript. Os métodos de biblioteca de clientes abordados neste artigo usam as seguintes operações de API REST:

Exemplos de código

Recursos da biblioteca de clientes