我想为我的spring security kerberos身份验证实现集成测试。 为此目的,有 KerberosRestTemplate (reference)。 KerberosRestTemplate 有一个默认构造函数,其描述为“如果要使用缓存票证,请将keyTabLocation和userPrincipal留空”。
对于研究我写了一个琐碎的课程:
public static void main(String[] args) {
KerberosRestTemplate krt = new KerberosRestTemplate();
String result = krt.getForObject("http://testserver.testad.local:8080/", String.class);
System.out.println(result);
}
当我运行它时,异常抛出:
Exception in thread "main" org.springframework.web.client.RestClientException: Error running rest call; nested exception is java.lang.IllegalArgumentException: Null name not allowed
at org.springframework.security.kerberos.client.KerberosRestTemplate.doExecute(KerberosRestT
emplate.java:196)
at org.springframework.web.client.RestTemplate.execute(RestTemplate.java:530)
at org.springframework.web.client.RestTemplate.getForObject(RestTemplate.java:237)
at edu.mezlogo.Application.main(Application.java:9)
Caused by: java.lang.IllegalArgumentException: Null name not allowed
at sun.security.krb5.PrincipalName.<init>(Unknown Source)
at sun.security.krb5.PrincipalName.<init>(Unknown Source)
at javax.security.auth.kerberos.KerberosPrincipal.<init>(Unknown Source)
at javax.security.auth.kerberos.KerberosPrincipal.<init>(Unknown Source)
at org.springframework.security.kerberos.client.KerberosRestTemplate.doExecute(KerberosRestT
emplate.java:182)
... 3 more
我的 klist 包含正确的缓存票证,用于我的服务。
#2> Client: deniz @ TESTAD.LOCAL
Server: HTTP/testserver.testad.local @ TESTAD.LOCAL
KerbTicket Encryption Type: RSADSI RC4-HMAC(NT)
Ticket Flags 0x40a10000 -> forwardable renewable pre_authent name_canonicalize
Start Time: 2/5/2016 6:17:39 (local)
End Time: 2/5/2016 16:16:32 (local)
Renew Time: 2/12/2016 6:16:32 (local)
Session Key Type: RSADSI RC4-HMAC(NT)
我的浏览器(firefox)已成功通过kerberos sso进行身份验证。
我使用Windows Server 2012.而Windows 7作为客户端。
如何使用缓存票证? (并且ktpass可以生成客户端密钥表吗?)
P.S。对不起我的英文。
答案 0 :(得分:1)
您正在检查Windows凭据缓存 - 而Java正在维护它是独立的。要查看Java的凭据缓存,您应该从klist
文件夹中执行JRE/bin
命令