Maison > Java > javaDidacticiel > Interprétation des nouvelles fonctionnalités de Java8--Base64

Interprétation des nouvelles fonctionnalités de Java8--Base64

零下一度
Libérer: 2017-06-17 14:10:20
original
1885 Les gens l'ont consulté

Cet article présente principalement les informations pertinentes de la nouvelle fonctionnalité de Java8, Base64, en détail. Il a une certaine valeur de référence.

Le codage BASE64 est un caractère couramment utilisé. est utilisé dans de nombreux endroits. Mais base64 n’est pas un algorithme de chiffrement et de déchiffrement dans le domaine de la sécurité. L'effet de sécurité est très médiocre et il est facile de le déchiffrer. Sa fonction principale devrait être l'exactitude des données transmises. Certaines passerelles ou systèmes ne peuvent utiliser que des caractères ASCII. Base64 est une méthode utilisée pour convertir des données de caractères non ASCII en caractères ASCII, et base64 est particulièrement adapté à la transmission rapide de données sous les protocoles http et mime.

API pour l'implémentation de Base64 dans le JDK

Avant le JDK1.6, il n'y avait pas de classe d'implémentation Base64 pour les classes principales du JDK. Sun /Sun.misc.BASE64Encoder et sun.misc.BASE64Decoder dans Oracle JDK L'avantage de leur utilisation est qu'ils n'ont pas besoin de s'appuyer sur des bibliothèques de classes tierces. supprimé dans les versions futures (la compilation avec maven émettra un avertissement), et les performances ne sont pas bonnes, il y aura des tests de performances plus tard.

JDK1.6 a ajouté une autre implémentation Base64, javax.xml.bind.DatatypeConverter avec deux méthodes statiques parseBase64Binary et printBase64Binary, cachées dans le package javax.xml.bind Ci-dessous, non connu de nombreux développeurs.

Dans Java 8, l'API d'encodage et de décodage BASE64 est implémentée sous le package java.util, et les performances sont bonnes, et l'API est simple et facile à comprendre. Vous trouverez ci-dessous un exemple d'utilisation de. cette classe.

java.util.Base64

Cette classe fournit un ensemble de méthodes statiques pour obtenir les trois codecs BASE64 suivants :

1) Encodage de base : il s'agit d'un encodage BASE64 standard, utilisé pour gérer les besoins courants


// 编码
String asB64 = Base64.getEncoder().encodeToString("some string".getBytes("utf-8"));
System.out.println(asB64); // 输出为: c29tZSBzdHJpbmc=
// 解码
byte[] asBytes = Base64.getDecoder().decode("c29tZSBzdHJpbmc=");
System.out.println(new String(asBytes, "utf-8")); // 输出为: some string
Copier après la connexion

2) Encodage d'URL : utiliser des traits de soulignement Remplacer la barre oblique inverse "/" dans l'URL


String urlEncoded = Base64.getUrlEncoder().encodeToString("subjects?abcd".getBytes("utf-8"));
System.out.println("Using URL Alphabet: " + urlEncoded);
// 输出为:
Using URL Alphabet: c3ViamVjdHM_YWJjZA==
Copier après la connexion

3) Encodage MIME : utilise des caractères alphanumériques de base pour produire une sortie BASE64 et est compatible avec le format MIME : chaque La ligne de sortie ne doit pas dépasser 76 caractères et chaque ligne doit se terminer par le caractère « rn ».


StringBuilder sb = new StringBuilder();
for (int t = 0; t < 10; ++t) {
 sb.append(UUID.randomUUID().toString());
}
byte[] toEncode = sb.toString().getBytes("utf-8");
String mimeEncoded = Base64.getMimeEncoder().encodeToString(toEncode);
System.out.println(mimeEncoded);
Copier après la connexion

Implémentation tierce de l'API Base64

Le premier est Apache couramment utilisé Commons Codec org.apache.commons.codec.binary.Base64 dans la bibliothèque ;
La deuxième est la méthode statique com.google.common.io.BaseEncoding.base64() dans la bibliothèque Google Guava ;
La troisième ; Le premier est net.iharder.Base64, ce package jar n'est qu'une classe
Le dernier est MigBase64, qui est connu comme la vitesse d'encodage Base64 la plus rapide, et il a été implémenté il y a 10 ans ; maintenez ce titre maintenant. Sachez

Test de performances d'encodage Base64

Ce qui précède mentionne un total de 7 façons d'implémenter l'encodage Base64, 3 dans Jdk et 4 chez des tiers, une fois que vous avez le choix, il faut les comparer. Les tests de performances sont le moyen le plus direct

Définissez d'abord deux interfaces
.


private static interface Base64Codec
  {
    public String encode(final byte[] data);
    public byte[] decode(final String base64) throws IOException;
  }
  private static interface Base64ByteCodec
  {
    public byte[] encodeBytes(final byte[] data);
    public byte[] decodeBytes(final byte[] base64) throws IOException;
  }
Copier après la connexion

La différence entre les deux interfaces est que l'un des paramètres de la méthode d'interface reçoit un tableau d'octets et renvoie un tableau d'octets, car byte->byte est comparé à String->byte ou byte-> les performances de String seront plus rapides, alors séparez deux groupes pour les tests


private static final Base64Codec[] m_codecs = { new GuavaImpl(), new JavaXmlImpl(),
    new Java8Impl(), new SunImpl(), new ApacheImpl(),new MiGBase64Impl(),new IHarderImpl() };
private static final Base64ByteCodec[] m_byteCodecs = {
    new ApacheImpl(), new Java8Impl(),new MiGBase64Impl(),new IHarderImpl() };
Copier après la connexion

Comme le montre le ci-dessus, il n'y a que 4 API qui prennent en charge byte->byte ;

7 classes d'implémentation Base64


private static class Java8Impl implements Base64Codec, Base64ByteCodec
  {
    private final Base64.Decoder m_decoder = Base64.getDecoder();
    private final Base64.Encoder m_encoder = Base64.getEncoder();
    @Override
    public String encode(byte[] data) {
      return m_encoder.encodeToString(data);
    }
    @Override
    public byte[] decode(String base64) throws IOException {
      return m_decoder.decode(base64);
    }
    public byte[] encodeBytes(byte[] data) {
      return m_encoder.encode( data );
    }
    public byte[] decodeBytes(byte[] base64) throws IOException {
      return m_decoder.decode( base64 );
    }
  }
  private static class JavaXmlImpl implements Base64Codec //no byte[] implementation
  {
    public String encode(byte[] data) {
      return DatatypeConverter.printBase64Binary( data );
    }
    public byte[] decode(String base64) throws IOException {
      return DatatypeConverter.parseBase64Binary( base64 );
    }
  }
..............
Copier après la connexion

Les codes suivants sont essentiellement diverses API. Le code pour implémenter Base64 ne sera pas répertorié en détail.

La méthode de test principale consiste à générer 100 millions de nombres aléatoires, à les diviser en blocs de 100 octets ou 1 000 octets, puis à les encoder et à les décoder respectivement, et à enregistrer l'heure, comme suit


private static TestResult testByteCodec( final Base64ByteCodec codec, final List<byte[]> buffers ) throws IOException {
    final List<byte[]> encoded = new ArrayList<byte[]>( buffers.size() );
    final long start = System.currentTimeMillis();
    for ( final byte[] buf : buffers )
      encoded.add( codec.encodeBytes(buf) );
    final long encodeTime = System.currentTimeMillis() - start;
    final List<byte[]> result = new ArrayList<byte[]>( buffers.size() );
    final long start2 = System.currentTimeMillis();
    for ( final byte[] ar : encoded )
      result.add( codec.decodeBytes(ar) );
    final long decodeTime = System.currentTimeMillis() - start2;
    for ( int i = 0; i < buffers.size(); ++i )
    {
      if ( !Arrays.equals( buffers.get( i ), result.get( i ) ) )
        System.out.println( "Diff at pos = " + i );
    }
    return new TestResult( encodeTime / 1000.0, decodeTime / 1000.0 );
  }
Copier après la connexion

Résultats des tests

Paramètres jvm : -Xms512m -Xmx4G

Tout est évident. D'après ce qui précède, on peut voir que les performances de sun ne sont pas très bonnes. Les performances d'IHarder et de MigBase64 sont acceptables. ce résultat de test, le nouveau java8 base64 fonctionne le plus rapidement. Eh bien, javaXml est le deuxième meilleur.

Résumé

Si vous avez besoin d'un codec Base64 performant et fiable, n'en cherchez pas en dehors du JDK, utilisez java dans java8 .util.Base64 et javax.xml.bind.DatatypeConverter, qui sont profondément cachés dans java6, sont tous deux de bons choix.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal