Maison >base de données >tutoriel mysql >L'encodage Base64 est-il une méthode efficace pour le stockage compact des UUID ?
Encodage Base64 pour le stockage UUID compact
Question :
Y a-t-il un problème avec le stockage un UUID sous forme de chaîne base64 avec les caractères "==" de fin supprimés pour minimiser espace ?
Réponse :
L'encodage Base64 peut minimiser efficacement la taille d'un UUID tout en conservant la lisibilité. Il est cependant essentiel de décoder correctement la chaîne pour récupérer l'UUID d'origine.
Voici une implémentation pratique en Java :
import org.apache.commons.codec.binary.Base64; public class UUIDBase64 { public static String uuidToBase64(String uuid) { UUID myUUID = UUID.fromString(uuid); ByteBuffer bb = ByteBuffer.wrap(new byte[16]); bb.putLong(myUUID.getMostSignificantBits()); bb.putLong(myUUID.getLeastSignificantBits()); return new Base64().encodeBase64URLSafeString(bb.array()); } public static String uuidFromBase64(String base64UUID) { Base64 base64 = new Base64(); byte[] bytes = base64.decodeBase64(base64UUID); ByteBuffer bb = ByteBuffer.wrap(bytes); UUID myUUID = new UUID(bb.getLong(), bb.getLong()); return myUUID.toString(); } }
Utilisation :
String uuid = "6fcb514b-b878-4c9d-95b7-8dc3a7ce6fd8"; String base64UUID = UUIDBase64.uuidToBase64(uuid); System.out.println("Base64 UUID: " + base64UUID); String decodedUUID = UUIDBase64.uuidFromBase64(base64UUID); System.out.println("Decoded UUID: " + decodedUUID); System.out.println("Equal?: " + uuid.equals(decodedUUID));
Cette approche supprime le remplissage "==" de fin pour produire une chaîne compacte de 22 caractères qui peut être facilement décodée. à l'UUID d'origine.
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!