Abstract:
The Blowfish is one of block cipher systems. It was developed as a better substitute for the Triple-DES system. Blowfish has following features:
- a. an input key length is a variable from minimum 32-bit up to maximum 448-bit;
- large subkey tables to make a brute-force attack harder by using hexadecimal string of π value to initialize the 32-bit subkey set (P-array[18] and Sboxes[4][256]); and
- one block encryption algorithm is used using fixed-sized all-zero strings in the subkey generation phase to make key-dependent subkeys.
Overall, the Blowfish has many common features with other block ciphers as following, thus I could reuse many methods/classes from the cryptoUtil.
- large S-boxes data structure for lookup;
- combined operations, .e.g. XOR mod 2^32; and
- multiple rounds of Feistel iteration by swapping left and right half of a block
data:image/s3,"s3://crabby-images/b7cf6/b7cf679b872cf32c770a306a1c779fc0e29a99aa" alt=""
data:image/s3,"s3://crabby-images/11a82/11a8216dc99db5dd4a6055362a856eddf8946ad7" alt=""
data:image/s3,"s3://crabby-images/c989a/c989ad50296311a4b3636f6c6f04521c686f369a" alt=""
data:image/s3,"s3://crabby-images/9f911/9f911242fa1a1aa555096bfaa820be5b3104878e" alt=""
data:image/s3,"s3://crabby-images/cf2b7/cf2b787ab1c7c645778877f7dfdaeac4e2b1388f" alt=""
data:image/s3,"s3://crabby-images/aa47c/aa47cdb7d94ad1363ce8b0a4f67eb3b6cd56e365" alt=""
data:image/s3,"s3://crabby-images/c37d0/c37d00e6999042f5c4f0c64110c179a60ff8a2b0" alt=""
data:image/s3,"s3://crabby-images/c762e/c762ecc6dc93a52d567ed62a6d42da28611cce36" alt=""
data:image/s3,"s3://crabby-images/81603/81603299099016aa27c9bf00bf37643ea9cdb4ae" alt=""
data:image/s3,"s3://crabby-images/33ecb/33ecbc5a0b91d8d9d6511fc5f1a26c1bc9bfa9c1" alt=""
data:image/s3,"s3://crabby-images/8ac58/8ac58b68e004eb2eb72b954fbcd073b086ac4d3f" alt=""
data:image/s3,"s3://crabby-images/1f7db/1f7db890a90538493d5475c055a7c4718a109b1d" alt=""