如何解决如何从 Java 应用程序成功连接到经过 kerberos 身份验证的 mongod 实例? 我在初始化 GSSAPI 凭据时遇到异常
我已经在 kerberos 身份验证模式下启动了 mongod 实例。我能够从 mongo shell 进行连接。从 java 应用程序连接时,出现以下异常:
Key for the principal mongodb/****@**** not available in ***.keytab
[Krb5LoginModule] authentication Failed
Unable to obtain password from user
我的 gss-jaas.conf 是
com.sun.security.jgss.initiate {
com.sun.security.auth.module.Krb5LoginModule required
useKeyTab=true
useTicketCache=false
principal="mongodb/***@***"
doNotPrompt=true
keyTab="D:\***.keytab"
debug=true;};
我使用 ktuil 并执行以下命令将主体写入 keytab 文件。谁能帮我找出问题所在?
ktutil: add_entry -password -p mongodb/***@*** -k 1 -e des-cbc-md4
Password for mongodb/***@***:
ktutil: wkt /tmp/***.keytab
ktutil: quit
我已经输入了密码并尝试通过回车跳过它。在这两种情况下,我都遇到了上述异常。我在 java 应用程序中使用了以下系统属性:
System.setProperty("java.security.krb5.conf","D:\\krb5.conf");
System.setProperty("java.security.auth.login.config","D:\\gss-jaas.conf");
System.setProperty("javax.security.auth.useSubjectCredsOnly","false");
System.setProperty("java.security.krb5.realm","****");
System.setProperty("java.security.krb5.kdc","*****");
kerberosCredential = MongoCredential.createGSSAPICredential(userName);
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。