Biblioteca de clientes do Compartilhamento de Arquivos do Azure para Java – versão 12.20.1
O protocolo SMB (Bloco de Mensagens do Servidor) é o protocolo de compartilhamento de arquivos preferencial usado localmente hoje. O serviço de Compartilhamento de Arquivos do Microsoft Azure permite que os clientes aproveitem a disponibilidade e a escalabilidade do SMB de IaaS (Infraestrutura de Nuvem como Serviço) do Azure sem precisar reescrever aplicativos cliente SMB.
Os arquivos armazenados nos compartilhamentos de serviço do Compartilhamento de Arquivos do Azure podem ser acessados por meio do protocolo SMB e também por meio de APIs REST. O serviço Compartilhamento de Arquivos oferece os quatro recursos a seguir: conta de armazenamento, compartilhamentos, diretórios e arquivos. Os Compartilhamentos fornecem uma maneira de organizar conjuntos de arquivos e também podem ser montados como um compartilhamento de arquivo SMB hospedado na nuvem.
Código-fonte | Documentação | de referência da APIDocumentação | da API RESTDocumentação do produto | Amostras
Introdução
Pré-requisitos
- JDK (Java Development Kit) com a versão 8 ou superior
- Assinatura do Azure
- Criar conta de armazenamento
Incluir o pacote
Incluir o arquivo da BOM
Inclua o azure-sdk-bom em seu projeto para assumir a dependência da versão ga da biblioteca. No trecho a seguir, substitua o espaço reservado {bom_version_to_target} pelo número de versão. Para saber mais sobre o BOM, consulte o BOM README do SDK do AZURE.
<dependencyManagement>
<dependencies>
<dependency>
<groupId>com.azure</groupId>
<artifactId>azure-sdk-bom</artifactId>
<version>{bom_version_to_target}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
Depois, inclua a dependência direta na seção de dependências sem a marca de versão.
<dependencies>
<dependency>
<groupId>com.azure</groupId>
<artifactId>azure-storage-file-share</artifactId>
</dependency>
</dependencies>
Incluir dependência direta
Se você quiser assumir a dependência de uma versão específica da biblioteca que não está presente no BOM, adicione a dependência direta ao seu projeto da seguinte maneira.
<dependency>
<groupId>com.azure</groupId>
<artifactId>azure-storage-file-share</artifactId>
<version>12.20.1</version>
</dependency>
Criar uma conta de armazenamento
Para criar uma Conta de Armazenamento, você pode usar o Portal do Azure ou a CLI do Azure.
az storage account create \
--resource-group <resource-group-name> \
--name <storage-account-name> \
--location <location>
Autenticar o cliente
Para interagir com o serviço de Armazenamento (Serviço de Compartilhamento de Arquivos, Compartilhamento, Diretório, MessageId, Arquivo), você precisará criar uma instância da classe Cliente de Serviço. Para tornar isso possível, você precisará da cadeia de caracteres SAS da Conta SAS (assinatura de acesso compartilhado) da conta de Armazenamento. Saiba mais em Token SAS
Obter credenciais
SAS Token
Use o snippet da CLI do Azure abaixo para obter o token SAS da conta de Armazenamento.
az storage file generate-sas --name {account name} --expiry {date/time to expire SAS token} --permission {permission to grant} --connection-string {connection string of the storage account}
CONNECTION_STRING=<connection-string> az storage file generate-sas --name javasdksas --expiry 2019-06-05 --permission rpau --connection-string $CONNECTION_STRING
Como alternativa, obtenha o Token SAS da conta no Portal do Azure.
- Vá até sua conta de armazenamento.
- Clique em "Assinatura de acesso compartilhado".
- Clique em "Gerar SAS e cadeia de conexão".
Credencial de chave compartilhada
- Há duas maneiras de criar uma credencial de chave compartilhada, a primeira é usar o nome da conta de armazenamento e a chave da conta. A segunda é usar o cadeia de conexão de armazenamento.
- Use o nome da conta e a chave da conta.
- O nome da conta é o nome da conta de armazenamento.
- Vá até sua conta de armazenamento.
- Selecione a guia "Chaves de acesso".
- Copie o valor "Key" para a Chave 1 ou a Chave 2.
- Usar o cadeia de conexão
- Vá até sua conta de armazenamento.
- Selecione a guia "Chaves de acesso".
- Copie o valor "Cadeia de conexão" para a Chave 1 ou a Chave 2.
- Use o nome da conta e a chave da conta.
- Há duas maneiras de criar uma credencial de chave compartilhada, a primeira é usar o nome da conta de armazenamento e a chave da conta. A segunda é usar o cadeia de conexão de armazenamento.
Principais conceitos
Formato de URL
Os Compartilhamentos de Arquivos podem ser endereçáveis usando o seguinte formato de URL:
https://<storage account>.file.core.windows.net/<share>
A URL a seguir endereça um fila no diagrama:
https://myaccount.file.core.windows.net/images-to-download
Sintaxe do URI de recurso
Para a conta de armazenamento, o URI de base para operações de fila inclui apenas o nome da conta:
https://myaccount.file.core.windows.net
Para o arquivo, o URI base inclui o nome da conta e o nome do diretório/arquivo:
https://myaccount.file.core.windows.net/myshare/mydirectorypath/myfile
Tratando exceções
Usa a seção gerada do shareServiceClient
shareServiceClient abaixo.
try {
shareServiceClient.createShare("myShare");
} catch (ShareStorageException e) {
logger.error("Failed to create a share with error code: " + e.getErrorCode());
}
Nomes de recurso
A URI para referenciar um compartilhamento, diretório ou arquivo deve ser exclusiva. Dentro de uma determinada conta de armazenamento, cada compartilhamento deve ter um nome exclusivo. Cada arquivo dentro de um determinado compartilhamento ou diretório deve ter um nome exclusivo dentro desse compartilhamento ou diretório.
Se você tentar criar um compartilhamento, diretório ou arquivo com um nome que viola as regras de nomenclatura, a solicitação falhará com um código de status 400 (Solicitação Incorreta).
Compartilhar Nomes
As regras para nomes de serviço de Compartilhamento de Arquivos são mais restritivas do que as prescritas pelo protocolo SMB para nomes de compartilhamento SMB, para que os serviços blob e arquivo possam compartilhar convenções de nomenclatura semelhantes para contêineres e compartilhamentos. As restrições de nomenclatura para os compartilhamentos são os seguintes:
- Um nome de compartilhamento deve ter um nome DNS válido.
- Os nomes de compartilhamentos começam com uma letra ou um número e pode conter apenas letras, números e o caractere de traço (-).
- Cada caractere de traço (-) deve ser precedido imediatamente e seguido por uma letra ou número; traços consecutivos não são permitidos em nomes compartilhados.
- Todas as letras em um nome compartilhado deve estar em letra minúscula.
- Os nomes compartilhados devem ter de 3 a 63 caracteres de comprimento.
Nomes de diretório e arquivo
As regras de nomenclatura do serviço de Compartilhamento de Arquivos do Azure para nomes de diretório e arquivo são as seguintes:
- Os nomes de arquivo e diretório de compartilhamento são que preservam maiúsculas de minúsculas e não diferenciam maiúsculas de minúsculas.
- Os nomes de componentes de arquivo e diretório de compartilhamento não devem ter mais de 255 caracteres.
- Os nomes do Diretório de Compartilhamento não podem terminar com o caractere de barra (/). Se fornecido, será removido automaticamente.
- Os nomes de arquivo de compartilhamento não devem terminar com o caractere de barra (/).
- Os caracteres reservados de URL precisam ser escapados corretamente.
- Os seguintes caracteres não são permitidos:
" \ / : | < > * ?
- Caracteres de caminho de URL ilegal não são permitidos. Pontos de código como \uE000, embora válidos em nomes de arquivo NTFS, não são caracteres Unicode válidos. Além disso, não há permissão também para alguns caracteres ASCII ou Unicode, como caracteres de controle (0x00 a 0x1F, \u0081, etc.). Para regras que regem cadeias de caracteres Unicode em HTTP/1.1 , consulte RFC 2616, Seção 2.2: Regras Básicas e RFC 3987.
- Os seguintes nomes de arquivo não são permitidos: LPT1, LPT2, LPT3, LPT4, LPT5, LPT6, LPT7, LPT8, LPT9, COM1, COM2, COM3, COM4, COM5, COM6, COM7, COM8, COM9, PRN, AUX, NUL, CON, CLOCK$, caractere de ponto (.) e dois caracteres de ponto (..).
Nomes de metadados
Os metadados para um recurso de arquivos ou compartilhado são armazenados como pares com valor de nome associados a um recurso. Os diretórios não têm metadados. Os nomes de metadados devem seguir as regras de nomenclatura para identificadores C#.
Observe que os nomes de metadados preservam a forma com a qual foram criados, mas não diferenciam maiúsculas de minúsculas quando definidos ou lidos. Se dois ou mais cabeçalhos de metadados com o mesmo nome forem enviados para um recurso, o serviço do Azure File retornará o código de status 400 (Solicitação Incorreta).
Compartilhar Serviços
A API REST do Serviço de Compartilhamento de Arquivos fornece operações em contas e gerencia as propriedades do serviço de arquivo. Ele permite as operações de listagem e exclusão de compartilhamentos, obtenção e definição de propriedades do serviço de arquivo.
Depois de ter o SASToken, você poderá construir o shareServiceClient
com ${accountName}
, ${sasToken}
String shareServiceURL = String.format("https://%s.file.core.windows.net", ACCOUNT_NAME);
ShareServiceClient shareServiceClient = new ShareServiceClientBuilder().endpoint(shareServiceURL)
.sasToken(SAS_TOKEN).buildClient();
Compartilhar
O recurso do compartilhamento inclui os metadados e as propriedades desse compartilhamento. Ele permite as operações de criação, criação de instantâneo, exclusão de compartilhamentos, obtenção de propriedades de compartilhamento, definição de metadados, obtenção e definição de ACL (política de acesso). Obter e definir ACL (política de acesso) só pode ser usado pelo ShareClient com ConnectionString.
Compartilhar com SASToken
Depois de ter o SASToken, você poderá construir o cliente de compartilhamento com ${accountName}
, ${shareName}
, ${sasToken}
String shareURL = String.format("https://%s.file.core.windows.net", ACCOUNT_NAME);
ShareClient shareClient = new ShareClientBuilder().endpoint(shareURL)
.sasToken(SAS_TOKEN).shareName(shareName).buildClient();
Compartilhar com ConnectionString
Depois de ter o ConnectionString, você poderá construir o cliente de compartilhamento com ${accountName}
, ${shareName}
, ${connectionString}
String shareURL = String.format("https://%s.file.core.windows.net", ACCOUNT_NAME);
ShareClient shareClient = new ShareClientBuilder().endpoint(shareURL)
.connectionString(CONNECTION_STRING).shareName(shareName).buildClient();
Compartilhar com TokenCredential
Depois de ter o TokenCredential, você poderá construir o cliente de compartilhamento com ${accountName}
e ShareTokenIntent
${shareName}
.
ShareTokenIntent.BACKUP
especifica solicitações destinadas a operações de tipo de backup/administrador, o que significa que todas as ACLs de arquivo/diretório são ignoradas e permissões completas são concedidas. O usuário deve ter a permissão RBAC necessária para usar ShareTokenIntent.BACKUP
.
String shareURL = String.format("https://%s.file.core.windows.net", ACCOUNT_NAME);
ShareClient serviceClient = new ShareClientBuilder()
.endpoint(shareURL)
.credential(tokenCredential)
.shareTokenIntent(ShareTokenIntent.BACKUP)
.shareName(shareName)
.buildClient();
Diretório
O recurso de diretório inclui as propriedades para esse diretório. Ele permite as operações de criação, listagem, exclusão de diretórios ou subdiretórios ou arquivos, obtenção de propriedades, definição de metadados, listagem e força o fechamento dos identificadores.
Depois de ter o SASToken, você poderá construir o cliente de serviço de arquivo com ${accountName}
, ${shareName}
, ${directoryPath}
, ${sasToken}
String directoryURL = String.format("https://%s.file.core.windows.net", ACCOUNT_NAME);
ShareDirectoryClient directoryClient = new ShareFileClientBuilder().endpoint(directoryURL)
.sasToken(SAS_TOKEN).shareName(shareName).resourcePath(directoryPath).buildDirectoryClient();
Arquivo
O recurso de arquivo inclui as propriedades desse arquivo. Ele permite as operações de criação, upload, cópia, download, exclusão de arquivos ou intervalo dos arquivos, obtenção de propriedades, configuração de metadados, listagem e forçar o fechamento dos identificadores.
Depois de ter o SASToken, você poderá construir o cliente de serviço de arquivo com ${accountName}
, ${shareName}
, ${directoryPath}
, , ${fileName}
, ${sasToken}
String fileURL = String.format("https://%s.file.core.windows.net", ACCOUNT_NAME);
ShareFileClient fileClient = new ShareFileClientBuilder().connectionString(CONNECTION_STRING)
.endpoint(fileURL).shareName(shareName).resourcePath(directoryPath + "/" + fileName).buildFileClient();
Exemplos
As seções a seguir fornecem vários snippets de código que abrangem algumas das tarefas mais comuns do Serviço de Configuração, incluindo:
- Criar um compartilhamento
- Criar um instantâneo no Share
- Criar um diretório
- Criar um subdiretório
- Criar um arquivo
- Listar todos os compartilhamentos
- Listar todos os subdiretórios e arquivos
- Listar todos os intervalos no arquivo
- Excluir um compartilhamento
- Excluir um diretório
- Excluir um subdiretório
- Excluir um arquivo
- Copiar um arquivo
- Anular cópia de um arquivo
- Carregar dados no arquivo de armazenamento
- Carregar dados maiores que 4 MB no Arquivo de Armazenamento
- Carregar arquivo no arquivo de armazenamento
- Baixar dados do intervalo de arquivos
- Baixar arquivo do Arquivo de Armazenamento
- Obter propriedades de serviço de compartilhamento
- Definir propriedades de um serviço de compartilhamento
- Definir metadados de compartilhamento
- Obter uma política de acesso de compartilhamento
- Definir uma política de acesso de compartilhamento
- Obter identificadores no Diretório e no Arquivo
- Forçar alças de fechamento na ID do identificador
- Definir cota em Compartilhar
- Definir httpHeaders de arquivo
Criar um compartilhamento
Crie um compartilhamento na Conta de Armazenamento. Gera StorageException se o compartilhamento não for criado.
Tomando um ShareServiceClient em KeyConcept, ${shareServiceClient}
.
String shareName = "testshare";
shareServiceClient.createShare(shareName);
Criar um instantâneo no Share
Tomando um ShareServiceClient em KeyConcept, ${shareServiceClient}
.
String shareName = "testshare";
ShareClient shareClient = shareServiceClient.getShareClient(shareName);
shareClient.createSnapshot();
Criar um diretório
Tomando o shareClient inicializado acima, ${shareClient}
.
String dirName = "testdir";
shareClient.createDirectory(dirName);
Criar um subdiretório
Tomando o diretórioClient em KeyConcept, ${directoryClient}
.
String subDirName = "testsubdir";
directoryClient.createSubdirectory(subDirName);
criar um arquivo
Tomando o diretórioClient em KeyConcept, ${directoryClient}
.
String fileName = "testfile";
long maxSize = 1024;
directoryClient.createFile(fileName, maxSize);
Listar todos os compartilhamentos
Tomando o shareServiceClient em KeyConcept, ${shareServiceClient}
shareServiceClient.listShares();
Listar todos os subdiretórios e arquivos
Tomando o diretórioClient em KeyConcept, ${directoryClient}
directoryClient.listFilesAndDirectories();
Listar todos os intervalos no arquivo
Tomando o fileClient em KeyConcept, ${fileClient}
fileClient.listRanges();
Excluir um compartilhamento
Tomando o shareClient em KeyConcept, ${shareClient}
shareClient.delete();
Excluir um diretório
Tomando o shareClient em KeyConcept, ${shareClient}
.
String dirName = "testdir";
shareClient.deleteDirectory(dirName);
Excluir um subdiretório
Tomando o diretórioClient em KeyConcept, ${directoryClient}
.
String subDirName = "testsubdir";
directoryClient.deleteSubdirectory(subDirName);
Excluir um arquivo
Tomando o diretórioClient em KeyConcept, ${directoryClient}
.
String fileName = "testfile";
directoryClient.deleteFile(fileName);
Copiar um arquivo
Tomando o fileClient em KeyConcept, ${fileClient}
com cadeia de caracteres de URL de origem.
String sourceURL = "http://222.178.203.72:19005/whst/63/=lxZbbntmszehkdzbnqdzvhmcnvrzmds//myshare/myfile";
Duration pollInterval = Duration.ofSeconds(2);
SyncPoller<ShareFileCopyInfo, Void> poller = fileClient.beginCopy(sourceURL, (Map<String, String>) null, pollInterval);
Anular cópia de um arquivo
Tomando o fileClient em KeyConcept, ${fileClient}
com a resposta de informações de cópia retornada acima ${copyId}=[copyInfoResponse](#copy-a-file)
de .
fileClient.abortCopy("copyId");
Carregar dados no armazenamento
Tomando o fileClient em KeyConcept, ${fileClient}
com dados de "padrão" .
String uploadText = "default";
InputStream data = new ByteArrayInputStream(uploadText.getBytes(StandardCharsets.UTF_8));
fileClient.upload(data, uploadText.length());
Carregar dados maiores que 4 MB no armazenamento
Tomando o fileClient em KeyConcept, ${fileClient}
com dados de "padrão" .
byte[] data = "Hello, data sample!".getBytes(StandardCharsets.UTF_8);
long chunkSize = 4 * 1024 * 1024L;
if (data.length > chunkSize) {
for (int offset = 0; offset < data.length; offset += chunkSize) {
try {
// the last chunk size is smaller than the others
chunkSize = Math.min(data.length - offset, chunkSize);
// select the chunk in the byte array
byte[] subArray = Arrays.copyOfRange(data, offset, (int) (offset + chunkSize));
// upload the chunk
fileClient.uploadWithResponse(new ByteArrayInputStream(subArray), chunkSize, (long) offset, null, Context.NONE);
} catch (RuntimeException e) {
logger.error("Failed to upload the file", e);
if (Boolean.TRUE.equals(fileClient.exists())) {
fileClient.delete();
}
throw e;
}
}
} else {
fileClient.upload(new ByteArrayInputStream(data), data.length);
}
Carregar arquivo no armazenamento
Tomando o fileClient em KeyConcept, ${fileClient}
.
String filePath = "${myLocalFilePath}";
fileClient.uploadFromFile(filePath);
Baixar dados do intervalo de arquivos
Tomando o fileClient em KeyConcept, ${fileClient}
com o intervalo de 1024 a 2048.
ShareFileRange fileRange = new ShareFileRange(0L, 2048L);
OutputStream stream = new ByteArrayOutputStream();
fileClient.downloadWithResponse(stream, fileRange, false, null, Context.NONE);
Baixar arquivo do armazenamento
Tomando o fileClient em KeyConcept ${fileClient}
e baixe para o arquivo de filePath.
String filePath = "${myLocalFilePath}";
fileClient.downloadToFile(filePath);
Obter propriedades de serviço de compartilhamento
Tomando um ShareServiceClient em KeyConcept, ${shareServiceClient}
.
shareServiceClient.getProperties();
Definir propriedades de um serviço de compartilhamento
Tomando um ShareServiceClient em KeyConcept, ${shareServiceClient}
.
ShareServiceProperties properties = shareServiceClient.getProperties();
properties.getMinuteMetrics().setEnabled(true).setIncludeApis(true);
properties.getHourMetrics().setEnabled(true).setIncludeApis(true);
shareServiceClient.setProperties(properties);
Definir metadados de compartilhamento
Tomando o shareClient em KeyConcept, ${shareClient}
.
Map<String, String> metadata = Collections.singletonMap("directory", "metadata");
shareClient.setMetadata(metadata);
Obter uma política de acesso de compartilhamento
Tomando o shareClient em KeyConcept, ${shareClient}
.
shareClient.getAccessPolicy();
Definir uma política de acesso de compartilhamento
Tomando o shareClient em KeyConcept, ${shareClient}
.
ShareAccessPolicy accessPolicy = new ShareAccessPolicy().setPermissions("r")
.setStartsOn(OffsetDateTime.now(ZoneOffset.UTC))
.setExpiresOn(OffsetDateTime.now(ZoneOffset.UTC).plusDays(10));
ShareSignedIdentifier permission = new ShareSignedIdentifier().setId("mypolicy").setAccessPolicy(accessPolicy);
shareClient.setAccessPolicy(Collections.singletonList(permission));
Obter identificadores no arquivo de diretório
Tomando o diretórioClient em KeyConcept, ${directoryClient}
PagedIterable<HandleItem> handleItems = directoryClient.listHandles(null, true, Duration.ofSeconds(30), Context.NONE);
Forçar alças de fechamento na ID do identificador
Tomando o diretórioClient em KeyConcept e ${directoryClient}
a ID do identificador retornado acima ${handleId}=[handleItems](#get-handles-on-directory-file)
PagedIterable<HandleItem> handleItems = directoryClient.listHandles(null, true, Duration.ofSeconds(30), Context.NONE);
String handleId = handleItems.iterator().next().getHandleId();
directoryClient.forceCloseHandleWithResponse(handleId, Duration.ofSeconds(30), Context.NONE);
Definir cota no compartilhamento
Tomando o shareClient em KeyConcept, ${shareClient}
.
int quotaOnGB = 1;
shareClient.setPropertiesWithResponse(new ShareSetPropertiesOptions().setQuotaInGb(quotaOnGB), null, Context.NONE);
Definir httpheaders de arquivo
Tomando o fileClient em KeyConcept, ${fileClient}
.
ShareFileHttpHeaders httpHeaders = new ShareFileHttpHeaders().setContentType("text/plain");
fileClient.setProperties(1024, httpHeaders, null, null);
Solução de problemas
Geral
Quando você interage com o arquivo usando essa biblioteca de clientes Java, os erros retornados pelo serviço correspondem aos mesmos códigos http status retornados para solicitações de API REST. Por exemplo, se você tentar recuperar um compartilhamento que não existe em sua Conta de Armazenamento, um 404
erro será retornado, indicando Not Found
.
Cliente HTTP padrão
Por padrão, todas as bibliotecas de cliente usam o cliente HTTP do Netty. Adicionar a dependência acima configurará automaticamente a biblioteca de cliente para usar o cliente HTTP do Netty. A configuração ou a alteração do cliente HTTP é detalhada no wiki de clientes HTTP.
Biblioteca SSL padrão
Todas as bibliotecas de cliente, por padrão, usam a biblioteca SSL com o uso do Tomcat nativo para habilitar o desempenho de nível nativo para operações SSL. A biblioteca SSL é um uber jar que contém bibliotecas nativas para Linux/macOS/Windows e fornece melhor desempenho em comparação com a implementação SSL padrão no JDK. Para obter mais informações, incluindo como reduzir o tamanho da dependência, consulte a seção ajuste de desempenho da wiki.
Próximas etapas
Contribuição
Este projeto aceita contribuições e sugestões. A maioria das contribuições exige que você concorde com um CLA (Contrato de Licença do Colaborador) declarando que você tem o direito de nos conceder, e de fato concede, os direitos de usar sua contribuição. Para obter detalhes, visite https://cla.microsoft.com.
Quando você envia uma solicitação de pull, um bot do CLA determina automaticamente se você precisa fornecer um CLA e preencher a PR corretamente (por exemplo, rótulo, comentário). Basta seguir as instruções fornecidas pelo bot. Você só precisará fazer isso uma vez em todos os repositórios que usam nosso CLA.
Este projeto adotou o Código de Conduta de Software Livre da Microsoft. Para obter mais informações, confira as Perguntas frequentes sobre o Código de Conduta ou contate opencode@microsoft.com para enviar outras perguntas ou comentários.
Para obter detalhes sobre como contribuir para esse repositório, consulte o guia de contribuição.
- Bifurcar
- Criar seu branch de recurso (
git checkout -b my-new-feature
) - Confirmar suas alterações (
git commit -am 'Add some feature'
) - Enviar por push para o branch (
git push origin my-new-feature
) - Criar nova solicitação de pull