我怎样才能在oracle中获得JAVA中日期的md5总和?

时间:2011-07-08 13:38:44

标签: java oracle md5

我有下一个麻烦。 在数据库日期从日期开始作为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中?

1 个答案:

答案 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代码中存在一个非常糟糕的错误,它创建并存储了这些哈希值。将日期隐式转换为字符串可能很危险。