0

AES暗号化を使用してテキストファイルを暗号化したい。
ただし、Aesコードとファイル読み取りコードを組み合わせる方法がわかりません。私はこの種の暗号化に不慣れです。どんな助けでも大歓迎です。

私はこれをやろうとしました。また、暗号化の下にエラーがあり、引数には適用できないと述べています。または私は別の方法でそれを行う必要がありますか?

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

    FileReader file = new FileReader ("original.txt");
    BufferedReader reader = new BufferedReader(file);

    String text = "";
    String line = reader.readLine();
    while(line !=null)
    {
        text +=line; 
        line = reader.readLine();
    }


    String test = Testing.encrypt(text);
    System.out.println("Encrypted : " + test);
    reader.close();
  } 

完全なコードは以下のとおりです。どうもありがとうございます。

(AES暗号化)

 package encypt.com;

import java.io.BufferedReader;
import java.io.FileReader;
import java.security.*;
import java.security.spec.InvalidKeySpecException;
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import sun.misc.*;

public class Testing {

private static final String ALGORITHM = "AES";
private static final int ITERATIONS = 2;
private static final byte[] keyValue = 
    new byte[] { 'T', 'h', 'i', 's', 'I', 's', 'A', 'S', 'e', 'c', 'r', 'e', 't', 'K', 'e', 'y'};

public static String encrypt(String value, String salt) throws Exception {
    Key key = generateKey();
    Cipher c = Cipher.getInstance(ALGORITHM);  
    c.init(Cipher.ENCRYPT_MODE, key);

    String valueToEnc = null;
    String eValue = value;
    for (int i = 0; i < ITERATIONS; i++) {
        valueToEnc = salt + eValue;
        byte[] encValue = c.doFinal(valueToEnc.getBytes());
        eValue = new BASE64Encoder().encode(encValue);
    }
    return eValue;
}

public static String decrypt(String value, String salt) throws Exception {
    Key key = generateKey();
    Cipher c = Cipher.getInstance(ALGORITHM);
    c.init(Cipher.DECRYPT_MODE, key);

    String dValue = null;
    String valueToDecrypt = value;
    for (int i = 0; i < ITERATIONS; i++) {
        byte[] decordedValue = new BASE64Decoder().decodeBuffer(valueToDecrypt);
        byte[] decValue = c.doFinal(decordedValue);
        dValue = new String(decValue).substring(salt.length());
        valueToDecrypt = dValue;
    }
    return dValue;
}

private static Key generateKey() throws Exception {
    Key key = new SecretKeySpec(keyValue, ALGORITHM);
    // SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ALGORITHM);
    // key = keyFactory.generateSecret(new DESKeySpec(keyValue));
    return key;
}


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


    String password = "mypassword";
    String salt = "this is a simple clear salt";
    String passwordEnc = Testing.encrypt(password, salt);
    String passwordDec = Testing.decrypt(passwordEnc, salt);

   System.out.println("Salt Text : " + salt);
   System.out.println("Plain Text : " + password);
   System.out.println("Encrypted : " + passwordEnc);
   System.out.println("Decrypted : " + passwordDec);
}
}

(ファイル読み取りコード)

package encypt.com;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.util.Scanner;

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

    FileReader file = new FileReader ("key.txt");
    BufferedReader reader = new BufferedReader(file);

    String text = "";
    String line = reader.readLine();
    while(line !=null)
    {
        text +=line; 
        line = reader.readLine();
    }

    reader.close();
    System.out.println(text); 
  } 
} 
4

1 に答える 1

2

電話をかけようとしたためにエラーが発生したと思います

public static String encrypt(String value, String salt)

String test = Testing.encrypt(text);

そのため、saltパラメータがありません。

ieでこの関数を呼び出してみてください

String test = Testing.encrypt(text,"mySalt");
于 2012-08-13T13:13:33.590 に答える