Intereting Posts
Обновление MongoDB: как проверить, удалось или не удалось выполнить обновление? Использовать PHP для генерации случайного десятичного числа до двух децимал Не удалось подключиться к почтовому серверу на порту «localhost» 25, проверьте свой «SMTP», Обновить статус ответа посетителей – API календаря Google (PHP) Какие функции необходимы для ввода защищенных форм? AWS Cloudfront + Load Balancer, url изменяется с основного домена на субдомен балансировки нагрузки Нестатический метод … не следует называть статически sql-запрос с двумя объединениями и простая логика Перенаправление адреса заголовка Php не работает Сравнение массива PHP и поиск совпадающих и несогласованных элементов Как читать один файл внутри zip-архива Обработчик событий Laravel 5 не стреляет Как установить cron job url для codeigniter? Создание функции php для возврата результатов mysql php str_ireplace без потери дела

Функция PHP для генерации v4 UUID

Таким образом, я делал некоторые копания вокруг, и я пытался объединить функцию, которая генерирует действительный UUID v4 в PHP. Это самое близкое мне место. Мои знания в шестнадцатеричном, десятичном, двоичном, побитовые операторы PHP и тому подобное почти не существуют. Эта функция генерирует действительный UUID v4 до одной области. UUID v4 должен быть в форме:

xxxxxxxx-xxxx- 4 xxx- y xxx-xxxxxxxxxxxx

где y – 8, 9, A или B. Здесь функции терпят неудачу, поскольку они не придерживаются этого.

Я надеялся, что кто-то с большим количеством знаний, чем я, в этой области, может одолжить мне руку и помочь мне исправить эту функцию, чтобы она придерживалась этого правила.

Функция следующая:

<?php function gen_uuid() { $uuid = array( 'time_low' => 0, 'time_mid' => 0, 'time_hi' => 0, 'clock_seq_hi' => 0, 'clock_seq_low' => 0, 'node' => array() ); $uuid['time_low'] = mt_rand(0, 0xffff) + (mt_rand(0, 0xffff) << 16); $uuid['time_mid'] = mt_rand(0, 0xffff); $uuid['time_hi'] = (4 << 12) | (mt_rand(0, 0x1000)); $uuid['clock_seq_hi'] = (1 << 7) | (mt_rand(0, 128)); $uuid['clock_seq_low'] = mt_rand(0, 255); for ($i = 0; $i < 6; $i++) { $uuid['node'][$i] = mt_rand(0, 255); } $uuid = sprintf('%08x-%04x-%04x-%02x%02x-%02x%02x%02x%02x%02x%02x', $uuid['time_low'], $uuid['time_mid'], $uuid['time_hi'], $uuid['clock_seq_hi'], $uuid['clock_seq_low'], $uuid['node'][0], $uuid['node'][1], $uuid['node'][2], $uuid['node'][3], $uuid['node'][4], $uuid['node'][5] ); return $uuid; } ?> 

Спасибо всем, кто может мне помочь.

Из этого комментария в руководстве PHP вы можете использовать следующее:

 function gen_uuid() { return sprintf( '%04x%04x-%04x-%04x-%04x-%04x%04x%04x', // 32 bits for "time_low" mt_rand( 0, 0xffff ), mt_rand( 0, 0xffff ), // 16 bits for "time_mid" mt_rand( 0, 0xffff ), // 16 bits for "time_hi_and_version", // four most significant bits holds version number 4 mt_rand( 0, 0x0fff ) | 0x4000, // 16 bits, 8 bits for "clk_seq_hi_res", // 8 bits for "clk_seq_low", // two most significant bits holds zero and one for variant DCE1.1 mt_rand( 0, 0x3fff ) | 0x8000, // 48 bits for "node" mt_rand( 0, 0xffff ), mt_rand( 0, 0xffff ), mt_rand( 0, 0xffff ) ); } 

Вместо того, чтобы разбивать его на отдельные поля, проще создать случайный блок данных и изменить отдельные позиции байтов. Вы также должны использовать лучший генератор случайных чисел, чем mt_rand ().

Согласно RFC 4122 – Раздел 4.4 , вам необходимо изменить эти поля:

  1. time_hi_and_version (бит 4-7 из 7-го октета),
  2. clock_seq_hi_and_reserved (бит 6 и 7 из 9-го октета)

Все остальные 122 бита должны быть достаточно случайными.

Следующий подход генерирует 128 бит случайных данных, используя openssl_random_pseudo_bytes() , делает перестановки в октетах, а затем использует bin2hex() и vsprintf() для окончательного форматирования.

 function guidv4($data) { assert(strlen($data) == 16); $data[6] = chr(ord($data[6]) & 0x0f | 0x40); // set version to 0100 $data[8] = chr(ord($data[8]) & 0x3f | 0x80); // set bits 6-7 to 10 return vsprintf('%s%s-%s-%s-%s-%s%s%s', str_split(bin2hex($data), 4)); } echo guidv4(openssl_random_pseudo_bytes(16)); 

С PHP 7 генерация случайных последовательностей байтов еще проще, используя random_bytes() :

 echo guidv4(random_bytes(16)); 

Любой, кто использует зависимости композитора , может захотеть рассмотреть эту библиотеку: https://github.com/ramsey/uuid

Это не легче:

 Uuid::uuid4(); 

в системах unix, используйте системное ядро ​​для создания uuid для вас.

 file_get_contents('/proc/sys/kernel/random/uuid') 

Кредит Самвеен на https://serverfault.com/a/529319/210994

Обратите внимание !: Использование этого метода для получения uuid действительно исчерпывает энтропийный пул, очень быстро! Я бы не стал использовать это там, где его часто вызывали.

Мой ответ основан на комментарии пользователя uniqid, но он использует функцию openssl_random_pseudo_bytes для генерации случайной строки вместо чтения из /dev/urandom

 function guid() { $randomString = openssl_random_pseudo_bytes(16); $time_low = bin2hex(substr($randomString, 0, 4)); $time_mid = bin2hex(substr($randomString, 4, 2)); $time_hi_and_version = bin2hex(substr($randomString, 6, 2)); $clock_seq_hi_and_reserved = bin2hex(substr($randomString, 8, 2)); $node = bin2hex(substr($randomString, 10, 6)); /** * Set the four most significant bits (bits 12 through 15) of the * time_hi_and_version field to the 4-bit version number from * Section 4.1.3. * @see http://tools.ietf.org/html/rfc4122#section-4.1.3 */ $time_hi_and_version = hexdec($time_hi_and_version); $time_hi_and_version = $time_hi_and_version >> 4; $time_hi_and_version = $time_hi_and_version | 0x4000; /** * Set the two most significant bits (bits 6 and 7) of the * clock_seq_hi_and_reserved to zero and one, respectively. */ $clock_seq_hi_and_reserved = hexdec($clock_seq_hi_and_reserved); $clock_seq_hi_and_reserved = $clock_seq_hi_and_reserved >> 2; $clock_seq_hi_and_reserved = $clock_seq_hi_and_reserved | 0x8000; return sprintf('%08s-%04s-%04x-%04x-%012s', $time_low, $time_mid, $time_hi_and_version, $clock_seq_hi_and_reserved, $node); } // guid 

Вдохновленный ответом broofa здесь .

 preg_replace_callback('/[xy]/', function ($matches) { return dechex('x' == $matches[0] ? mt_rand(0, 15) : (mt_rand(0, 15) & 0x3 | 0x8)); } , 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'); 

Или если вы не можете использовать анонимные функции.

 preg_replace_callback('/[xy]/', create_function( '$matches', 'return dechex("x" == $matches[0] ? mt_rand(0, 15) : (mt_rand(0, 15) & 0x3 | 0x8));' ) , 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'); 

Из тома, на http://www.php.net/manual/en/function.uniqid.php

 $r = unpack('v*', fread(fopen('/dev/random', 'r'),16)); $uuid = sprintf('%04x%04x-%04x-%04x-%04x-%04x%04x%04x', $r[1], $r[2], $r[3], $r[4] & 0x0fff | 0x4000, $r[5] & 0x3fff | 0x8000, $r[6], $r[7], $r[8]) 

Как насчет использования mysql для создания uuid для вас?

 $conn = new mysqli($servername, $username, $password, $dbname, $port); $query = 'SELECT UUID()'; echo $conn->query($query)->fetch_row()[0]; 

В моем поиске создания v4 uuid я пришел первым на эту страницу, а затем нашел это на http://php.net/manual/en/function.com-create-guid.php

 function guidv4() { if (function_exists('com_create_guid') === true) return trim(com_create_guid(), '{}'); $data = openssl_random_pseudo_bytes(16); $data[6] = chr(ord($data[6]) & 0x0f | 0x40); // set version to 0100 $data[8] = chr(ord($data[8]) & 0x3f | 0x80); // set bits 6-7 to 10 return vsprintf('%s%s-%s-%s-%s-%s%s%s', str_split(bin2hex($data), 4)); } 

кредит: павел.волинцев

Если вы используете CakePHP вы можете использовать их метод CakeText::uuid(); из класса CakeText для создания RFC4122 uuid.

Скорее запоздало, я знаю, но это был мой ответ:

  function NewGuid() { if (function_exists('com_create_guid')){ /** * @var Guid $uuid */ $uuid = com_create_guid(); print "com created"; return $uuid; } else { mt_srand((double)microtime()*10000); $charid = strtoupper(md5(uniqid(rand(), true))); $hyphen = chr(45); /** * @var Guid $uuid */ $uuid = substr($charid, 0, 8).$hyphen .substr($charid, 8, 4).$hyphen .substr($charid,12, 4).$hyphen .substr($charid,16, 4).$hyphen .substr($charid,20,12); return $uuid; } }