>Java >java지도 시간 >Java의 3DES 암호화 및 암호 해독이 일반적으로 암호 텍스트를 원래 문자열로 다시 해독하지 못하는 이유는 무엇이며 이 문제를 어떻게 해결할 수 있습니까?

Java의 3DES 암호화 및 암호 해독이 일반적으로 암호 텍스트를 원래 문자열로 다시 해독하지 못하는 이유는 무엇이며 이 문제를 어떻게 해결할 수 있습니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-11 03:21:02373검색

Why does 3DES encryption and decryption in Java usually fail to decrypt the ciphertext back to the original string, and how can this issue be resolved?

Java의 3DES 암호화 및 복호화

일반적으로 3DES를 사용하여 Java에서 문자열을 암호화 및 복호화할 때 일반적인 문제가 발생하여 암호문을 성공적으로 복호화할 수 없게 됩니다. . 원래 문자열을 반환합니다. 이 문서에서는 문자열을 암호화 및 해독하고 이를 원래 문자열로 복원할 수 있는 간단한 코드 예제를 제공합니다.

원래 질문에서 주어진 코드에는 다음과 같은 오류가 있습니다.

  • 암호화 방법에서는 Base64 인코딩 대신 암호화 결과가 직접 반환됩니다.
  • 복호화 방법에서는 Base64 디코딩을 먼저 수행하는 대신 암호화 결과를 복호화된 데이터의 입력으로 직접 사용합니다.

수정된 코드는 다음과 같습니다.

import java.security.MessageDigest;
import java.util.Arrays;

import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;

public class TripleDESTest {

    public static void main(String[] args) throws Exception {

        String text = "kyle boon";

        byte[] codedtext = new TripleDESTest().encrypt(text);
        String decodedtext = new TripleDESTest().decrypt(codedtext);

        System.out.println(codedtext); // this is a byte array, you'll just see a reference to an array
        System.out.println(decodedtext); // This correctly shows "kyle boon"
    }

    public byte[] encrypt(String message) throws Exception {
        final MessageDigest md = MessageDigest.getInstance("md5");
        final byte[] digestOfPassword = md.digest("HG58YZ3CR9"
                .getBytes("utf-8"));
        final byte[] keyBytes = Arrays.copyOf(digestOfPassword, 24);
        for (int j = 0, k = 16; j < 8;) {
            keyBytes[k++] = keyBytes[j++];
        }

        final SecretKey key = new SecretKeySpec(keyBytes, "DESede");
        final IvParameterSpec iv = new IvParameterSpec(new byte[8]);
        final Cipher cipher = Cipher.getInstance("DESede/CBC/PKCS5Padding");
        cipher.init(Cipher.ENCRYPT_MODE, key, iv);

        final byte[] plainTextBytes = message.getBytes("utf-8");
        final byte[] cipherText = cipher.doFinal(plainTextBytes);
        final String encodedCipherText = new sun.misc.BASE64Encoder()
                .encode(cipherText);

        return cipherText;
    }

    public String decrypt(byte[] message) throws Exception {
        final MessageDigest md = MessageDigest.getInstance("md5");
        final byte[] digestOfPassword = md.digest("HG58YZ3CR9"
                .getBytes("utf-8"));
        final byte[] keyBytes = Arrays.copyOf(digestOfPassword, 24);
        for (int j = 0, k = 16; j < 8;) {
            keyBytes[k++] = keyBytes[j++];
        }

        final SecretKey key = new SecretKeySpec(keyBytes, "DESede");
        final IvParameterSpec iv = new IvParameterSpec(new byte[8]);
        final Cipher decipher = Cipher.getInstance("DESede/CBC/PKCS5Padding");
        decipher.init(Cipher.DECRYPT_MODE, key, iv);

        final byte[] encData = new sun.misc.BASE64Decoder().decodeBuffer(message);
        final byte[] plainText = decipher.doFinal(encData);

        return new String(plainText, "UTF-8");
    }
}

올바른 Base64 인코딩 및 디코딩 단계를 사용한 후 코드는 문자열을 성공적으로 3DES 암호화 및 해독할 수 있으며 해독된 결과를 확인할 수 있습니다. 원래 문자열로 올바르게 복원되었습니다.

위 내용은 Java의 3DES 암호화 및 암호 해독이 일반적으로 암호 텍스트를 원래 문자열로 다시 해독하지 못하는 이유는 무엇이며 이 문제를 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.