我正在研究检查 Kerberos KeyTab 文件是否有效的 Java 代码库,但它使用内部类sun.security.krb5.internal.ktab.KeyTab
作为其isValid()
方法。目前,它正在执行以下操作:
File keytabFile = new File("/path/to/keytab");
KeyTab keytab = KeyTab.getInstance(keytabFile);
boolean keytabIsValid = keytab.isValid();
if (!keytabIsValid) {
throw new ApplicationSpecificException("Keytab is not valid");
}
在 Java 9 中访问这个方法更令人烦恼,所以我正在寻找一种方法来避免使用这个内部类,但是浏览 JDK 源代码,我还没有看到任何公开该isValid()
方法或等价物的东西- 内部类。
是否有不依赖黑客的选项,例如反映私有方法或访问内部 API?