如何为Tomcat JDBCRealm准备摘要密码



此处为示例http://tomcat.apache.org/tomcat-7.0-doc/realm-howto.html#JDBCRealmuser_pass列的类型为varchar(15),而java.security.MessageDigest类获取并返回byte[]。哪个转换应该应用于密码'abcd'(例如),以将其转换为Tomcat所期望的MD5摘要?

PS。

我尝试了以下方法,它有效(与digest.bat结果一致)。现在唯一的问题是长度:摘要更长,超过15个字符。我可以换一下桌子吗?

public class DigestRunner {
    /**
     * @param args
     * @throws NoSuchAlgorithmException 
     */
    public static void main(String[] args) throws NoSuchAlgorithmException {
        String password = "abcd";
        MessageDigest dig = MessageDigest.getInstance("MD5");
        System.out.println(toString(dig.digest(password.getBytes())));
    }

    public static String toString(byte[] ba)
    {
        StringBuilder hex = new StringBuilder(ba.length * 2);
        for(byte b : ba)
            hex.append(String.format("%02x", b));
        return hex.toString();
    }
}

varchar(15)对于摘要密码来说肯定太短,但对于明文密码来说通常足够了。只需加大尺寸即可。

我使用了以下代码来创建摘要密码:

final MessageDigest messageDigest = java.security.MessageDigest.
        getInstance("SHA-256");
final byte bin[] = messageDigest.digest(("admin").getBytes());
System.out.println(Base64.encodeBase64String(bin));

(来自Apache Commons编解码器的Base64

此外,Tomcat中有一个digest.bat/digest.sh,请在您链接的页面上查看它。

相关内容

  • 没有找到相关文章

最新更新