perldoc > Crypt::Cipher::Khazad(3pm)

📛 NAME

Crypt::Cipher::Khazad - Symmetric cipher Khazad, key size: 128 bits

🚀 Quick Reference

Use CaseCommandDescription
🔐 Create a CBC ciphermy $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

📖 SYNOPSIS

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");

📝 DESCRIPTION

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).

🛠️ METHODS

🏗️ new

$c = Crypt::Cipher::Khazad->new($key);
#or
$c = Crypt::Cipher::Khazad->new($key, $rounds);

🔐 encrypt

$ciphertext = $c->encrypt($plaintext);

🔓 decrypt

$plaintext = $c->decrypt($ciphertext);

🔑 keysize

$c->keysize;
#or
Crypt::Cipher::Khazad->keysize;
#or
Crypt::Cipher::Khazad::keysize;

🧱 blocksize

$c->blocksize;
#or
Crypt::Cipher::Khazad->blocksize;
#or
Crypt::Cipher::Khazad::blocksize;

🔐 max_keysize

$c->max_keysize;
#or
Crypt::Cipher::Khazad->max_keysize;
#or
Crypt::Cipher::Khazad::max_keysize;

🔐 min_keysize

$c->min_keysize;
#or
Crypt::Cipher::Khazad->min_keysize;
#or
Crypt::Cipher::Khazad::min_keysize;

🔄 default_rounds

$c->default_rounds;
#or
Crypt::Cipher::Khazad->default_rounds;
#or
Crypt::Cipher::Khazad::default_rounds;

📚 SEE ALSO

Crypt::Cipher::Khazad(3pm)
📛 NAME 🚀 Quick Reference 📖 SYNOPSIS 📝 DESCRIPTION 🛠️ METHODS
🏗️ new 🔐 encrypt 🔓 decrypt 🔑 keysize 🧱 blocksize 🔐 max_keysize 🔐 min_keysize 🔄 default_rounds
📚 SEE ALSO

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)
Valid XHTML 1.0 Transitional!Valid CSS!
Enhanced by LLM: deepseek-v4-pro / taotoken.net / www.chedong.com - original format

^_top_^