RubyにおけるHmacMD 5暗号化
3058 ワード
詳細
Java側とインタフェースをして、真ん中にHmacMD 5の暗号化アルゴリズムがあります.
so,soの結果は以下の通りである.
rubyの出力結果
参照
=> "3FD9B6B4901DAF25BFB9DAA0718B3698"
JAvaの出力結果
参照
3FD9B6B4901DAF25BFB9DAA0718B3698
補足:
secret key直接MD 5を使用しない場合は、次のrubyコードを呼び出せばよい.
MD 5方面のライブラリはまだ比較的に多くて、Opensslの中にもあります
Java側とインタフェースをして、真ん中にHmacMD 5の暗号化アルゴリズムがあります.
so,soの結果は以下の通りである.
gem install ruby-hmac
require 'hmac-md5'
HMAC::MD5.new("test_key").update("test_string").hexdigest.upcase()
rubyの出力結果
参照
=> "3FD9B6B4901DAF25BFB9DAA0718B3698"
package com.study;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import javax.crypto.Mac;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
public class HmacMD5 {
private static byte[] encryptHMAC(String data, String secret) {
byte[] bytes = null;
SecretKey secretKey;
try {
secretKey = new SecretKeySpec(secret.getBytes(Constants.CHARSET_UTF8), "HmacMD5");
Mac mac = Mac.getInstance(secretKey.getAlgorithm());
mac.init(secretKey);
bytes = mac.doFinal(data.getBytes(Constants.CHARSET_UTF8));
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InvalidKeyException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return bytes;
}
private static String byte2hex(byte[] bytes) {
StringBuilder sign = new StringBuilder();
for (int i = 0; i < bytes.length; i++) {
String hex = Integer.toHexString(bytes[i] & 0xFF);
if (hex.length() == 1) {
sign.append("0");
}
sign.append(hex.toUpperCase());
}
return sign.toString();
}
public abstract class Constants
{
public static final String CHARSET_UTF8 = "UTF-8";
}
public static void main(String[] args) throws UnsupportedEncodingException,
IOException {
String str = "test_string";
byte[] bytes = encryptHMAC(str,"test_key");
String data = byte2hex(bytes);
System.out.println(data);
}
}
JAvaの出力結果
参照
3FD9B6B4901DAF25BFB9DAA0718B3698
補足:
secret key直接MD 5を使用しない場合は、次のrubyコードを呼び出せばよい.
Digest::MD5.hexdigest('test_string').upcase
=> "3474851A3410906697EC77337DF7AAE4"
MD 5方面のライブラリはまだ比較的に多くて、Opensslの中にもあります