= 5.3.0, but OpenSSL may not always be available return 'X' . bin2hex(openssl_random_pseudo_bytes(16)); } else { // Fall back to a rudimentary ID generator: // * $_SERVER array will make the ID unique to this request. // * spl_object_hash($this) will make the ID unique to this object instance. // (note that object hashes can be reused, but the other data here should prevent issues here). // * uniqid('', true) will use the current microtime(), plus additional random data. // * $this->index guarantees the uniqueness of IDs from the current object. $this->index++; $entropy = serialize($_SERVER) . uniqid('', true) . spl_object_hash($this) . $this->index; return 'X' . md5($entropy); } } }