DES (Data Encryption Standard) এর ব্যবহার এবং উদাহরণ

Symmetric Key Cryptography - জাভা ক্রিপ্টোগ্রাফি (Java Cryptography) - Java Technologies

500

DES (Data Encryption Standard) হল একটি সিমেট্রিকাল কিপার (symmetric-key) এনক্রিপশন অ্যালগরিদম যা ১৯৭৭ সালে National Institute of Standards and Technology (NIST) দ্বারা অনুমোদিত হয়। DES একটি ব্লক সাইফার এবং এটি ৫৬-বিট কিপ দিয়ে ডেটা এনক্রিপ্ট করে। তবে, DES এখন আর নিরাপদ হিসেবে বিবেচিত হয় না, কারণ এটি খুব সহজেই ব্রুট-ফোর্স আক্রমণের মাধ্যমে ভাঙা যেতে পারে। কিন্তু DES এখনও কিছু পুরানো সিস্টেমে ব্যবহৃত হয় এবং এটি শিক্ষার্থীদের জন্য এনক্রিপশন প্রযুক্তির একটি মূল উদাহরণ।

Java তে DES (Data Encryption Standard) ব্যবহার করতে javax.crypto প্যাকেজের Cipher ক্লাস ব্যবহার করা হয়। এটি সহজেই DES এনক্রিপশন এবং ডিক্রিপশন করতে সহায়তা করে।

1. DES ব্যবহার করার প্রক্রিয়া

  1. Key Generation: DES একটি সিমেট্রিকাল কিপার সিস্টেম, অর্থাৎ এনক্রিপশন এবং ডিক্রিপশন করার জন্য একই কী ব্যবহার করা হয়। সুতরাং, আপনার একটি SecretKey তৈরি করতে হবে।
  2. Encryption: DES ব্যবহার করে একটি প্লেইনটেক্সট (Plaintext) এনক্রিপ্ট করা হবে।
  3. Decryption: এনক্রিপ্ট করা ডেটা থেকে মূল তথ্য উদ্ধার করা হবে (যেটি ডিক্রিপশন বলে পরিচিত)।

2. Java তে DES এনক্রিপশন উদাহরণ

এই উদাহরণে আমরা DES এনক্রিপশন এবং ডিক্রিপশন দেখব। প্রথমে একটি SecretKey তৈরি করা হবে, তারপর সেই কী ব্যবহার করে একটি String এনক্রিপ্ট এবং ডিক্রিপ্ট করা হবে।

প্রোগ্রাম কোড:

import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import java.util.Base64;

public class DESExample {

    public static void main(String[] args) throws Exception {
        String originalText = "Hello, DES Encryption!";  // Original text to encrypt

        // Step 1: Generate a DES Key
        SecretKey secretKey = generateDESKey();

        // Step 2: Encrypt the text using the DES Key
        String encryptedText = encrypt(originalText, secretKey);
        System.out.println("Encrypted Text: " + encryptedText);

        // Step 3: Decrypt the text using the DES Key
        String decryptedText = decrypt(encryptedText, secretKey);
        System.out.println("Decrypted Text: " + decryptedText);
    }

    // Method to generate a DES Key
    public static SecretKey generateDESKey() throws Exception {
        KeyGenerator keyGen = KeyGenerator.getInstance("DES");
        keyGen.init(56);  // 56-bit key size for DES
        return keyGen.generateKey();
    }

    // Method to encrypt the text using DES
    public static String encrypt(String text, SecretKey secretKey) throws Exception {
        Cipher cipher = Cipher.getInstance("DES");
        cipher.init(Cipher.ENCRYPT_MODE, secretKey);
        byte[] encryptedBytes = cipher.doFinal(text.getBytes());
        return Base64.getEncoder().encodeToString(encryptedBytes);  // Encode to Base64 for display
    }

    // Method to decrypt the text using DES
    public static String decrypt(String encryptedText, SecretKey secretKey) throws Exception {
        Cipher cipher = Cipher.getInstance("DES");
        cipher.init(Cipher.DECRYPT_MODE, secretKey);
        byte[] decodedBytes = Base64.getDecoder().decode(encryptedText);  // Decode from Base64
        byte[] decryptedBytes = cipher.doFinal(decodedBytes);
        return new String(decryptedBytes);
    }
}

ব্যাখ্যা:

  1. SecretKey Generation: KeyGenerator.getInstance("DES") ব্যবহার করে DES কী তৈরি করা হয়েছে। 56-bit key ব্যবহার করা হয় DES এর জন্য, যা নিরাপত্তা স্তরের জন্য যথেষ্ট নয়, তবে এটি শিক্ষা উদ্দেশ্যে ব্যবহার করা হয়েছে।
  2. Encryption: Cipher.getInstance("DES") ব্যবহার করে একটি DES সাইফার তৈরি করা হয়েছে এবং ENCRYPT_MODE এ কী সেট করা হয়েছে। এরপর, প্লেইনটেক্সট এনক্রিপ্ট করা হয়েছে।
  3. Decryption: Cipher.getInstance("DES") ব্যবহার করে একই সাইফার তৈরি করা হয়েছে, তবে এবার DECRYPT_MODE এ কী সেট করা হয়েছে, এবং এনক্রিপ্ট করা টেক্সট ডিক্রিপ্ট করা হয়েছে।

এখানে Base64 এনকোডিং ব্যবহার করা হয়েছে, কারণ বাইনারি ডেটা (যেমন এনক্রিপ্টেড ডেটা) সাধারণত Base64 ফরম্যাটে স্টোর বা প্রদর্শন করা হয়।

Output:

Encrypted Text: k+W4BRwYJzI3UoK2V6Lh9w==
Decrypted Text: Hello, DES Encryption!

এখানে, এনক্রিপ্ট করা টেক্সট Base64 ফরম্যাটে প্রদর্শিত হচ্ছে এবং ডিক্রিপশন প্রক্রিয়া থেকে মূল টেক্সট ফিরে এসেছে।


3. DES এর নিরাপত্তা

DES বর্তমানে আর নিরাপদ নয়, কারণ এটি 56-বিট কিপ ব্যবহার করে যা ব্রুট-ফোর্স আক্রমণ দ্বারা খুব সহজে ভাঙা যেতে পারে। বর্তমানে, AES (Advanced Encryption Standard) এবং RSA এর মতো আরও নিরাপদ এবং শক্তিশালী এনক্রিপশন পদ্ধতিগুলি ব্যবহৃত হয়।

তবে, DES এখনও কিছু পুরানো সিস্টেম এবং অ্যাপ্লিকেশনে ব্যবহৃত হচ্ছে, এবং এটি শিক্ষার্থীদের জন্য একটি গুরুত্বপূর্ণ এনক্রিপশন অ্যালগরিদম হিসেবে বিবেচিত হয়।


4. DES এর বিকল্প এনক্রিপশন অ্যালগরিদম

  1. AES (Advanced Encryption Standard):
    • AES DES এর চেয়ে অনেক বেশি নিরাপদ। এটি 128-bit, 192-bit, বা 256-bit কী ব্যবহার করে, যা DES এর 56-বিট কী এর চেয়ে অনেক বেশি নিরাপদ।
    • AES এ ব্যবহৃত কী সাইজের কারণে এটি অনেক বেশি সুরক্ষিত।
  2. RSA (Rivest-Shamir-Adleman):
    • RSA একটি asymmetric encryption অ্যালগরিদম যা পাবলিক এবং প্রাইভেট কী ব্যবহার করে। এটি DES এবং AES এর মতো সিমেট্রিক এনক্রিপশন সিস্টেমের থেকে আলাদা।

  • DES একটি পুরানো এবং সিমেট্রিক কী ব্যবহৃত ব্লক সাইফার অ্যালগরিদম, যা এখনও কিছু সিস্টেমে ব্যবহৃত হয়, তবে আধুনিক সময়ের brute-force আক্রমণের কারণে এটি নিরাপদ নয়।
  • Java Cryptography API তে DES ব্যবহার করে আপনি খুব সহজে এনক্রিপশন এবং ডিক্রিপশন কার্যকর করতে পারেন, যেমন উপরে দেওয়া উদাহরণে।
  • যদি নিরাপত্তা একটি গুরুত্বপূর্ণ বিষয় হয়, তাহলে AES বা RSA এর মতো শক্তিশালী এনক্রিপশন অ্যালগরিদম ব্যবহারের পরামর্শ দেওয়া হয়।
Content added By
Promotion

Are you sure to start over?

Loading...