Lire en anglais

Partager via


Base64FormattingOptions Énumération

Définition

Spécifie si les méthodes ToBase64CharArray et ToBase64String pertinentes insèrent des sauts de ligne dans leur résultat.

Cette énumération prend en charge une combinaison au niveau du bit de ses valeurs membres.

[System.Flags]
public enum Base64FormattingOptions
Héritage
Base64FormattingOptions
Attributs

Champs

InsertLineBreaks 1

Insère des sauts de ligne tous les 76 caractères dans la représentation sous forme de chaîne.

None 0

N’insère pas de sauts de ligne tous les 76 caractères dans la représentation sous forme de chaîne.

Exemples

L’exemple suivant appelle la Convert.ToBase64String(Byte[], Base64FormattingOptions) méthode avec un InsertLineBreaks argument pour insérer des sauts de ligne dans la chaîne générée par l’encodage d’un tableau d’octets de 100 éléments :

using System;

public class Example
{
   public static void Main()
   {
       // Define a byte array.
       var bytes = new byte[100];
       int originalTotal = 0;
       for (int ctr = 0; ctr <= bytes.GetUpperBound(0); ctr++) {
          bytes[ctr] = (byte)(ctr + 1);
          originalTotal += bytes[ctr];
       }
       // Display summary information about the array.
       Console.WriteLine("The original byte array:");
       Console.WriteLine("   Total elements: {0}", bytes.Length);
       Console.WriteLine("   Length of String Representation: {0}",
                         BitConverter.ToString(bytes).Length);
       Console.WriteLine("   Sum of elements: {0:N0}", originalTotal);
       Console.WriteLine();

       // Convert the array to a base 64 string.
       string s = Convert.ToBase64String(bytes,
                                         Base64FormattingOptions.InsertLineBreaks);
       Console.WriteLine("The base 64 string:\n   {0}\n", s);

       // Restore the byte array.
       Byte[] newBytes = Convert.FromBase64String(s);
       int newTotal = 0;
       foreach (var newByte in newBytes)
          newTotal += newByte;

       // Display summary information about the restored array.
       Console.WriteLine("   Total elements: {0}", newBytes.Length);
       Console.WriteLine("   Length of String Representation: {0}",
                         BitConverter.ToString(newBytes).Length);
       Console.WriteLine("   Sum of elements: {0:N0}", newTotal);
   }
}
// The example displays the following output:
//   The original byte array:
//      Total elements: 100
//      Length of String Representation: 299
//      Sum of elements: 5,050
//
//   The base 64 string:
//      AQIDBAUGBwgJCgsMDQ4PEBESExQVFhcYGRobHB0eHyAhIiMkJSYnKCkqKywtLi8wMTIzNDU2Nzg5
//   Ojs8PT4/QEFCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaW1xdXl9gYWJjZA==
//
//      Total elements: 100
//      Length of String Representation: 299
//      Sum of elements: 5,050

Comme le montre la sortie de l’exemple, le Convert.FromBase64String réussit à restaurer le tableau d’octets d’origine ; les caractères de saut de ligne sont ignorés pendant la conversion.

Remarques

Les Convert.ToBase64CharArray méthodes et Convert.ToBase64String convertissent la valeur d’un tableau d’entiers non signés 8 bits en une représentation sous forme de chaîne équivalente composée de 64 chiffres en base. La représentation sous forme de chaîne peut contenir un ou plusieurs sauts de ligne, où un saut de ligne est défini comme un caractère de retour chariot (U+000D) suivi d’un caractère de flux de ligne (U+000A). Les sauts de ligne étant considérés comme des espaces blancs dans un encodage en base 64, ils sont ignorés lors de la conversion d’une chaîne encodée en base 64 en tableau d’octets. Les sauts de ligne sont simplement pratiques lors de l’affichage de la chaîne encodée sur un contrôle ou un appareil tel qu’une fenêtre de console.

Les None valeurs et InsertLineBreaks s’excluent mutuellement. Par conséquent, bien que l’énumération Base64FormattingOptions soit marquée avec l’attribut FlagsAttribute , il n’est pas judicieux d’effectuer une combinaison au niveau du bit de ces deux valeurs.

S’applique à

Produit Versions
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1