3

Java で非常に単純な RSA 暗号化を台無しにしています。しかし、出力ファイルは空のようです。CipherOutputStream なしで試してみると、同じことが機能します。ループ内の各書き込みサイクルが影響を与えていないことがわかります。手がかり...ありがとう。

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.Security;

import javax.crypto.Cipher;
import javax.crypto.CipherInputStream;
import javax.crypto.CipherOutputStream;


public class ExampleRSA {
    private static String VIDEO_SOURCE_FILE = "C:/Users/ggoldman/Desktop/Video/inputVideo.dv";
    private static String EncryptedFile = "C:/Users/ggoldman/Desktop/Video/encVideo.dv";
    private static File decfile = new File("C:/Users/ggoldman/Desktop/Video/decVideo.dv");
    private static File incfile = new File(EncryptedFile);
    private static File sourceMedia = new File(VIDEO_SOURCE_FILE);


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


        KeyPairGenerator kpg = KeyPairGenerator.getInstance("RSA");
        Cipher cipher = Cipher.getInstance("RSA");

        kpg.initialize(1024);
        KeyPair keyPair = kpg.generateKeyPair();
        PrivateKey privKey = keyPair.getPrivate();
        PublicKey pubKey = keyPair.getPublic();

        // Encrypt

        cipher.init(Cipher.ENCRYPT_MODE, pubKey);


        FileInputStream fis = new FileInputStream(sourceMedia);
        FileOutputStream fos = new FileOutputStream(incfile);
        CipherOutputStream cos = new CipherOutputStream(fos, cipher);

        byte[] block = new byte[32];
        int i;
        while ((i = fis.read(block)) != -1) {
            cos.write(block, 0, i);
        }
        cos.close();
}
4

1 に答える 1

2

RSAだけでファイル全体を暗号化および復号化することはできません(少なくとも、小さな文字列以上の場合はそうではありません)。RSA アルゴリズムは 1 つのブロックのみを暗号化でき、ファイル全体を処理するにはかなり時間がかかります。

3DES または AES を使用してファイルを暗号化し、受信者の RSA 公開鍵を使用して AES キーを暗号化できます。

于 2012-11-26T18:51:49.393 に答える