6

これは、暗号化と復号化のプロセスに使用している現在のコードであり、暗号化と復号化の時間が長すぎることを除いて、本来あるべき方法で機能します。

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import javax.crypto.Cipher;
import javax.crypto.CipherInputStream;
import javax.crypto.CipherOutputStream;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;

public class EncryptAndDecrypt{

   public static void main(String[] args) {
    try {
        String key = "myencryptedpass123";

        FileInputStream fis = new FileInputStream("File_to_encrypt.mp4");
        FileOutputStream fos = new FileOutputStream("Encrypted_file.mp4");
        encrypt(key, fis, fos);

        FileInputStream fis2 = new FileInputStream("Encrypted_file.mp4");
        FileOutputStream fos2 = new FileOutputStream("File_to_decrypt.mp4");
        decrypt(key, fis2, fos2);
    } catch (Throwable e) {
        e.printStackTrace();
    }
}

public static void encrypt(String key, InputStream is, OutputStream os) throws Throwable {
    encryptOrDecrypt(key, Cipher.ENCRYPT_MODE, is, os);
}

public static void decrypt(String key, InputStream is, OutputStream os) throws Throwable {
    encryptOrDecrypt(key, Cipher.DECRYPT_MODE, is, os);
}

public static void encryptOrDecrypt(String key, int mode, InputStream is, OutputStream os) throws Throwable {

    DESKeySpec dks = new DESKeySpec(key.getBytes());
    SecretKeyFactory skf = SecretKeyFactory.getInstance("DES");
    SecretKey desKey = skf.generateSecret(dks);
    Cipher cipher = Cipher.getInstance("DES"); 

    if (mode == Cipher.ENCRYPT_MODE) {
        cipher.init(Cipher.ENCRYPT_MODE, desKey);
        CipherInputStream cis = new CipherInputStream(is, cipher);
        doCopy(cis, os);
    } else if (mode == Cipher.DECRYPT_MODE) {
        cipher.init(Cipher.DECRYPT_MODE, desKey);
        CipherOutputStream cos = new CipherOutputStream(os, cipher);
        doCopy(is, cos);
    }
}

public static void doCopy(InputStream is, OutputStream os) throws IOException {
    byte[] bytes = new byte[64];
    int numBytes;
    while ((numBytes = is.read(bytes)) != -1) {
        os.write(bytes, 0, numBytes);
    }
    os.flush();
    os.close();
    is.close();
}

}

今、より良い解決策を望んでいます...

4

2 に答える 2

2

より大きなバッファーを使用することは間違いありませんが、暗号化は主に CPU バウンドであるため、はるかに高速になる可能性は低いです。さらに

  • 「セキュリティ上の欠陥を気にしない」場合は、暗号化を完全に放棄することをお勧めします
  • DES を使用しています。使用しないでください
  • 人間が読める文字列をキーとして使用しています -- 使用しないでください
  • の別のインスタンスで暗号化と復号化を行うと、そのコードは機能しない可能性がありますCipher
  • デフォルトを使用している場合は、トラブルに備えることになります。次のようなものを使用しますCipher.getInstance("AES/CBC/PKCS5Padding")
  • これを Android で動作させたいのに、なぜデスクトップでテストしているのですか?

はい、アプリにキーを含めると、「DRM」はあまり役に立ちません。

于 2012-05-11T02:59:24.897 に答える