Ayúdeme por favor en un problema kerberos + Java. Tengo un programa simple de Java para autenticar a un directorio activo de Windows usando Kerberos. El siguiente código de Java funciona bien sin ningún problema y estampados cierto-Autenticación Java y Kerberos krb5.conf versus System.setProperty
public class KerberosAuthenticator {
public static void main(String[] args) {
String jaasConfigFilePath = "/myDir/jaas.conf";
System.setProperty("java.security.auth.login.config", jaasConfigFilePath);
System.setProperty("java.security.krb5.realm", "ENG.TEST.COM");
System.setProperty("java.security.krb5.kdc","winsvr2003r2.eng.test.com");
boolean success = auth.KerberosAuthenticator.authenticate("testprincipal", "testpass");
System.out.println(success);
}
}
Bue cuando especifique la ruta al archivo krb5.conf en lugar de especificar manualmente el reino y KDC, él los errores hacia fuera diciendo "nombre de dominio nulo (601) - reino predeterminado no especificado ". El siguiente es el código-
public class KerberosAuthenticator {
public static void main(String[] args) {
String jaasConfigFilePath = "/myDir/jaas.conf";
System.setProperty("java.security.auth.login.config", jaasConfigFilePath);
String krb5ConfigFilePath = "/etc/krb5/krb5.conf";
System.setProperty("java.security.krb5.conf", krb5ConfigFilePath);
boolean success = auth.KerberosAuthenticator.authenticate("testprincipal", "testpass");
System.out.println(success);
}
}
El contenido de krb5.conf es la siguiente manera-
[libdefault]
default_realm = ENG.TEST.COM
[realms]
ENG.TEST.COM = {
kdc = winsvr2003r2.eng.test.com
kpasswd_server = winsvr2003r2.eng.test.com
admin_server = winsvr2003r2.eng.test.com
kpasswd_protocol = SET_CHANGE
}
[domain_realm]
.eng.test.com = ENG.TEST.COM
eng.test.com = ENG.TEST.COM
[logging]
default = FILE:/var/krb5/kdc.log
kdc = FILE:/var/krb5/kdc.log
kdc_rotate = {
period = 1d
versions = 10
}
[appdefaults]
kinit = {
renewable = true
forwardable = true
}
No conozco la respuesta a su pregunta, pero si estuviera en su lugar, usaría el depurador de mi IDE para ingresar al 'KerberosAuthenticator' y determinar por qué no está obteniendo el dominio predeterminado. ¡Buena suerte! –