我有下一个麻烦。 在数据库日期从日期开始作为md5存储。当我在JAVA中从同一个日期创建md5时,我有另一个哈希。 例如:date - 01.02.1980 java hash是addaf0f9a1fb3699871293f888f6e46e(与字符串中的oracle md5 hash相同) oracle hash是DF0919EA828A77DC2CCF68474ED703AC
我试着在java中重复oracle结果:
System.out.println(streamConvertor.getHash("01.02.1980", Boolean.TRUE));
System.out.println("");
System.out.println(streamConvertor.getHash("01.02.1980", Boolean.FALSE));
public String getMD5(String input, Boolean is_date) throws ParseException {
try {
MessageDigest md = MessageDigest.getInstance("MD5");
byte[] mdinput;
Boolean pr;
if (input.equals("01.02.1980")) {
pr = true;
} else {
pr = false;
}
if (is_date == Boolean.TRUE) {
SimpleDateFormat df = new SimpleDateFormat("dd.MM.yyyy");
Date day = df.parse(input);
mdinput = df.format(day).getBytes();
} else {
mdinput = input.getBytes();
}
if (pr == Boolean.TRUE) {
System.out.println("Is date " + is_date + " - " + mdinput);
}
byte[] messageDigest = md.digest(mdinput);
if (pr == Boolean.TRUE) {
System.out.println("message - " + messageDigest);
}
BigInteger number = new BigInteger(1, messageDigest);
if (pr == Boolean.TRUE) {
System.out.println("Number - " + number);
}
String hashtext = number.toString(16);
// Now we need to zero pad it if you actually want the full 32 chars.
while (hashtext.length() < 32) {
hashtext = "0" + hashtext;
}
if (pr == Boolean.TRUE) {
System.out.println("hashtext - " + hashtext);
}
return hashtext;
}
catch (NoSuchAlgorithmException e) {
throw new RuntimeException(e);
}
}
并且输出不同,但只有在byte []转换为BigInteger:
之后Is date true - [B@4a65e0
message - [B@665753
Number - 231093251542199165689934828427325924462
hashtext - addaf0f9a1fb3699871293f888f6e46e
Is date false - [B@ef22f8
message - [B@1e0cf70
Number - 231093251542199165689934828427325924462
hashtext - addaf0f9a1fb3699871293f888f6e46e
有没有可能制作md5哈希,例如在oracle中?
答案 0 :(得分:2)
在上面的评论中,您说Oracle中使用的确切表达式是:
DBMS_CRYPTO.hash( UTL_RAW.CAST_TO_RAW( UPPER(to_date('01.02.1980', 'dd.mm.yyyy')) ),2 )
所以你取字符串'01 .02.1980'并使用适当的格式将其转换为DATE
。然后将结果传递给UPPER()
;这将导致DATE
使用会话的默认日期格式隐式转换为字符串。因此,如果在不同的环境中执行此表达式的结果可能会有所不同。
要尝试在Java中重现相同的哈希值,请使用NLS_DATE_FORMAT
实例参数指示的日期格式。但是有可能对某些条目有效,但对其他条目有效,因为使用的日期格式可能有所不同。
基本上,Oracle代码中存在一个非常糟糕的错误,它创建并存储了这些哈希值。将日期隐式转换为字符串可能很危险。