Download the PHP package brainfoolong/js-aes-php without Composer
On this page you can find all versions of the php package brainfoolong/js-aes-php. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download brainfoolong/js-aes-php
More information about brainfoolong/js-aes-php
Files in brainfoolong/js-aes-php
Package js-aes-php
Short Description Slim native AES encryption/decryption on client side with Javascript and on server side with PHP
License MIT
Homepage https://github.com/brainfoolong/js-aes-php
Informations about the package js-aes-php
Slim native AES encryption/decryption on client side with Javascript and on server side with PHP
A tool to AES encrypt/decrypt data in javascript and/or PHP. You can use it for PHP only, for Javascript only or mix it together.
It uses aes-256-cbc
implementation with random salts and random initialization vector. This library does not support other ciphers or modes.
This library is the successor to my previous CryptoJs-Aes-Php encryption library that required CryptoJS. This library does not require any third party dependency as modern browsers and Node now have proper crypto tools built in. Attention: This library does output different encryption values to my previous library, it cannot be a drop-in replacement.
Features
- Encrypt any value in Javascript (objects/array/etc...) - Everything that can be passed to JSON.stringify
- Encrypt any value in PHP (object/array/etc...) - Everything that can be passed to json_encode
- Decrypt in PHP/Javascript, doesn't matter where you have encrypted the values
- Easy store and transfer the encrypted values, the encrypted output only contains hex characters (0-9 A-F)
- Small footprint: 5kb unzipped Javascript file
Install
- NPM:
npm i js-aes-php
- Composer:
composer require brainfoolong/js-aes-php
- Or just download the latest release zip for everything at once
Requirements
- For Javascript: Any recent Browser or Node environment (15+)
- For Typescript: Use
src/ts/js-aes-php.ts
- For PHP: 8.0 or above with OpenSSL extension enabled
PHP - How to use
Javascript/Typescript - How to use
Security Notes
This library use AES-256-CBC encryption, which is still good and safe but there are (maybe) better alternatives for your use case. If you require really high security, you should invest more time for what is suitable for you.
Also, there's a good article about PHP issues/info related to this library: https://stackoverflow.com/questions/16600708/how-do-you-encrypt-and-decrypt-a-php-string/30159120#30159120
Alternatives - ASCON
You may wonder if there are alternatives to AES encryption that you can use in PHP/JS. ASCON is a newer, lightweight cipher that have been selected in 2023 by the NIST as the new standard for lightweight cryptography, which may suite your needs. I have created libraries for both PHP and JS which you can find at https://github.com/brainfoolong/php-ascon and https://github.com/brainfoolong/js-ascon
Changelog
1.0.1 - 2024-08-14
Initial Public Release
All versions of js-aes-php with dependencies
ext-openssl Version *
ext-json Version *