- Trending Categories
- Data Structure
- Networking
- RDBMS
- Operating System
- Java
- iOS
- HTML
- CSS
- Android
- Python
- C Programming
- C++
- C#
- MongoDB
- MySQL
- Javascript
- PHP

- Selected Reading
- UPSC IAS Exams Notes
- Developer's Best Practices
- Questions and Answers
- Effective Resume Writing
- HR Interview Questions
- Computer Glossary
- Who is Who

# How are subkeys generated in Blowfish algorithm?

Blowfish is a symmetric block cipher algorithm invented by Brute Schneier in December 1993. Blowfish is a substitute of DES or IDEA. One of the most popular feistel network ciphers is Blowfish. Blowfish algorithm has 64-bit block size and variable key length from 42 bits to 448 bits. The algorithm includes a key-expansion part, and data-encryption part.

Blowfish create the key of at most 448 bits into several subkey arrays the total is 1042 32 bit values or 4168 bytes. It is a 16- round feistel system, which supports very high key-dependent S-boxes and enable 16 iterations.

Every round is adapted with a key and data dependent substitution and a keydependent permutation. The 32-bit words and XOR operations are implemented by additions. There is a P-array and four 32-bit S-boxes.

The P-array includes 18 of 32-bit sub keys, while each S-box includes 256 entries. The input is a 64 bit data element. The process of Sub key generation is as follows −

Blowfish creates use of a very large number of subkeys. These keys have to be ready before encryption and decryption appears. The key size field from 32 bits to 448 bits. In other terms, the key size ranges from 1 to 14 words, each including a word of 32 bits. These keys are saved in an array as follows −

K1, K2,….Kn where 1 ≤ n ≤ 14

The concept of P-array including 18, 32-bit subkeys −

P1,P2,………….,P18.

Creation of the P-array is described subsequently.

There are four 32-bit S-Boxes includes 256 entries each −

S1, 0, S1, 1… S1, 255

S2, 0, S2, 1… S2, 255

S3, 0, S3, 1… S3, 255

S4, 0, S4, 1… S4, 255

Creation of the P-array is defines subsequently.

It can initialize the P-array first, followed by the four S-boxes, with a fixed string.

P Array and the four S boxes is indicates as hexadecimal digits of Pi.

It can implement a bitwise XOR operations of P-array and with the K array reusing words from the K array required with the key bits (i.e., P1 XOR (thirty two bits of key), P2 XOR (thirty two bits of key).

It can encrypt the 64 bit block and use the following encryption process to encrypt the all-zeros with the common P and S arrays.

It can create the place of p1 and p2 with output of encryption and new output is termed as p1 and p2.

It can encrypt the output of step3 utilizing current P box and S box and transform p3 and p4 with resulting encrypted text and new output is termed as p3 and p4.

It can repeat the following steps until it can acquire all the elements of P array i.e P1, P2.

- Related Questions & Answers
- What are the operations of Blowfish Algorithm?
- What is the Blowfish encryption algorithm?
- What is Data Encryption and Decryption in Blowfish Algorithm?
- How MySQL stored GENERATED COLUMNS are different from MySQL virtual GENERATED COLUMNS?
- What are the SOM Algorithm?
- What are the different types of MySQL GENERATED COLUMNS?
- What are the popular Hashing Algorithm?
- What are the popular Encryption Algorithm?
- What are the applications of RSA Algorithm?
- What are the application of MD5 Algorithm?
- Type of Boxes Generated in CSS
- What are the Algorithm of Cryptographic in information security?
- What are the types of the partitional algorithm?
- What are the modules of Triple DES Algorithm?
- What are risks in implementing the RSA algorithm without padding?