Comparar opções de armazenamento
O .NET Multi-Platform App UI (MAUI) fornece várias opções de armazenamento para armazenar dados em cache localmente em um dispositivo, dependendo da natureza, estrutura e tamanho dos dados. As três opções mais usadas para armazenar dados localmente em um aplicativo .NET MAUI são:
- Preferências: Armazena dados em pares chave-valor
- Sistema de arquivos: Armazena arquivos soltos diretamente no dispositivo por meio do acesso ao sistema de arquivos
- Banco de dados: armazena dados em um banco de dados relacional
Nesta unidade, analisamos essas opções de armazenamento e as situações para as quais cada opção é mais apropriada.
Quando usar preferências
As preferências são convenientes ao se trabalhar com dados simples, como seleções de usuário. Eles geralmente são usados para permitir que os usuários configurem o aplicativo. Você armazena esses dados como um conjunto de pares chave-valor. Por exemplo, suponha que você deseja que o usuário possa especificar se o aplicativo deve salvar o nome de usuário e senha dele entre sessões. Você pode armazenar a escolha do usuário nas Preferências.
O código a seguir mostra como armazenar um valor booliano registrado na variável saveLoginDetails
em uma preferência nomeada SaveLogin
e, em seguida, ler esses dados novamente. Observe que o método Get
espera que você forneça um valor padrão se a preferência especificada não for encontrada:
bool saveLoginDetails = ...;
...
Preferences.Set("SaveLogin", saveLoginDetails);
...
var savedPreference = Preferences.Get("SaveLogin", false);
A classe Preferences
também contém métodos para determinar se existe uma preferência nomeada (ContainsKey
), excluir uma preferência (Remove
) e remover todos os dados de preferência (Clear
).
Observação
Você só deve armazenar tipos de dados simples como preferências. Não é possível armazenar referências a objetos grandes, como listas, coleções e matrizes. Para esse tipo de dados, use o sistema de arquivos ou um banco de dados.
Quando usar o sistema de arquivos
Dispositivos móveis e desktop têm um sistema de arquivos com uma estrutura de diretórios hierárquica de pastas e arquivos. É conveniente usar o sistema de arquivos quando você tem arquivos soltos, como XML, binário ou arquivos de texto. Por exemplo, suponha que você deseja armazenar dados de log localmente no dispositivo. Você pode criar um arquivo de texto, salvar esse arquivo sistema de arquivos e gravar logs nele conforme os eventos acontecerem. Você também pode serializar estruturas de dados grandes em um arquivo e armazená-lo em cache localmente no sistema de arquivos se precisar salvar quando o aplicativo for desligado. Quando o aplicativo for reiniciado, você poderá ler novamente esses dados na memória. O código a seguir mostra exemplos de serialização de dados em um arquivo e salvamento desse arquivo e, em seguida, a leitura dos dados de volta e a desserialização deles na memória. Aqui, usamos JSON para o formato de serialização, mas você pode salvar os dados em qualquer formato que achar mais apropriado para a natureza dos dados e os requisitos de segurança do aplicativo.
using System.Text.Json;
using System.IO;
// Data to be written to the file system, and read back later
List<Customer> customers = ...;
// Serialize and save
string fileName = ...;
var serializedData = JsonSerializer.Serialize(customers);
File.WriteAllText(fileName, serializedData);
...
// Read and deserialize
var rawData = File.ReadAllText(fileName);
customers = JsonSerializer.Deserialize<List<Customer>>(rawData);
Acessar a área restrita do aplicativo
Quando você estiver trabalhando com arquivos soltos, como os arquivos XML, precisará armazená-los em um local adequado no sistema de arquivos. Alguns desses dados podem ser confidenciais e você não deseja salvá-los em um local onde outros aplicativos ou usuários possam acessá-los facilmente. Os aplicativos .NET MAUI fornecem a área restrita do aplicativo. A área restrita do aplicativo é uma área privada com a qual seu aplicativo pode funcionar. Por padrão, nenhum outro aplicativo pode acessar essa área que não seja o sistema operacional. Você pode acessar a área restrita usando a propriedade estática AppDataDirectory
da classe FileSystem
:
string path = FileSystem.AppDataDirectory;
Nesse código, a variável path
contém o caminho do arquivo para o local onde você pode armazenar arquivos para o aplicativo usar. Você pode ler e gravar dados em arquivos nesta pasta usando as técnicas mostradas na seção Quando usar o sistema de arquivos.
Observação
A propriedade FileSystem.AppDataDirectory
é uma abstração de um caminho específico do dispositivo e é avaliada como pastas diferentes no Android, no iOS e no WinUI3. Essa abstração permite que você escreva um código que referencie a área restrita de uma maneira independente da plataforma na qual ela é executada. Use essa abstração em vez de referenciar explicitamente um caminho específico do dispositivo em seu código.
Diretrizes para salvar dados em aplicativos iOS
A Apple tem diretrizes de iOS para o local em que os arquivos devem ser armazenados. Há dois locais de pasta principais:
A pasta Biblioteca: Conforme descrito anteriormente, a propriedade
FileSystem.AppDataDirectory
retorna essa pasta. Use a pasta Biblioteca ao armazenar dados gerados pelo aplicativo.A pasta Documentos: O snippet de código a seguir mostra como referenciar essa pasta na variável
docFolder
. Use a pasta Documentos para armazenar apenas dados gerados pelo usuário. Esses dados são criados em resposta direta a uma ação do usuário. Por exemplo, se você estivesse criando um aplicativo de edição de texto, como o Microsoft Word, você armazenaria o documento na pasta Documentos.string docFolder = Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments);
Quando usar um banco de dados
É uma boa ideia usar um banco de dados local quando você tem relações entre dados ou quando quer filtrar os dados ao longo do tempo. Por exemplo: no cenário de redes sociais, cada postagem contém dados sobre ela, como o carimbo de data/hora e o conteúdo. No entanto, cada postagem também tem uma relação com um usuário que criou a postagem. Faz sentido representar essa relação em um banco de dados para impedir a duplicação de dados entre postagens e também melhorar a eficiência da pesquisa de dados.
Um banco de dados SQLite é um arquivo e você precisa armazená-lo em um local apropriado. Idealmente, você deve criar uma pasta na pasta AppDataDirectory
na área restrita e criar o banco de dados nessa pasta.