Crypt::Cipher::Khazad - Symmetric cipher Khazad, key size: 128 bits
| Use Case | Command | Description |
|---|---|---|
| 🔐 Create a CBC cipher | my $cbc = Crypt::Mode::CBC->new('Khazad'); | Instantiate CBC mode with Khazad |
| 🔏 Encrypt data | $ciphertext = $cbc->encrypt("secret", $key, $iv); | Encrypt using a 128-bit key and 16-byte IV |
| 🔓 Decrypt data | $plaintext = $cbc->decrypt($ciphertext, $key, $iv); | Decrypt back to plaintext |
| ⚙️ Get key size info | $c->keysize; or Crypt::Cipher::Khazad->keysize; | Returns 16 (128 bits) |
| 📦 Block size | $c->blocksize; | Always 16 bytes |
Example 1 ✅ (recommended, fast)
use Crypt::Mode::CBC;
my $key = '...'; # length has to be valid key size for this cipher
my $iv = '...'; # 16 bytes
my $cbc = Crypt::Mode::CBC->new('Khazad');
my $ciphertext = $cbc->encrypt("secret data", $key, $iv);
Example 2 🐢 (slower, legacy)
use Crypt::CBC;
use Crypt::Cipher::Khazad;
my $key = '...'; # length has to be valid key size for this cipher
my $iv = '...'; # 16 bytes
my $cbc = Crypt::CBC->new( -cipher=>'Cipher::Khazad', -key=>$key, -iv=>$iv );
my $ciphertext = $cbc->encrypt("secret data");
This module implements the Khazad cipher. Provided interface is compliant with Crypt::CBC module.
⚠️ BEWARE: This module implements just elementary "one-block-(en|de)cryption" operation — if you want to encrypt/decrypt generic data you have to use some of the cipher block modes - check for example Crypt::Mode::CBC, Crypt::Mode::CTR or Crypt::CBC (which will be slower).
$c = Crypt::Cipher::Khazad->new($key);
#or
$c = Crypt::Cipher::Khazad->new($key, $rounds);
$ciphertext = $c->encrypt($plaintext);
$plaintext = $c->decrypt($ciphertext);
$c->keysize;
#or
Crypt::Cipher::Khazad->keysize;
#or
Crypt::Cipher::Khazad::keysize;
$c->blocksize;
#or
Crypt::Cipher::Khazad->blocksize;
#or
Crypt::Cipher::Khazad::blocksize;
$c->max_keysize;
#or
Crypt::Cipher::Khazad->max_keysize;
#or
Crypt::Cipher::Khazad::max_keysize;
$c->min_keysize;
#or
Crypt::Cipher::Khazad->min_keysize;
#or
Crypt::Cipher::Khazad::min_keysize;
$c->default_rounds;
#or
Crypt::Cipher::Khazad->default_rounds;
#or
Crypt::Cipher::Khazad::default_rounds;
Generated by phpman v4.9.22-1-g1b0fcb4 · Markdown · JSON · MCP Author: Che Dong Under GNU General Public License
2026-07-05 02:23 @216.73.216.52
CrawledBy Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)
Enhanced by LLM: deepseek-v4-pro / taotoken.net / www.chedong.com - original format