library php-library-uid
PHP Library Uid
sinevia/php-library-uid
PHP Library Uid
- Wednesday, July 25, 2018
- by sinevia
- Repository
- 1 Watchers
- 3 Stars
- 205 Installations
- PHP
- 0 Dependents
- 0 Suggesters
- 0 Forks
- 0 Open issues
- 3 Versions
- 163 % Grown
PHP Library Uid
Class to generate unique identifying strings. Largest attention is paid on human friendly unique identifiers (dated digits)., (*1)
, (*2)
Supported UID Type
It supports several types of unique identifiers. The type you may want to use depends on how random and long you want the identifier to be. For most of the user cases a Micro UUID (20 chars) should be fine. A human UUID (32 chars) should almost never be used where a human is involved as too "mind bogling" to work with., (*3)
-
Human UUID (32 digits), (*4)
Format: YYYYMMDD-HHMM-SSMM-MMMMRRRRRRRRRRR, (*5)
2017111908492665991498485465 (with dashes: 20171119-0849-2665-991498485465), (*6)
-
Nano UID (23 digits), (*7)
Format: YYYYMMDD-HHMMSS-MMMMMM-NNN, (*8)
Examples:, (*9)
20171119084926659914984 (with dashes: 20171119-084926-659914-984), (*10)
-
Micro UID (20 digits), (*11)
Format: YYYYMMDD-HHMMSS-MMMMMM, (*12)
Examples:, (*13)
20171119084926659914 (with dashes: 20171119-084926-659914), (*14)
-
Seconds UID (14 digits), (*15)
Format: YYYYMMDD-HHMMSS, (*16)
Examples:, (*17)
20171119084926 (with dashes: 20171119-084926), (*18)
-
Timestamp UID (Unix Time - seconds since 1 Jan 1970), (*19)
Installation
Via composer, (*20)
composer require sinevia/php-library-uid
Usage
\Sinevia\Uid::humanUuid(); // 32 digits - YYYYMMDD-HHMM-SSMM-MMMMRRRRRRRRRRR
\Sinevia\Uid::nanoUid(); // 23 digits - YYYYMMDD-HHMMSS-MMMMMM-NNN
\Sinevia\Uid::microUid(); // 20 digits - YYYYMMDD-HHMMSS-MMMMMM
\Sinevia\Uid::secUid(); // 14 digits - YYYYMMDD-HHMMSS
\Sinevia\Uid::timestampUid(); // Unix time (seconds since 1 Jan 1970)
\Sinevia\Uid::timestampUidWithRandomPostFix(12); // Unix time + 12 random digits
\Sinevia\Uid::isHumanUid(1);
\Sinevia\Uid::isNanoUid(1);
\Sinevia\Uid::isMicroUid(1);
\Sinevia\Uid::isSecUid(1);