gpt4 book ai didi

java - 将 'password expiration' 信息从 Wildfly 服务器身份验证模块传递到远程 EJB 客户端

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:16:11 25 4
gpt4 key购买 nike

我们有一个 Wildfly 10 JEE 应用程序和一个使用远程 EJ 调用与服务器通信的 java 胖客户端。身份验证是使用 wildfly 服务器中的自定义登录模块完成的。

现在我们需要用密码过期的概念来增强这个登录模块。每当密码过期时,用户必须在登录过程中更改其密码。登录模块使用 JAAS 回调和 JAAS 回调处理程序。据我所知,我们可以在登录模块中使用 javax.security.auth.callback.TextInputCallback 在执行登录时向用户请求新密码。

这如何与远程处理集成。我们的胖客户端如何接收 TextInputCallback 以提供请求的输入?我想我们必须在客户端注册一个自定义的 CallbackHandler 来处理回调,但我还没有找到任何关于如何使用 Wildfly 执行此操作的文档。任何人都可以给我关于此类文档的提示或有关如何解决此问题的示例吗?

最佳答案

在我看来你走错了方向。使用您将密码更改放入 LoginModule 的方法存在一些问题。

  • 用户登录通常被认为是“安全”的过程,即“没有”副作用的过程。
  • 使用 TextInputCallback 请求新护照至少很奇怪。TextInputCallback 旨在要求用户提供常规文本而不是密码,例如第二个身份验证因素,如(基于时间的)PIN实现 CallbackHandler 的客户端不知道它是一个密码,当显示在屏幕上时可能必须屏蔽该密码。
  • 该方法违反了 LoginModule 的单一职责原则 - LoginModule 负责登录/验证用户。

请记住,通常对于密码更改,您需要经过身份验证/授权的用户,该用户必须通过重新输入他的旧密码来确认密码更改并且通常还提供第二个字段,用户可以在其中重新输入他的新密码。只有一个 xxxCallback 似乎还不够。

即使是控制流也不应该使用 Exceptions 我建议使用 CredentialExpiredException 来向客户端发出用户必须更改的信号密码。这也是 Oracle 在 WebLogic JAAS Examples 之一中执行此操作的方式。

在我的所有评论之后,如果您仍然想要/需要将其放入自定义 LoginModule 中,那么我建议定义您自己的自定义 Callback例如 PasswordChangeCallbackConfirmPasswordCallbackNewPasswordCallbackVerifyNewPasswordCallback

您只需将它们添加到自定义 LoginModule 即可,无需注册它们。请记住,标准客户端可能会遇到这些额外回调的问题。然后,您的客户端必须实现相应的 CallbackHandler

在 JAAS 中,有两种方法可以自定义使用的 CallbackHander* 通过配置自定义默认 CallbackHandler

来自CallbackHandler API documentaion

A default CallbackHandler class implementation may be specified in the auth.login.defaultCallbackHandler security property. The security property can be set in the Java security properties file located in the file named /lib/security/java.security. refers to the value of the java.home system property, and specifies the directory where the JRE is installed.

或者作为参数传递给 LoginContext 的构造函数。LoginContext 提供了两个接受 CallbackHandler

的构造函数
public LoginContext(String name, CallbackHandler callbackHandler)
throws LoginException


public LoginContext(String name, Subject subject,
CallbackHandler callbackHandler) throws LoginException

参见 LoginContext API Documentation

How does it integrate with removing?

它应该和你已经做过的一样。区别不大。

How does our fat client receive the TextInputCallback?

通过CallbackHandler 接口(interface),类似于PasswordCallback。您提到登录模块使用 CallbackHandler

  void  handle(Callback[] callbacks)

如果您想知道如何实现handle 方法CallbackHandler API Documentation还提供了 CallbackHandler handle 方法的实现示例。

关于java - 将 'password expiration' 信息从 Wildfly 服务器身份验证模块传递到远程 EJB 客户端,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44004932/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com