問題:
3DES 暗号化を使用して文字列を正常に暗号化および復号化できないコード内で繰り返されるエラーのためimplementation.
解決策:
この問題に対処するには、提供されたコードを分析しましょう:
public class TripleDESTest { // ... public byte[] encrypt(String message) { // ... final byte[] plainTextBytes = message.getBytes("utf-8"); final byte[] cipherText = cipher.doFinal(plainTextBytes); final String encodedCipherText = new sun.misc.BASE64Encoder().encode(cipherText); return cipherText; } // ... }
Base64 エンコーディングの誤解:
当初、コードには次の行が含まれていました。 Base64 の場合、暗号文を返す前にエンコードします。ただし、復号化メソッドでは Base64 エンコーディングが使用されていなかったため、暗号文はバイト配列として直接返される必要があります。
生のバイト配列の印刷:
コードは、暗号化されたデータと復号されたデータの両方をバイト配列として出力します。 System.out.println(codedtext);および System.out.println(decodedtext);。バイト配列は人間が判読できる値としてレンダリングされないため、これは意味のある出力を提供しません。実際の復号化されたテキストを表示するには、 new String(plainText, "UTF-8") を使用して文字列に変換します。
修正コード:
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(decodedtext); } 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
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3