Java তে Cryptography কি এবং এর প্রয়োগ?

Java Security সম্পর্কিত প্রশ্নাবলী - জাভা ইন্টারভিউ প্রশ্ন (Java Interview Questions) - Java Technologies

376

Cryptography হল একটি সায়েন্স যা তথ্যকে সুরক্ষিত রাখার জন্য বিভিন্ন কৌশল এবং প্রক্রিয়া ব্যবহার করে, যাতে শুধুমাত্র অনুমোদিত ব্যক্তি বা সিস্টেম সেই তথ্য পড়তে পারে বা প্রক্রিয়া করতে পারে। Java তে Cryptography মূলত তথ্যের গোপনীয়তা (confidentiality), অখণ্ডতা (integrity), পরিচয় নিশ্চিতকরণ (authentication) এবং অস্বীকৃতির প্রতিরোধ (non-repudiation) সুনিশ্চিত করতে ব্যবহৃত হয়। Java Cryptography একটি শক্তিশালী এবং নিরাপদ ডেটা সুরক্ষা পদ্ধতি প্রদান করে, যা Encryption, Decryption, Digital Signatures, Message Authentication Codes (MACs), Hashing ইত্যাদি সাপোর্ট করে।

Java Cryptography এর প্রধান লক্ষ্যসমূহ:

  1. Confidentiality (গোপনীয়তা): ডেটা এতো সুরক্ষিত থাকে যাতে শুধুমাত্র নির্দিষ্ট ব্যক্তি বা সিস্টেমই তথ্যটি অ্যাক্সেস করতে পারে।
  2. Integrity (অখণ্ডতা): নিশ্চিত করে যে ডেটা পরিবর্তিত হয়নি এবং তার মধ্যে কোনো অননুমোদিত পরিবর্তন হয়নি।
  3. Authentication (প্রমাণীকরণ): নিশ্চিত করে যে সংশ্লিষ্ট পক্ষের পরিচয় সঠিক এবং যে ডেটাটি প্রেরিত হয়েছে তা ঠিক সেখান থেকে এসেছে।
  4. Non-repudiation (অস্বীকৃতির প্রতিরোধ): যে কোনো পক্ষের জন্য এটি সম্ভব নয় যে তারা তাদের কাজ অস্বীকার করতে পারে। অর্থাৎ, প্রমাণ থাকতে হবে যে তারা একটি নির্দিষ্ট কাজ করেছে।

Java Cryptography API:

Java তে Cryptography বাস্তবায়নের জন্য Java Cryptography Architecture (JCA) এবং Java Cryptography Extension (JCE) ব্যবহার করা হয়। এগুলি Java-তে secure communications, digital signatures, message authentication, encryption এবং decryption বাস্তবায়ন করতে সাহায্য করে।

Java Cryptography API এর মধ্যে কিছু গুরুত্বপূর্ণ ক্লাস এবং ইন্টারফেস রয়েছে:

  • Cipher: এনক্রিপশন এবং ডিক্রিপশন করার জন্য ব্যবহৃত হয়।
  • KeyPairGenerator: পাবলিক এবং প্রাইভেট কী জেনারেট করতে ব্যবহৃত হয়।
  • MessageDigest: হ্যাশিং ফাংশন ব্যবহারের জন্য ব্যবহৃত হয় (যেমন SHA-256)।
  • Signature: ডিজিটাল স্বাক্ষর তৈরি ও যাচাই করার জন্য ব্যবহৃত হয়।
  • Mac: মেসেজ অটেনটিকেশন কোড (MAC) তৈরির জন্য ব্যবহৃত হয়।

Java Cryptography এর প্রয়োগ:

  1. Data Encryption (এনক্রিপশন):

    • Data Encryption হল এমন একটি প্রক্রিয়া যার মাধ্যমে plaintext ডেটা একটি এনক্রিপশন অ্যালগরিদমের মাধ্যমে ciphertext-এ রূপান্তরিত হয়, যাতে তা অদ্বিতীয়ভাবে সুরক্ষিত থাকে এবং শুধুমাত্র বৈধ প্রাপক তা ডিক্রিপ্ট করে পড়ে।
    • উদাহরণস্বরূপ: AES (Advanced Encryption Standard) ব্যবহার করে ডেটা এনক্রিপশন করা।

    Example:

    import javax.crypto.Cipher;
    import javax.crypto.KeyGenerator;
    import javax.crypto.SecretKey;
    
    public class EncryptionExample {
        public static void main(String[] args) throws Exception {
            // Create a new key generator for AES
            KeyGenerator keyGen = KeyGenerator.getInstance("AES");
            keyGen.init(128); // Set key size
            SecretKey secretKey = keyGen.generateKey();
    
            // Create Cipher instance and initialize it for encryption
            Cipher cipher = Cipher.getInstance("AES");
            cipher.init(Cipher.ENCRYPT_MODE, secretKey);
    
            String originalText = "Hello, Java Cryptography!";
            byte[] encryptedText = cipher.doFinal(originalText.getBytes());
    
            System.out.println("Encrypted text: " + new String(encryptedText));
        }
    }
    
  2. Data Decryption (ডিক্রিপশন):

    • ডিক্রিপশন হল এনক্রিপ্ট করা ডেটা থেকে আসল ডেটা পুনরুদ্ধার করার প্রক্রিয়া।
    • ডিক্রিপশন প্রক্রিয়া Cipher ক্লাসের মাধ্যমে করা হয়, যেখানে এনক্রিপ্ট করা ডেটা এবং সঠিক কী প্রদান করা হয়।

    Example:

    public class DecryptionExample {
        public static void main(String[] args) throws Exception {
            // Create Cipher instance and initialize it for decryption
            Cipher cipher = Cipher.getInstance("AES");
            cipher.init(Cipher.DECRYPT_MODE, secretKey);
    
            byte[] decryptedText = cipher.doFinal(encryptedText);
            System.out.println("Decrypted text: " + new String(decryptedText));
        }
    }
    
  3. Digital Signatures (ডিজিটাল স্বাক্ষর):

    • Digital Signature হল একটি নিরাপদ ডিজিটাল কোড যা একটি ডকুমেন্টের অখণ্ডতা এবং প্রমাণীকরণ নিশ্চিত করতে ব্যবহৃত হয়। এটি পাবলিক কী ক্রিপ্টোগ্রাফি ব্যবহার করে সৃষ্ট হয়।
    • ডিজিটাল স্বাক্ষর তৈরি করতে, Signature ক্লাস ব্যবহার করা হয়, এবং এটি যাচাই করার জন্য পাবলিক কী প্রয়োজন।

    Example:

    import java.security.*;
    import java.util.Base64;
    
    public class DigitalSignatureExample {
        public static void main(String[] args) throws Exception {
            // Create a KeyPairGenerator instance
            KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");
            keyPairGenerator.initialize(2048); // Set key size
            KeyPair keyPair = keyPairGenerator.generateKeyPair();
    
            // Create a Signature instance
            Signature signature = Signature.getInstance("SHA256withRSA");
            signature.initSign(keyPair.getPrivate());
    
            String message = "This is a message to sign.";
            signature.update(message.getBytes());
    
            // Generate the signature
            byte[] digitalSignature = signature.sign();
    
            System.out.println("Digital Signature: " + Base64.getEncoder().encodeToString(digitalSignature));
        }
    }
    
  4. Message Digest (হ্যাশিং):

    • Message Digest একটি হ্যাশ ফাংশন যা ডেটার একটি একক মান তৈরি করে যা হ্যাশ ভ্যালু নামে পরিচিত। এটি ডেটার অখণ্ডতা যাচাই করতে ব্যবহৃত হয়। SHA-256 বা MD5 হ্যাশ ফাংশন সাধারণত ব্যবহৃত হয়।
    • MessageDigest ক্লাস ব্যবহার করে হ্যাশিং করা হয়।

    Example:

    import java.security.*;
    
    public class HashingExample {
        public static void main(String[] args) throws Exception {
            // Create a MessageDigest instance for SHA-256
            MessageDigest digest = MessageDigest.getInstance("SHA-256");
    
            String input = "Hello, Java Cryptography!";
            byte[] hash = digest.digest(input.getBytes());
    
            System.out.println("SHA-256 Hash: " + bytesToHex(hash));
        }
    
        // Helper method to convert byte array to hexadecimal string
        public static String bytesToHex(byte[] bytes) {
            StringBuilder hexString = new StringBuilder();
            for (byte b : bytes) {
                hexString.append(String.format("%02x", b));
            }
            return hexString.toString();
        }
    }
    
  5. Message Authentication Code (MAC):

    • MAC (Message Authentication Code) হল একটি ছোট পিস ডেটা যা ডেটার অখণ্ডতা এবং প্রমাণীকরণ নিশ্চিত করার জন্য একটি গোপন কী ব্যবহার করে তৈরি করা হয়।
    • Mac ক্লাস ব্যবহার করে MAC তৈরি করা হয়।

    Example:

    import javax.crypto.Mac;
    import javax.crypto.spec.SecretKeySpec;
    
    public class MACExample {
        public static void main(String[] args) throws Exception {
            String message = "This is a secret message.";
            String key = "secretkey";
    
            // Create Mac instance
            Mac mac = Mac.getInstance("HmacSHA256");
            SecretKeySpec secretKeySpec = new SecretKeySpec(key.getBytes(), "HmacSHA256");
            mac.init(secretKeySpec);
    
            byte[] macResult = mac.doFinal(message.getBytes());
            System.out.println("MAC: " + bytesToHex(macResult));
        }
    
        public static String bytesToHex(byte[] bytes) {
            StringBuilder hexString = new StringBuilder();
            for (byte b : bytes) {
                hexString.append(String.format("%02x", b));
            }
            return hexString.toString();
        }
    }
    

JCA/JCE এর ব্যবহার:

  • Java Cryptography Architecture (JCA) এবং Java Cryptography Extension (JCE) Java তে শক্তিশালী ক্রিপ্টোগ্রাফি সমর্থন প্রদান করে। JCA এর মাধ্যমে আপনি বিভিন্ন ক্রিপ্টো প্রটোকল ব্যবহার করতে পারবেন, এবং JCE-এর মাধ্যমে উন্নত ক্রিপ্টোগ্রাফি ফিচার যেমন এনক্রিপশন, ডিক্রিপশন, ডিজিটাল সিগনেচার, হ্যাশিং ইত্যাদি ব্যবহার করতে পারবেন।

Cryptography এর প্রয়োগ:

  1. Secure Communication: নিরাপদ যোগাযোগ প্রতিষ্ঠার জন্য (যেমন HTTPS, SSL/TLS প্রোটোকল) ব্যবহার করা হয়।
  2. Data Encryption/Decryption: ডেটাকে নিরাপদভাবে স্টোর বা ট্রান্সফার করার জন্য এনক্রিপশন এবং ডিক্রিপশন ব্যবহৃত হয়।
  3. Digital Signatures: ডিজিটাল স্বাক্ষরের মাধ্যমে ডেটার অখণ্ডতা এবং প্রমাণীকরণ নিশ্চিত করা হয়।
  4. Password Protection: পাসওয়ার্ড স্টোরেজে নিরাপত্তা নিশ্চিত করতে হ্যাশিং ব্যবহৃত হয়।

Java Cryptography ডেটা সুরক্ষিত রাখতে ব্যবহৃত হয়, এবং Java-তে এতে সহায়তা প্রদান করা হয় JCA এবং JCE এর মাধ্যমে। এনক্রিপশন, ডিক্রিপশন, ডিজিটাল সিগনেচার, মেসেজ অটেনটিকেশন কোড, এবং হ্যাশিং প্রক্রিয়া Java Cryptography-র গুরুত্বপূর্ণ অংশ, যা তথ্যের গোপনীয়তা, অখণ্ডতা এবং প্রমাণীকরণ নিশ্চিত করতে সহায়তা করে।

Content added By
Promotion

Are you sure to start over?

Loading...