Download the PHP package tuupola/base32 without Composer
On this page you can find all versions of the php package tuupola/base32. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download tuupola/base32
More information about tuupola/base32
Files in tuupola/base32
Package base32
Short Description Base32 encoder and decoder for arbitrary data
License MIT
Homepage https://github.com/tuupola/base32
Informations about the package base32
Base32
This library implements Base32 encoding. In addition to integers it can encode and decode any arbitrary data.
Install
Install with composer.
This branch requires PHP 7.1 or up. The older 1.x branch supports also PHP 5.6 and 7.0.
Usage
This package has both pure PHP and GMP based encoders. By default encoder and decoder will use GMP functions if the extension is installed. If GMP is not available pure PHP encoder will be used instead.
If you are encoding to and from integer use the implicit decodeInteger()
and encodeInteger()
methods.
Also note that encoding a string and an integer will yield different results.
Encoding Modes
RCF4684
RCF4684 is the default when encoder is created without passing any parameters. Explicit parameters shown below.
RCF4684 HEX
RCF4684 base32hex encoding is identical to previous, except for the character set. This encoding is lexically sortable.
GMP
GMP encoding is identical to previous. Example below is shown with padding disabled.
Crockford's Base32
When decoding, upper and lower case letters are accepted, and i and l will be treated as 1 and o will be treated as 0. When encoding, only upper case letters are used. Hyphens are ignored during decoding.
Z-base-32 [WIP]
http://philzimmermann.com/docs/human-oriented-base-32-encoding.txt
Character Sets
By default Base32 uses RFC4648 character set. Shortcut is provided for other commonly used character sets. You can also use any custom character set of 32 unique characters.
Speed
Install GMP if you can. It is reasonably faster pure PHP encoder. Below benchmarks are for encoding random_bytes(128)
data.
Static Proxy
If you prefer to use static syntax use the provided static proxy.
Testing
You can run tests either manually or automatically on every code change. Automatic tests require entr to work.
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
License
The MIT License (MIT). Please see License File for more information.