Just to note this function is fairly slow, and can bring your script to a crawl if it is in a loop. Strangely if you run it as uniqid('', true) it runs much more quickly
(PHP 4, PHP 5, PHP 7, PHP 8)
uniqid — Génère un identifiant basé sur le temps
Génère un identifiant basé sur l'heure actuelle avec une précision à la microseconde,
préfixé par le préfixe
donné et ajoutant
éventuellement une valeur générée aléatoirement.
Cette fonction ne génère pas de valeurs cryptographiquement sûres, et ne doit pas être utilisée à des fins cryptographiques, ou à des fins qui exigent que les valeurs renvoyées soient indéchiffrables.
Si de l'aléatoire cryptographiquement sûre est requis, le Random\Randomizer peut être utilisé avec le moteur Random\Engine\Secure. Pour des cas d'usage simple, les fonctions random_int() et random_bytes() fournissent une API pratique et sûre qui est qui est soutenu par le CSPRNG du système d'exploitation.
Cette fonction ne garantit pas l'unicité de la valeur retournée
car celle-ci est basée sur l'heure actuelle en microsecondes
ou sur l'heure actuelle avec une petite quantité de données aléatoires ajoutées
si more_entropy
est true
.
prefix
Peut être utile, par exemple, pour identifier facilement différents hôtes, si vous générez simultanément sur plusieurs hôtes pouvant générer le même identifiant à la même microseconde. (Cela peut se produire même sur un seul hôte si l'horloge système est déplacée en arrière, par exemple par un ajustement NTP.)
Sans prefix
(préfixe vide), la
chaîne retournée fera 13 caractères. Si
more_entropy
est à true
, elle fera 23
caractères.
more_entropy
Si le paramètre optionnel more_entropy
est
true
, uniqid() ajoutera une entropie
"combined LCG"
à la fin de la valeur retournée,
ce qui augmente la probabilité de l'unicité du résultat.
Retourne un identifiant basé sur l'horodatage, sous la forme d'une chaîne de caractères.
Cette fonction ne garantit pas l'unicité de la valeur retournée.
Exemple #1 Exemple avec uniqid()
<?php
/* Un identifiant unique, comme : 4b3403665fea6 */
printf("uniqid(): %s\r\n", uniqid());
/* Nous pouvons également préfixer l'identifiant unique,
* ce qui revient à :
*
* $uniqid = $prefix . uniqid();
* $uniqid = uniqid($prefix);
*/
printf("uniqid('php_'): %s\r\n", uniqid('php_'));
/* Nous pouvons aussi activer le paramètre more_entropy,
* requis par quelques systèmes, comme Cygwin. Ceci fera que
* uniqid() produira une valeur comme : 4b340550242239.64159797
*/
printf("uniqid('', true): %s\r\n", uniqid('', true));
?>
Note:
Sous Cygwin, le paramètre
more_entropy
doit être passé àtrue
pour que cette fonction fonctionne.
Just to note this function is fairly slow, and can bring your script to a crawl if it is in a loop. Strangely if you run it as uniqid('', true) it runs much more quickly