gpt4 book ai didi

java - 如何使 JMX 自定义身份验证工作?

转载 作者:行者123 更新时间:2023-11-30 12:00:12 24 4
gpt4 key购买 nike

我在 JMX 上使用基于密码和访问文件的身份验证。在构建我的 JMXConnectorServer 时,我使用属性名称并且它工作正常。

Map<String, String> env = new HashMap<String, String>();
env.put(ApplicationProperties.JMX_PWD_FILE_PROP, pwdFile);
env.put(ApplicationProperties.JMX_ACCESS_FILE_PROP, accFile);
connectorServer = JMXConnectorServerFactory.newJMXConnectorServer(jmxServiceURL, env, mBeanServer);

但是,现在我想使用自定义身份 validator ,并且我实现了自己的登录模块以在密码文件中使用加密密码。因此,想法是在密码文件中有一个加密的密码和纯文本用户名。

public class ABCDJMXLoginModule implements LoginModule {

private CallbackHandler callbackHandler;
private Subject subject;
private String u_username;
private String u_password;
private JMXPrincipal user;
private Properties userCredentials;
private String passwordFile;
private String f_username;
private String f_password;

private static final Logger logger = LoggerFactory.getLogger(ABCDJMXLoginModule.class);

public boolean abort() throws LoginException {
// TODO Auto-generated method stub
return false;
}

public boolean commit() throws LoginException {
// TODO Auto-generated method stub
return true;
}

public void initialize(Subject subject, CallbackHandler callbackHandler, Map<String, ?> sharedState,
Map<String, ?> options) {
this.subject = subject;
this.callbackHandler = callbackHandler;
}

public boolean login() throws LoginException {
try {
attemptLogin();
loadPasswordFile();
} catch (Exception e) {
logger.info("Exception, e");
}
if (u_username == null || u_password == null) {
throw new LoginException("Either no username or no password specified");
}
logger.info("Password from user and file : " + u_password + " :: " + f_password);
if (u_password.equals(f_password)) {
return true;
}
return false;

}

public boolean logout() throws LoginException {
// TODO Auto-generated method stub
return true;
}

private void attemptLogin() throws LoginException {
Callback[] callbacks = new Callback[2];
callbacks[0] = new NameCallback("u_username");
callbacks[1] = new PasswordCallback("u_password", false);
try {
callbackHandler.handle(callbacks);
} catch (IOException e) {
logger.error("IOException", e);
} catch (UnsupportedCallbackException e) {
logger.error("UnsupportedCallbackException", e);
}
u_username = ((NameCallback) callbacks[0]).getName();
user = new JMXPrincipal(u_username);
char[] tmpPassword = ((PasswordCallback) callbacks[1]).getPassword();
u_password = tmpPassword.toString();
logger.info("UserName : " + u_username);
logger.info("Password : " + u_password);
System.arraycopy(tmpPassword, 0, u_password, 0, tmpPassword.length);
((PasswordCallback) callbacks[1]).clearPassword();
}

private void loadPasswordFile() throws IOException {
FileInputStream fis = null;
passwordFile = "c:\\abcd.jmx.enc.password.file";

try {
fis = new FileInputStream(passwordFile);
} catch (SecurityException e) {
logger.error("Security Exception", e);
}
BufferedInputStream bis = new BufferedInputStream(fis);
userCredentials = new Properties();
userCredentials.load(bis);
bis.close();
f_username = u_username;
f_password = (String) userCredentials.get(f_username);
logger.info("UserName before Decrypt : " + f_username);
logger.info("Password from file before Decrypt : " + f_password);
// decrypt the password from file and later compare it with user password from JConsole
if (f_password != null) f_password = Cryptography.decrypt(f_password);
logger.info("Password from file after Decrypt : " + f_password);
}

}

当我使用以下代码并尝试通过 JConsole 连接时,没有任何反应。

Map<String, String> env = new HashMap<String, String>();
env.put(ApplicationProperties.JMX_PWD_FILE_PROP, pwdFile);
env.put(ApplicationProperties.JMX_ACCESS_FILE_PROP, accFile);
env.put("jmx.remote.x.login.config", "com.splwg.ejb.service.management.ABCDJMXLoginModule");
connectorServer = JMXConnectorServerFactory.newJMXConnectorServer(jmxServiceURL, env, mBeanServer);

关于为什么会发生这种情况的任何想法?当然,我也不会进入 ABCDJMXLoginModule 类 - 我在那里有一些打印语句,但没有一个被打印出来。任何类型的想法和解决方案表示赞赏。我也尝试使用属性“com.sun.management.jmxremote.login.config”。我原以为在环境中提及该属性并将其传递给 JMXCOnnectorServer 就可以解决所有问题。

我错过了什么吗?

最佳答案

env.put("jmx.remote.x.login.config", "com.splwg.ejb.service.management.ABCDJMXLoginModule");

jmx.remote.x.login.config 属性用于设置上下文名称,而不是您的 LoginModule 类名称。

您需要创建 jaas 模块配置文件并通过系统属性引用它,而不是输入您的 LoginModule 类名,例如:-Djava.security.auth.login.config=path/to/your/login/config/file.cfg

示例配置:

MyConfig {
com.splwg.ejb.service.management.ABCDJMXLoginModule REQUIRED
configKey1="config Value 1"
configKey2="config Value 2"
}

在你的java代码中:

env.put("jmx.remote.x.login.config", "MyConfig");

我也会删除

env.put(ApplicationProperties.JMX_PWD_FILE_PROP, pwdFile);

因为我认为这可能会导致使用标准的 jmx 身份验证机制而不是 JAAS(但我不确定)。

通过上述更改,您应该拥有基于 jaas 的身份验证(使用您的自定义登录模块)和使用 accFile 的授权的 jmx。

关于java - 如何使 JMX 自定义身份验证工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2143653/

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