Question

Question: existe-t-il un meilleur moyen de le faire?

VB.Net

Function GuidToBase64(ByVal guid As Guid) As String
    Return Convert.ToBase64String(guid.ToByteArray).Replace("/", "-").Replace("+", "_").Replace("=", "")
End Function

Function Base64ToGuid(ByVal base64 As String) As Guid
    Dim guid As Guid
    base64 = base64.Replace("-", "/").Replace("_", "+") & "=="

    Try
        guid = New Guid(Convert.FromBase64String(base64))
    Catch ex As Exception
        Throw New Exception("Bad Base64 conversion to GUID", ex)
    End Try

    Return guid
End Function

C #

public string GuidToBase64(Guid guid)
{
    return Convert.ToBase64String(guid.ToByteArray()).Replace("/", "-").Replace("+", "_").Replace("=", "");
}

public Guid Base64ToGuid(string base64)
{
   Guid guid = default(Guid);
   base64 = base64.Replace("-", "/").Replace("_", "+") + "==";

   try {
       guid = new Guid(Convert.FromBase64String(base64));
   }
   catch (Exception ex) {
       throw new Exception("Bad Base64 conversion to GUID", ex);
   }

   return guid;
}
Était-ce utile?

La solution

Je comprends que la raison pour laquelle vous découpez == est que vous pouvez être certain que, pour le GUID (de 16 octets), la chaîne codée toujours se terminera par ==. Vous pouvez donc enregistrer 2 caractères à chaque conversion.

A côté du point @Skurmedal déjà mentionné (devrait émettre une exception en cas de chaîne non valide en entrée), je pense que le code que vous avez posté est juste suffisant.

Autres conseils

Vous pouvez consulter ce site: http://prettycode.org/2009/11/12/short-guid/

Cela semble très proche de ce que vous faites.

public class ShortGuid
{
    private readonly Guid guid;
    private readonly string value;

    /// <summary>Create a 22-character case-sensitive short GUID.</summary>
    public ShortGuid(Guid guid)
    {
        if (guid == null)
        {
            throw new ArgumentNullException("guid");
        }

        this.guid = guid;
        this.value = Convert.ToBase64String(guid.ToByteArray())
            .Substring(0, 22)
            .Replace("/", "_")
            .Replace("+", "-");
    }

    /// <summary>Get the short GUID as a string.</summary>
    public override string ToString()
    {
        return this.value;
    }

    /// <summary>Get the Guid object from which the short GUID was created.</summary>
    public Guid ToGuid()
    {
        return this.guid;
    }

    /// <summary>Get a short GUID as a Guid object.</summary>
    /// <exception cref="System.ArgumentNullException"></exception>
    /// <exception cref="System.FormatException"></exception>
    public static ShortGuid Parse(string shortGuid)
    {
        if (shortGuid == null)
        {
            throw new ArgumentNullException("shortGuid");
        }
        else if (shortGuid.Length != 22)
        {
            throw new FormatException("Input string was not in a correct format.");
        }

        return new ShortGuid(new Guid(Convert.FromBase64String
            (shortGuid.Replace("_", "/").Replace("-", "+") + "==")));
    }

    public static implicit operator String(ShortGuid guid)
    {
        return guid.ToString();
    }

    public static implicit operator Guid(ShortGuid shortGuid)
    {
        return shortGuid.guid;
    }
}

L'un des problèmes liés à l'utilisation de cette technique pour formater un GUID à utiliser dans une URL ou un nom de fichier est que deux GUID distincts peuvent produire deux valeurs qui ne diffèrent que par les cas, par exemple:

    var b1 = GuidToBase64(new Guid("c9d045f3-e21c-46d0-971d-b92ebc2ab83c"));
    var b2 = GuidToBase64(new Guid("c9d045f3-e21c-46d0-971d-b92ebc2ab8a4"));
    Console.WriteLine(b1);  // 80XQyRzi0EaXHbkuvCq4PA
    Console.WriteLine(b2);  // 80XQyRzi0EaXHbkuvCq4pA

Étant donné que les URL sont parfois interprétées comme ne faisant pas la distinction entre les majuscules et les minuscules, les chemins et les noms de fichiers Windows ne respectent pas la casse. cela pourrait entraîner des collisions.

Si votre méthode ne peut pas convertir le base64 qui lui est transmis en un GUID, ne devriez-vous pas lancer une exception? Les données transmises à la méthode sont clairement erronées.

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top