Wie kann ich eine UUID in C # generieren?

136

Ich erstelle programmgesteuert eine IDL-Datei. Wie erstelle ich programmgesteuert UUIDs für die Schnittstellen und Methoden?

Kann ich die UUID programmgesteuert generieren?

Uma Shankar Subramani
quelle
24
Du meinst Guid.NewGuid()?
SLaks

Antworten:

219

Sie suchen wahrscheinlich System.Guid.NewGuid().

Tudor
quelle
33
Sie können auch String UUID = Guid.NewGuid (). ToString ()
Justin
10
GUID und UUID sind alle gleich?
Uma Shankar Subramani
17
@Uma Shankar Subramani: GUID = Global Unique Identifier, UUID = Universally Unique Identifier. Unterschiedliche Wörter für das gleiche Konzept.
Tudor
1
Wenn Sie die GUID als eine Zeichenfolge formatieren möchten, die sich von der Standardzeichenfolge unterscheidet, können Sie die ToString(string format)Überladung verwenden, die einen von mehreren Formatspezifizierern akzeptiert.
Michiel van Oosterhout
7
Sie sollten dies wahrscheinlich tun, System.Guid.NewGuid().ToString("B").ToUpper()wenn Sie mit einigen MS Build-Tools kompatibel sein möchten, die UUIDs in Kleinbuchstaben nicht verstehen. Beispielsweise haben vdprojSetup-Projekte UUIDs in Großbuchstaben und lösen eine Ausnahme aus, wenn Sie sie in Kleinbuchstaben angeben.
Mark Lakata
43

Seien Sie vorsichtig: Während die Zeichenfolgendarstellungen für .NET Guid und (RFC4122) UUID identisch sind, ist das Speicherformat nicht identisch . .NET handelt in den ersten drei GuidTeilen mit Little-Endian-Bytes .

Wenn Sie die Bytes übertragen (z. B. als base64), können Sie sie nicht einfach verwenden Guid.ToByteArray()und codieren. Sie benötigen Array.Reversedie ersten drei Teile (Daten1-3).

Ich mache es so:

var rfc4122bytes = Convert.FromBase64String("aguidthatIgotonthewire==");
Array.Reverse(rfc4122bytes,0,4);
Array.Reverse(rfc4122bytes,4,2);
Array.Reverse(rfc4122bytes,6,2);
var guid = new Guid(rfc4122bytes);

In dieser Antwort finden Sie die spezifischen Details zur .NET-Implementierung.

Bearbeiten : Dank an Jeff Walker, Code Ranger, für den Hinweis, dass die Interna für das Format des Byte-Arrays, das in den Byte-Array-Konstruktor und ein- und ausgeht, nicht relevant sind ToByteArray().

Ben Mosher
quelle
Hinweis: Mir ist klar, dass das OP wahrscheinlich gemeint ist Guid(da es für eine IDL vorgesehen ist), aber ich bin gerade darauf gestoßen. Also los, Binger und Googler.
Ben Mosher
1
Ich kann das nicht testen, aber sind Sie sicher, dass Sie den BitConverter.IsLittleEndian überprüfen sollten, anstatt nur immer umzukehren. In den Dokumenten für Guid.ToByteArray () wird die Bytereihenfolge als Little Endian aufgerufen und angegeben, dass der Konstruktor übereinstimmt. Die Spezifikation für GUID ist Little Endian. Ich würde denken, dass dies unabhängig von der Maschinenbyte-Reihenfolge sein sollte.
Jeff Walker Code Ranger
@ JeffWalkerCodeRanger: von Eric Lippert, vor langer
Ben Mosher
Ich sehe nicht, wie der Eric Lippert-Link die Frage beantwortet. Wenn ich mir den Mono-Code unter github.com/mono/mono/blob/master/mcs/class/corlib/System/… ansehe , sehe ich immer davon aus, dass die Bytes unabhängig von der nativen Endianness in Little-Endian-Reihenfolge vorliegen. Das passt zu meinem Verständnis, dass es, wenn es von der Plattform abhängt, nicht der Semantik der MS-API oder der Spezifikation entspricht. Wenn man sich die zerlegte mscorelib ansieht, scheint man anzunehmen, dass die Bytes im Array ebenfalls in Little-Endian-Reihenfolge vorliegen.
Jeff Walker Code Ranger
Sieht so aus, als hättest du recht. Während das interne Speicherformat endianness-sensitiv ist, sind der Konstruktor und ToByteArraynicht; Sie sind immer lil'endian. Eingehende bearbeiten.
Ben Mosher
3

Hier ist eine clientseitige "sequentielle Guid" -Lösung.

http://www.pinvoke.net/default.aspx/rpcrt4.uuidcreate

using System;
using System.Runtime.InteropServices;


namespace MyCompany.MyTechnology.Framework.CrossDomain.GuidExtend
{
    public static class Guid
    {

        /*

        Original Reference for Code:
        http://www.pinvoke.net/default.aspx/rpcrt4/UuidCreateSequential.html

        */


        [DllImport("rpcrt4.dll", SetLastError = true)]
        static extern int UuidCreateSequential(out System.Guid guid);

        public static System.Guid NewGuid()
        {
            return CreateSequentialUuid();
        }


        public static System.Guid CreateSequentialUuid()
        {
            const int RPC_S_OK = 0;
            System.Guid g;
            int hr = UuidCreateSequential(out g);
            if (hr != RPC_S_OK)
                throw new ApplicationException("UuidCreateSequential failed: " + hr);
            return g;
        }


        /*

        Text From URL above:

        UuidCreateSequential (rpcrt4)

        Type a page name and press Enter. You'll jump to the page if it exists, or you can create it if it doesn't.
        To create a page in a module other than rpcrt4, prefix the name with the module name and a period.
        . Summary
        Creates a new UUID 
        C# Signature:
        [DllImport("rpcrt4.dll", SetLastError=true)]
        static extern int UuidCreateSequential(out Guid guid);


        VB Signature:
        Declare Function UuidCreateSequential Lib "rpcrt4.dll" (ByRef id As Guid) As Integer


        User-Defined Types:
        None.

        Notes:
        Microsoft changed the UuidCreate function so it no longer uses the machine's MAC address as part of the UUID. Since CoCreateGuid calls UuidCreate to get its GUID, its output also changed. If you still like the GUIDs to be generated in sequential order (helpful for keeping a related group of GUIDs together in the system registry), you can use the UuidCreateSequential function.

        CoCreateGuid generates random-looking GUIDs like these:

        92E60A8A-2A99-4F53-9A71-AC69BD7E4D75
        BB88FD63-DAC2-4B15-8ADF-1D502E64B92F
        28F8800C-C804-4F0F-B6F1-24BFC4D4EE80
        EBD133A6-6CF3-4ADA-B723-A8177B70D268
        B10A35C0-F012-4EC1-9D24-3CC91D2B7122



        UuidCreateSequential generates sequential GUIDs like these:

        19F287B4-8830-11D9-8BFC-000CF1ADC5B7
        19F287B5-8830-11D9-8BFC-000CF1ADC5B7
        19F287B6-8830-11D9-8BFC-000CF1ADC5B7
        19F287B7-8830-11D9-8BFC-000CF1ADC5B7
        19F287B8-8830-11D9-8BFC-000CF1ADC5B7



        Here is a summary of the differences in the output of UuidCreateSequential:

        The last six bytes reveal your MAC address 
        Several GUIDs generated in a row are sequential 
        Tips & Tricks:
        Please add some!

        Sample Code in C#:
        static Guid UuidCreateSequential()
        {
           const int RPC_S_OK = 0;
           Guid g;
           int hr = UuidCreateSequential(out g);
           if (hr != RPC_S_OK)
             throw new ApplicationException
               ("UuidCreateSequential failed: " + hr);
           return g;
        }



        Sample Code in VB:
        Sub Main()
           Dim myId As Guid
           Dim code As Integer
           code = UuidCreateSequential(myId)
           If code <> 0 Then
             Console.WriteLine("UuidCreateSequential failed: {0}", code)
           Else
             Console.WriteLine(myId)
           End If
        End Sub




        */








    }
}

Schlüsselwörter: CreateSequentialUUID SequentialUUID

granadaCoder
quelle
0

Ich habe einen GitHub Gist mit einer Java-ähnlichen UUID-Implementierung in C #: https://gist.github.com/rickbeerendonk/13655dd24ec574954366

Die UUID kann wie in Java aus den niedrigsten und höchstwertigen Bits erstellt werden. Es macht sie auch sichtbar. Die Implementierung hat eine explizite Konvertierung in eine GUID und eine implizite Konvertierung von einer GUID.

Rick Beerendonk
quelle