Подтвердить что ты не робот

конвертировать uuid в байт, который работает при использовании UUID.nameUUIDFromBytes(b)

Используя преобразование UUID в байт

public byte[] getIdAsByte(UUID uuid)
{
    ByteBuffer bb = ByteBuffer.wrap(new byte[16]);
    bb.putLong(uuid.getMostSignificantBits());
    bb.putLong(uuid.getLeastSignificantBits());
    return bb.array();
}

Однако, если я попытаюсь воссоздать UUID с помощью этой функции,

public UUID frombyte(byte[] b)
{
    return UUID.nameUUIDFromBytes(b);
}

Это не тот же UUID. Преобразование randomUUID назад и вперед возвращает два разных.

UUID u = UUID.randomUUID();
System.out.println(u.toString());
System.out.println(frombyte(getIdAsByte(u)).toString());

печатает:

1ae004cf-0f48-469f-8a94-01339afaec41
8b5d1a71-a4a0-3b46-bec3-13ab9ab12e8e
4b9b3361

Ответ 1

public class UuidUtils {
  public static UUID asUuid(byte[] bytes) {
    ByteBuffer bb = ByteBuffer.wrap(bytes);
    long firstLong = bb.getLong();
    long secondLong = bb.getLong();
    return new UUID(firstLong, secondLong);
  }

  public static byte[] asBytes(UUID uuid) {
    ByteBuffer bb = ByteBuffer.wrap(new byte[16]);
    bb.putLong(uuid.getMostSignificantBits());
    bb.putLong(uuid.getLeastSignificantBits());
    return bb.array();
  }
}

@Test
public void verifyUUIDBytesCanBeReconstructedBackToOriginalUUID() {
  UUID u = UUID.randomUUID();
  byte[] uBytes = UuidUtils.asBytes(u);
  UUID u2 = UuidUtils.asUuid(uBytes);
  Assert.assertEquals(u, u2);
}

@Test
public void verifyNameUUIDFromBytesMethodDoesNotRecreateOriginalUUID() {
  UUID u = UUID.randomUUID();
  byte[] uBytes = UuidUtils.asBytes(u);
  UUID u2 = UUID.nameUUIDFromBytes(uBytes);
  Assert.assertNotEquals(u, u2);
}

Ответ 2

потому что nameUUIDFromBytes создает определенный тип UUID (как состояния javadoc).

если вы хотите преобразовать байт [] обратно в UUID, вы должны использовать конструктор UUID. Оберните ByteBuffer вокруг байта [], прочитайте 2 longs и передайте их конструктору UUID.