Package for encrypting strings with AES256-GCM

Maintainers

Details

github.com/randomphp/gcm

Source

Issues

Installs: 0

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 0

Open Issues: 0

pkg:composer/randomphp/gcm

1.2.2 2026-02-17 18:03 UTC

This package is auto-updated.

Last update: 2026-02-17 18:03:53 UTC


README

RandomPHP

RandomPHP GCM

Secure string encryption/decryption using AES-256-GCM (authenticated encryption) built on phpseclib v3.

Requirements

  • PHP >= 8.1
  • phpseclib/phpseclib ~3.0

Installation

composer require randomphp/gcm

Usage

Encrypt

<?php

use RandomPHP\GCM\Encryptor;
use RandomPHP\GCM\EncryptionVersion;

$key = random_bytes(32); // 32 bytes (256-bit) recommended for AES-256

$cipherText = Encryptor::encrypt(
    plainText: "Hello World!",
    key: $key,
    version: EncryptionVersion::V2 // optional (default: V2)
);

echo $cipherText;

Decrypt

decrypt() automatically detects the cipher format/version.

<?php

use RandomPHP\GCM\Encryptor;

$key = /* the same key used for encryption */;

$plainText = Encryptor::decrypt(
    cipherText: $cipherText,
    key: $key
);

echo $plainText;

Decode (inspect parts)

If you want to inspect the nonce/tag/ciphertext components without decrypting:

<?php

use RandomPHP\GCM\Encryptor;

$decoded = Encryptor::decode($cipherText);

var_dump($decoded->version);    // EncryptionVersion::V1 or V2
var_dump($decoded->nonce);      // raw bytes
var_dump($decoded->cipherText); // raw bytes
var_dump($decoded->tag);        // raw bytes

Note: the values returned by decode() are raw binary strings (bytes). Convert to hex/base64 if you want them readable.

Error Handling

The library throws dedicated exceptions under RandomPHP\GCM\Exceptions:

  • EncryptionException
  • DecryptionException
  • DecodingException

Example:

<?php

use RandomPHP\GCM\Encryptor;
use RandomPHP\GCM\Exceptions\EncryptionException;
use RandomPHP\GCM\Exceptions\DecryptionException;
use RandomPHP\GCM\Exceptions\DecodingException;

try {
    $key = random_bytes(32);
    $cipherText = Encryptor::encrypt("Secret data", $key);
    $plainText  = Encryptor::decrypt($cipherText, $key);
} catch (EncryptionException | DecryptionException | DecodingException $e) {
    // Handle error (log, fail request, etc.)
    echo $e->getMessage();
}

Security Notes

  • Use a strong, secret key. 32 bytes is recommended for AES-256 (random_bytes(32)).
  • Do not reuse nonces (this library generates a fresh nonce per encryption).
  • Protect keys (env vars / secrets manager). Never commit keys to source control.

Tests

composer install
vendor/bin/phpunit