Порядковый номер атрибутов objectUUID Active Directory в Java / Apache Directory Studio
Я подключаюсь к серверу Active Directory из Java. Я добавляю свойство:
env.put("java.naming.ldap.attributes.binary", "objectGUID");
и тогда я читаю objecUUID следующим образом:
Attribute a = result.getAttributes().get("objectUUID");
byte[] b = (byte[])a.get();
и отформатируйте это так:
String id = Hex.
encodeHexString(b).
replaceAll(
"(.{8})(.{4})(.{4})(.{4})(.{12})",
"$1-$2-$3-$4-$5"
)
);
В результате получился красивый формат UUID. Когда я хочу найти запись по ее UUID, я удаляю тире:
id = id.replaceAll("[^a-zA-Z0-9]+", "");
и затем вставьте обратную косую черту:
id = id.replaceAll("([a-zA-Z0-9]{2,2})", "\\\\$1");
Это все работает хорошо. У меня проблема с тем, что Apache Directory Studio показывает (например) UUID моего пользователя как:
8e591e3a-35ab-45cc-8dca-c5e451adc975
Когда мой код показывает UUID той же записи, что и:
3a1e598e-ab35-cc45-8dca-c5e451adc975
как вы можете видеть, старшие и младшие байты меняются местами на левые восемь байтов, но с правой стороны они идентичны. Это почему? Это кажется очень странным...
.rm
1 ответ
Если вы посмотрите здесь:
https://en.wikipedia.org/wiki/Universally_unique_identifier
Name Length (Bytes) Length (Hex Digits) Contents
time_low 4 8 integer giving the low 32 bits of the time
time_mid 2 4 integer giving the middle 16 bits of the time
time_hi_and_version 2 4 4-bit "version" in the most significant bits, followed by the high 12 bits of the time
clock_seq_hi_and_res clock_seq_low 2 4 1-3 bit "variant" in the most significant bits, followed by the 13-15 bit clock sequence
node 6 12 the 48-bit node id
Вы можете видеть, что первые 3 сегмента являются целыми числами / шортами, связанными с данными "времени", и, следовательно, имеют порядковый номер, тогда как другие разделы являются просто двоичными данными и поэтому не имеют.