为LDAP用户设置已经哈希的密码(使用Java)

时间:2015-01-26 15:43:37

标签: java security hash passwords ldap

我尝试将遗留应用程序(自己的用户管理)迁移到LDAP。旧应用程序将其用户存储在具有散列密码的数据库表中。我知道散列算法(SSHA-256)以及salt(用户名),我能用几行代码重新创建散列(当我知道密码时,例如其中一个测试用户)。

这就是哈希的创建方式:

public static String hash(String password, String salt) throws Exception {

    MessageDigest messageDigest = MessageDigest.getInstance("SHA-256");
    String text = password + "{" + salt + "}";
    messageDigest.update(text.getBytes("UTF-8"));
    byte[] digest = messageDigest.digest();
    StringBuilder stringBuilder = new StringBuilder(digest.length * 2);
    for(byte b: digest)
        stringBuilder.append(String.format("%02x", b & 0xff));
    return stringBuilder.toString();
}

此方法的结果存储在旧数据库中。我也想为LDAP中的用户使用此密码哈希(否则,每个用户必须在迁移后创建新密码)。我尝试以下方法在LDAP中设置密码:

Attribute attribute = new BasicAttribute("userpassword", someHashFromTheMethodAbove);
ModificationItem[] modifications = new ModificationItem[1];
modifications[0] = new ModificationItem(DirContext.REPLACE_ATTRIBUTE, attribute);
context.modifyAttributes("uid=testuser,ou=User,dc=users,dc=de", modifications);

密码的实际设置有效,我可以看到密码已被更改。但是,我无法使用新密码进行身份验证。

enter image description here

1 个答案:

答案 0 :(得分:3)

在大多数LDAP服务器中,SSHA散列方案基于SHA1而不是SHA-256。 您可能想尝试使用{SSHA256}前缀。