Glassfish中的密码加密算法



我最近将Glassfish从3.1.2更新到4.0,并想在我的应用程序上使用基于表单的身份验证之前设置一个JDBCRealm。密码在数据库中使用SHA-256散列(这是默认的摘要算法选项)。

领域有一个属性在这个Glassfish版本中是必须的:Password Encryption Algorithm。令人难以置信的是,官方Glassfish文档说它是可选的,输入字段下的注释说将其保留为空是有风险的,但是你不能将其保留为空,因为它是强制性的。

无论我在这个属性中设置什么,我都无法登录之前工作的应用程序。(新注册用户和老用户都是如此。)我在谷歌上搜索了好几天,但找不到这个领域的选项。有哪些选择?

另外,我正在使用MySQL的Glassfish。Glassfish发送的哈希密码加密到DB或只是一些指令MySQL存储哈希密码与这种加密?

这个问题对我有点帮助,但并没有解决我的问题。

更新:实际上,我不使用经典的基于表单的身份验证,而是使用HttpServletRequest#login()的自定义JSF表单编程登录,但我不认为这在这个问题上很重要。

我用Glassfish 4.1和一个为MySQL配置的JDBC Realm测试了一个简单的用例。

您可以设置一个简单的用户表:

  • name:存储用户名
  • password:存储用户的SHA-256哈希值密码(不加盐)
  • group:存储用户组(即admin, user)

INSERT INTO users (name, password, group) VALUES ("admin", SHA2("password", 256), "admins"); 

在管理控制台中,转到配置>安全>领域并编辑您的领域。

在"密码加密算法"一栏输入"AES"。

在"摘要算法"字段中输入"SHA-256"。

在"Charset"字段中输入"UTF-8"。

相关内容

  • 没有找到相关文章

最新更新