Javaで文字列のSHA-256ハッシュ値を計算する次のプログラムを作成しました。
_public class ToHash {
public static void main(String[] args) {
byte[] data = "test".getBytes("UTF8");
MessageDigest digest = MessageDigest.getInstance("SHA-256");
byte[] hash = digest.digest(data);
System.out.println(new BASE64Encoder().encode(hash));
}
}
_
まあ、それはうまくいきます。次のステップでは、ファイルを受け入れてそのハッシュ値を計算する方法で開発したいと思います。私の解決策は、文字列配列内のファイル全体を読み取り、その文字列配列でdigest()
メソッドを呼び出すことです。しかし、2つの問題があります:
ファイル全体を配列に読み込む方法がわかりませんか?現在、私はそれを1行ずつ読み、新しい行を配列に追加する必要があると思います!
上記の方法では、大きなファイル用に大量のメモリが必要です。
これは、ファイルを読み取るための現在のプログラムです。
_public class ToHash {
public static void main(String[] args) throws NoSuchAlgorithmException, UnsupportedEncodingException, FileNotFoundException, IOException {
// TODO code application logic here
// The name of the file to open.
String fileName = "C:\\Users\\ghasemi\\Desktop\\1.png";
BufferedReader br = null;
try {
String sCurrentLine;
br = new BufferedReader(new FileReader(fileName));
while ((sCurrentLine = br.readLine()) != null) {
byte[] data = sCurrentLine.getBytes("UTF8");
System.out.println(new BASE64Encoder().encode(data));
}
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
if (br != null) {
br.close();
}
} catch (IOException ex) {
ex.printStackTrace();
}
}
}
}
_
BufferedReader
オブジェクトが1回の呼び出しでファイル全体を読み取るメソッドがないようです。
ファイルを読み取って、ハッシュの値を計算することができます。
byte[] buffer= new byte[8192];
int count;
MessageDigest digest = MessageDigest.getInstance("SHA-256");
BufferedInputStream bis = new BufferedInputStream(new FileInputStream(fileName));
while ((count = bis.read(buffer)) > 0) {
digest.update(buffer, 0, count);
}
bis.close();
byte[] hash = digest.digest();
System.out.println(new BASE64Encoder().encode(hash));
これは、文字セットやファイルのメモリへの適合については何も想定しておらず、行末記号も無視しません。
または、DigestInputStream.
を使用できます