Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
58f816a4
D
dragonwell8_jdk
项目概览
openanolis
/
dragonwell8_jdk
通知
4
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_jdk
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
58f816a4
编写于
6月 17, 2009
作者:
W
weijun
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
6849275: enhance krb5 reg tests
Reviewed-by: xuelei
上级
221295e8
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
122 addition
and
136 deletion
+122
-136
test/sun/security/krb5/auto/CrossRealm.java
test/sun/security/krb5/auto/CrossRealm.java
+8
-3
test/sun/security/krb5/auto/HttpNegotiateServer.java
test/sun/security/krb5/auto/HttpNegotiateServer.java
+3
-39
test/sun/security/krb5/auto/KDC.java
test/sun/security/krb5/auto/KDC.java
+90
-66
test/sun/security/krb5/auto/META-INF/services/sun.net.spi.nameservice.NameServiceDescriptor
...NF/services/sun.net.spi.nameservice.NameServiceDescriptor
+1
-1
test/sun/security/krb5/auto/OneKDC.java
test/sun/security/krb5/auto/OneKDC.java
+5
-18
test/sun/security/krb5/auto/basic.sh
test/sun/security/krb5/auto/basic.sh
+15
-9
未找到文件。
test/sun/security/krb5/auto/CrossRealm.java
浏览文件 @
58f816a4
/*
/*
* Copyright 2008 Sun Microsystems, Inc. All Rights Reserved.
* Copyright 2008
-2009
Sun Microsystems, Inc. All Rights Reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
*
* This code is free software; you can redistribute it and/or modify it
* This code is free software; you can redistribute it and/or modify it
...
@@ -26,6 +26,7 @@
...
@@ -26,6 +26,7 @@
* @bug 6706974
* @bug 6706974
* @summary Add krb5 test infrastructure
* @summary Add krb5 test infrastructure
*/
*/
import
java.io.File
;
import
java.io.FileOutputStream
;
import
java.io.FileOutputStream
;
import
java.io.IOException
;
import
java.io.IOException
;
import
java.security.Security
;
import
java.security.Security
;
...
@@ -50,17 +51,20 @@ public class CrossRealm implements CallbackHandler {
...
@@ -50,17 +51,20 @@ public class CrossRealm implements CallbackHandler {
KDC
kdc1
=
KDC
.
create
(
"RABBIT.HOLE"
);
KDC
kdc1
=
KDC
.
create
(
"RABBIT.HOLE"
);
kdc1
.
addPrincipal
(
"dummy"
,
"bogus"
.
toCharArray
());
kdc1
.
addPrincipal
(
"dummy"
,
"bogus"
.
toCharArray
());
kdc1
.
addPrincipalRandKey
(
"krbtgt/RABBIT.HOLE"
);
kdc1
.
addPrincipalRandKey
(
"krbtgt/RABBIT.HOLE"
);
kdc1
.
addPrincipal
(
"krbtgt/SNAKE.HOLE"
,
"sharedsec"
.
toCharArray
());
kdc1
.
addPrincipal
(
"krbtgt/SNAKE.HOLE@RABBIT.HOLE"
,
"rabbit->snake"
.
toCharArray
());
KDC
kdc2
=
KDC
.
create
(
"SNAKE.HOLE"
);
KDC
kdc2
=
KDC
.
create
(
"SNAKE.HOLE"
);
kdc2
.
addPrincipalRandKey
(
"krbtgt/SNAKE.HOLE"
);
kdc2
.
addPrincipalRandKey
(
"krbtgt/SNAKE.HOLE"
);
kdc2
.
addPrincipal
(
"krbtgt/RABBIT.HOLE"
,
"sharedsec"
.
toCharArray
());
kdc2
.
addPrincipal
(
"krbtgt/SNAKE.HOLE@RABBIT.HOLE"
,
"rabbit->snake"
.
toCharArray
());
kdc2
.
addPrincipalRandKey
(
"host/www.snake.hole"
);
kdc2
.
addPrincipalRandKey
(
"host/www.snake.hole"
);
KDC
.
saveConfig
(
"krb5-localkdc.conf"
,
kdc1
,
kdc2
,
KDC
.
saveConfig
(
"krb5-localkdc.conf"
,
kdc1
,
kdc2
,
"forwardable=true"
,
"forwardable=true"
,
"[domain_realm]"
,
"[domain_realm]"
,
".snake.hole=SNAKE.HOLE"
);
".snake.hole=SNAKE.HOLE"
);
new
File
(
"krb5-localkdc.conf"
).
deleteOnExit
();
System
.
setProperty
(
"java.security.krb5.conf"
,
"krb5-localkdc.conf"
);
System
.
setProperty
(
"java.security.krb5.conf"
,
"krb5-localkdc.conf"
);
}
}
...
@@ -68,6 +72,7 @@ public class CrossRealm implements CallbackHandler {
...
@@ -68,6 +72,7 @@ public class CrossRealm implements CallbackHandler {
Security
.
setProperty
(
"auth.login.defaultCallbackHandler"
,
"CrossRealm"
);
Security
.
setProperty
(
"auth.login.defaultCallbackHandler"
,
"CrossRealm"
);
System
.
setProperty
(
"java.security.auth.login.config"
,
"jaas-localkdc.conf"
);
System
.
setProperty
(
"java.security.auth.login.config"
,
"jaas-localkdc.conf"
);
System
.
setProperty
(
"javax.security.auth.useSubjectCredsOnly"
,
"false"
);
System
.
setProperty
(
"javax.security.auth.useSubjectCredsOnly"
,
"false"
);
new
File
(
"jaas-localkdc.conf"
).
deleteOnExit
();
FileOutputStream
fos
=
new
FileOutputStream
(
"jaas-localkdc.conf"
);
FileOutputStream
fos
=
new
FileOutputStream
(
"jaas-localkdc.conf"
);
fos
.
write
((
"com.sun.security.jgss.krb5.initiate {\n"
+
fos
.
write
((
"com.sun.security.jgss.krb5.initiate {\n"
+
" com.sun.security.auth.module.Krb5LoginModule\n"
+
" com.sun.security.auth.module.Krb5LoginModule\n"
+
...
...
test/sun/security/krb5/auto/HttpNegotiateServer.java
浏览文件 @
58f816a4
...
@@ -25,7 +25,6 @@
...
@@ -25,7 +25,6 @@
* @test
* @test
* @bug 6578647
* @bug 6578647
* @summary Undefined requesting URL in java.net.Authenticator.getPasswordAuthentication()
* @summary Undefined requesting URL in java.net.Authenticator.getPasswordAuthentication()
* @run main/othervm -Dsun.net.spi.nameservice.provider.1=ns,mock HttpNegotiateServer
*/
*/
import
com.sun.net.httpserver.Headers
;
import
com.sun.net.httpserver.Headers
;
...
@@ -40,12 +39,10 @@ import java.io.IOException;
...
@@ -40,12 +39,10 @@ import java.io.IOException;
import
java.io.InputStreamReader
;
import
java.io.InputStreamReader
;
import
java.net.HttpURLConnection
;
import
java.net.HttpURLConnection
;
import
java.net.InetSocketAddress
;
import
java.net.InetSocketAddress
;
import
java.net.InetAddress
;
import
java.net.PasswordAuthentication
;
import
java.net.PasswordAuthentication
;
import
java.net.Proxy
;
import
java.net.Proxy
;
import
java.net.URL
;
import
java.net.URL
;
import
java.security.PrivilegedExceptionAction
;
import
java.security.PrivilegedExceptionAction
;
import
java.net.UnknownHostException
;
import
java.util.HashMap
;
import
java.util.HashMap
;
import
java.util.Map
;
import
java.util.Map
;
import
javax.security.auth.Subject
;
import
javax.security.auth.Subject
;
...
@@ -53,8 +50,6 @@ import org.ietf.jgss.GSSContext;
...
@@ -53,8 +50,6 @@ import org.ietf.jgss.GSSContext;
import
org.ietf.jgss.GSSCredential
;
import
org.ietf.jgss.GSSCredential
;
import
org.ietf.jgss.GSSManager
;
import
org.ietf.jgss.GSSManager
;
import
sun.security.jgss.GSSUtil
;
import
sun.security.jgss.GSSUtil
;
import
sun.net.spi.nameservice.NameService
;
import
sun.net.spi.nameservice.NameServiceDescriptor
;
import
sun.security.krb5.Config
;
import
sun.security.krb5.Config
;
/**
/**
...
@@ -62,7 +57,7 @@ import sun.security.krb5.Config;
...
@@ -62,7 +57,7 @@ import sun.security.krb5.Config;
* party uses JAAS login to get subjects and executes JGSS calls using
* party uses JAAS login to get subjects and executes JGSS calls using
* Subject.doAs.
* Subject.doAs.
*/
*/
public
class
HttpNegotiateServer
implements
NameServiceDescriptor
{
public
class
HttpNegotiateServer
{
// Two realm, web server in one, proxy server in another
// Two realm, web server in one, proxy server in another
final
static
String
REALM_WEB
=
"WEB.DOMAIN"
;
final
static
String
REALM_WEB
=
"WEB.DOMAIN"
;
...
@@ -142,12 +137,12 @@ public class HttpNegotiateServer implements NameServiceDescriptor {
...
@@ -142,12 +137,12 @@ public class HttpNegotiateServer implements NameServiceDescriptor {
public
static
void
main
(
String
[]
args
)
public
static
void
main
(
String
[]
args
)
throws
Exception
{
throws
Exception
{
KDC
kdcw
=
new
KDC
(
REALM_WEB
,
0
,
true
);
KDC
kdcw
=
KDC
.
create
(
REALM_WEB
);
kdcw
.
addPrincipal
(
WEB_USER
,
WEB_PASS
);
kdcw
.
addPrincipal
(
WEB_USER
,
WEB_PASS
);
kdcw
.
addPrincipalRandKey
(
"krbtgt/"
+
REALM_WEB
);
kdcw
.
addPrincipalRandKey
(
"krbtgt/"
+
REALM_WEB
);
kdcw
.
addPrincipalRandKey
(
"HTTP/"
+
WEB_HOST
);
kdcw
.
addPrincipalRandKey
(
"HTTP/"
+
WEB_HOST
);
KDC
kdcp
=
new
KDC
(
REALM_PROXY
,
0
,
true
);
KDC
kdcp
=
KDC
.
create
(
REALM_PROXY
);
kdcp
.
addPrincipal
(
PROXY_USER
,
PROXY_PASS
);
kdcp
.
addPrincipal
(
PROXY_USER
,
PROXY_PASS
);
kdcp
.
addPrincipalRandKey
(
"krbtgt/"
+
REALM_PROXY
);
kdcp
.
addPrincipalRandKey
(
"krbtgt/"
+
REALM_PROXY
);
kdcp
.
addPrincipalRandKey
(
"HTTP/"
+
PROXY_HOST
);
kdcp
.
addPrincipalRandKey
(
"HTTP/"
+
PROXY_HOST
);
...
@@ -306,36 +301,5 @@ public class HttpNegotiateServer implements NameServiceDescriptor {
...
@@ -306,36 +301,5 @@ public class HttpNegotiateServer implements NameServiceDescriptor {
}
}
}
}
}
}
@Override
public
NameService
createNameService
()
throws
Exception
{
NameService
ns
=
new
NameService
()
{
@Override
public
InetAddress
[]
lookupAllHostAddr
(
String
host
)
throws
UnknownHostException
{
// Everything is localhost
return
new
InetAddress
[]{
InetAddress
.
getByAddress
(
host
,
new
byte
[]{
127
,
0
,
0
,
1
})
};
}
@Override
public
String
getHostByAddr
(
byte
[]
addr
)
throws
UnknownHostException
{
// No reverse lookup
throw
new
UnknownHostException
();
}
};
return
ns
;
}
@Override
public
String
getProviderName
()
{
return
"mock"
;
}
@Override
public
String
getType
()
{
return
"ns"
;
}
}
}
test/sun/security/krb5/auto/KDC.java
浏览文件 @
58f816a4
...
@@ -30,6 +30,8 @@ import java.lang.reflect.Method;
...
@@ -30,6 +30,8 @@ import java.lang.reflect.Method;
import
java.security.SecureRandom
;
import
java.security.SecureRandom
;
import
java.util.*
;
import
java.util.*
;
import
java.util.concurrent.*
;
import
java.util.concurrent.*
;
import
sun.net.spi.nameservice.NameService
;
import
sun.net.spi.nameservice.NameServiceDescriptor
;
import
sun.security.krb5.*
;
import
sun.security.krb5.*
;
import
sun.security.krb5.internal.*
;
import
sun.security.krb5.internal.*
;
import
sun.security.krb5.internal.ccache.CredentialsCache
;
import
sun.security.krb5.internal.ccache.CredentialsCache
;
...
@@ -118,14 +120,16 @@ public class KDC {
...
@@ -118,14 +120,16 @@ public class KDC {
// The random generator to generate random keys (including session keys)
// The random generator to generate random keys (including session keys)
private
static
SecureRandom
secureRandom
=
new
SecureRandom
();
private
static
SecureRandom
secureRandom
=
new
SecureRandom
();
// Principal db
// Principal db
. principal -> pass
private
Map
<
String
,
char
[]>
passwords
=
new
HashMap
<
String
,
char
[]>();
private
Map
<
String
,
char
[]>
passwords
=
new
HashMap
<
String
,
char
[]>();
// Realm name
// Realm name
private
String
realm
;
private
String
realm
;
//
The request/response job queue
//
KDC
private
BlockingQueue
<
Job
>
q
=
new
ArrayBlockingQueue
<
Job
>(
100
)
;
private
String
kdc
;
// Service port number
// Service port number
private
int
port
;
private
int
port
;
// The request/response job queue
private
BlockingQueue
<
Job
>
q
=
new
ArrayBlockingQueue
<
Job
>(
100
);
// Options
// Options
private
Map
<
Option
,
Object
>
options
=
new
HashMap
<
Option
,
Object
>();
private
Map
<
Option
,
Object
>
options
=
new
HashMap
<
Option
,
Object
>();
...
@@ -139,33 +143,21 @@ public class KDC {
...
@@ -139,33 +143,21 @@ public class KDC {
PREAUTH_REQUIRED
,
PREAUTH_REQUIRED
,
};
};
static
{
System
.
setProperty
(
"sun.net.spi.nameservice.provider.1"
,
"ns,mock"
);
}
/**
/**
* A standalone KDC server.
* A standalone KDC server.
* @param args
* @throws java.lang.Exception
*/
*/
public
static
void
main
(
String
[]
args
)
throws
Exception
{
public
static
void
main
(
String
[]
args
)
throws
Exception
{
if
(
args
.
length
>
0
)
{
KDC
kdc
=
create
(
"RABBIT.HOLE"
,
"kdc.rabbit,hole"
,
0
,
false
);
if
(
args
[
0
].
equals
(
"-help"
)
||
args
[
0
].
equals
(
"--help"
))
{
System
.
out
.
println
(
"Usage:"
);
System
.
out
.
println
(
" java "
+
KDC
.
class
+
" "
+
"Start KDC on port 8888"
);
return
;
}
}
String
localhost
=
"localhost"
;
try
{
localhost
=
InetAddress
.
getByName
(
localhost
)
.
getCanonicalHostName
();
}
catch
(
UnknownHostException
uhe
)
{
;
// Ignore, localhost is still "localhost"
}
KDC
kdc
=
create
(
"RABBIT.HOLE"
,
8888
,
false
);
kdc
.
addPrincipal
(
"dummy"
,
"bogus"
.
toCharArray
());
kdc
.
addPrincipal
(
"dummy"
,
"bogus"
.
toCharArray
());
kdc
.
addPrincipal
(
"foo"
,
"bar"
.
toCharArray
());
kdc
.
addPrincipal
(
"foo"
,
"bar"
.
toCharArray
());
kdc
.
addPrincipalRandKey
(
"krbtgt/"
+
kdc
.
realm
);
kdc
.
addPrincipalRandKey
(
"krbtgt/RABBIT.HOLE"
);
kdc
.
addPrincipalRandKey
(
"server/"
+
localhost
);
kdc
.
addPrincipalRandKey
(
"server/host.rabbit.hole"
);
kdc
.
addPrincipalRandKey
(
"backend/"
+
localhost
);
kdc
.
addPrincipalRandKey
(
"backend/host.rabbit.hole"
);
KDC
.
saveConfig
(
"krb5.conf"
,
kdc
,
"forwardable = true"
);
}
}
/**
/**
...
@@ -175,7 +167,7 @@ public class KDC {
...
@@ -175,7 +167,7 @@ public class KDC {
* @throws java.io.IOException for any socket creation error
* @throws java.io.IOException for any socket creation error
*/
*/
public
static
KDC
create
(
String
realm
)
throws
IOException
{
public
static
KDC
create
(
String
realm
)
throws
IOException
{
return
create
(
realm
,
0
,
true
);
return
create
(
realm
,
"kdc."
+
realm
.
toLowerCase
(),
0
,
true
);
}
}
/**
/**
...
@@ -187,8 +179,8 @@ public class KDC {
...
@@ -187,8 +179,8 @@ public class KDC {
* @return the running KDC instance
* @return the running KDC instance
* @throws java.io.IOException for any socket creation error
* @throws java.io.IOException for any socket creation error
*/
*/
public
static
KDC
create
(
String
realm
,
int
port
,
boolean
asDaemon
)
throws
IOException
{
public
static
KDC
create
(
String
realm
,
String
kdc
,
int
port
,
boolean
asDaemon
)
throws
IOException
{
return
new
KDC
(
realm
,
port
,
asDaemon
);
return
new
KDC
(
realm
,
kdc
,
port
,
asDaemon
);
}
}
/**
/**
...
@@ -228,10 +220,7 @@ public class KDC {
...
@@ -228,10 +220,7 @@ public class KDC {
KeyTab
ktab
=
KeyTab
.
create
(
tab
);
KeyTab
ktab
=
KeyTab
.
create
(
tab
);
for
(
KDC
kdc:
kdcs
)
{
for
(
KDC
kdc:
kdcs
)
{
for
(
String
name
:
kdc
.
passwords
.
keySet
())
{
for
(
String
name
:
kdc
.
passwords
.
keySet
())
{
if
(
name
.
equals
(
"krbtgt/"
+
kdc
.
realm
))
{
ktab
.
addEntry
(
new
PrincipalName
(
name
,
continue
;
}
ktab
.
addEntry
(
new
PrincipalName
(
name
+
"@"
+
kdc
.
realm
,
name
.
indexOf
(
'/'
)
<
0
?
name
.
indexOf
(
'/'
)
<
0
?
PrincipalName
.
KRB_NT_UNKNOWN
:
PrincipalName
.
KRB_NT_UNKNOWN
:
PrincipalName
.
KRB_NT_SRV_HST
),
PrincipalName
.
KRB_NT_SRV_HST
),
...
@@ -255,6 +244,9 @@ public class KDC {
...
@@ -255,6 +244,9 @@ public class KDC {
* @param pass the password for the principal
* @param pass the password for the principal
*/
*/
public
void
addPrincipal
(
String
user
,
char
[]
pass
)
{
public
void
addPrincipal
(
String
user
,
char
[]
pass
)
{
if
(
user
.
indexOf
(
'@'
)
<
0
)
{
user
=
user
+
"@"
+
realm
;
}
passwords
.
put
(
user
,
pass
);
passwords
.
put
(
user
,
pass
);
}
}
...
@@ -264,7 +256,7 @@ public class KDC {
...
@@ -264,7 +256,7 @@ public class KDC {
* form of host/f.q.d.n
* form of host/f.q.d.n
*/
*/
public
void
addPrincipalRandKey
(
String
user
)
{
public
void
addPrincipalRandKey
(
String
user
)
{
passwords
.
put
(
user
,
randomPassword
());
addPrincipal
(
user
,
randomPassword
());
}
}
/**
/**
...
@@ -275,6 +267,14 @@ public class KDC {
...
@@ -275,6 +267,14 @@ public class KDC {
return
realm
;
return
realm
;
}
}
/**
* Returns the name of kdc
* @return the name of kdc
*/
public
String
getKDC
()
{
return
kdc
;
}
/**
/**
* Writes a krb5.conf for one or more KDC that includes KDC locations for
* Writes a krb5.conf for one or more KDC that includes KDC locations for
* each realm and the default realm name. You can also add extra strings
* each realm and the default realm name. You can also add extra strings
...
@@ -299,7 +299,7 @@ public class KDC {
...
@@ -299,7 +299,7 @@ public class KDC {
*
*
* [realms]
* [realms]
* REALM.NAME = {
* REALM.NAME = {
* kdc =
local
host:port_number
* kdc = host:port_number
* }
* }
* </pre>
* </pre>
*
*
...
@@ -320,10 +320,10 @@ public class KDC {
...
@@ -320,10 +320,10 @@ public class KDC {
*
*
* [realms]
* [realms]
* KDC1.NAME = {
* KDC1.NAME = {
* kdc =
local
host:port1
* kdc = host:port1
* }
* }
* KDC2.NAME = {
* KDC2.NAME = {
* kdc =
local
host:port2
* kdc = host:port2
* }
* }
* </pre>
* </pre>
* @param file the name of the file to write into
* @param file the name of the file to write into
...
@@ -372,16 +372,17 @@ public class KDC {
...
@@ -372,16 +372,17 @@ public class KDC {
* Private constructor, cannot be called outside.
* Private constructor, cannot be called outside.
* @param realm
* @param realm
*/
*/
private
KDC
(
String
realm
)
{
private
KDC
(
String
realm
,
String
kdc
)
{
this
.
realm
=
realm
;
this
.
realm
=
realm
;
this
.
kdc
=
kdc
;
}
}
/**
/**
* A constructor that starts the KDC service also.
* A constructor that starts the KDC service also.
*/
*/
protected
KDC
(
String
realm
,
int
port
,
boolean
asDaemon
)
protected
KDC
(
String
realm
,
String
kdc
,
int
port
,
boolean
asDaemon
)
throws
IOException
{
throws
IOException
{
this
(
realm
);
this
(
realm
,
kdc
);
startServer
(
port
,
asDaemon
);
startServer
(
port
,
asDaemon
);
}
}
/**
/**
...
@@ -426,7 +427,11 @@ public class KDC {
...
@@ -426,7 +427,11 @@ public class KDC {
* the database.
* the database.
*/
*/
private
char
[]
getPassword
(
PrincipalName
p
)
throws
KrbException
{
private
char
[]
getPassword
(
PrincipalName
p
)
throws
KrbException
{
char
[]
pass
=
passwords
.
get
(
p
.
getNameString
());
String
pn
=
p
.
toString
();
if
(
p
.
getRealmString
()
==
null
)
{
pn
=
pn
+
"@"
+
getRealm
();
}
char
[]
pass
=
passwords
.
get
(
pn
);
if
(
pass
==
null
)
{
if
(
pass
==
null
)
{
throw
new
KrbException
(
Krb5
.
KDC_ERR_C_PRINCIPAL_UNKNOWN
);
throw
new
KrbException
(
Krb5
.
KDC_ERR_C_PRINCIPAL_UNKNOWN
);
}
}
...
@@ -434,29 +439,18 @@ public class KDC {
...
@@ -434,29 +439,18 @@ public class KDC {
}
}
/**
/**
* Returns the salt string for the principal. For normal users, the
* Returns the salt string for the principal.
* concatenation for the realm name and the sections of the principal;
* for krgtgt/A@B and krbtgt/B@A, always return AB (so that inter-realm
* principals have the same key).
* @param p principal
* @param p principal
* @return the salt
* @return the salt
*/
*/
private
String
getSalt
(
PrincipalName
p
)
{
private
String
getSalt
(
PrincipalName
p
)
{
String
[]
ns
=
p
.
getNameStrings
();
String
[]
ns
=
p
.
getNameStrings
();
if
(
ns
[
0
].
equals
(
"krbtgt"
)
&&
ns
.
length
>
1
)
{
String
s
=
p
.
getRealmString
();
// Shared cross-realm keys must be the same
if
(
s
==
null
)
s
=
getRealm
();
if
(
ns
[
1
].
compareTo
(
realm
)
<
0
)
{
for
(
String
n:
p
.
getNameStrings
())
{
return
ns
[
1
]
+
realm
;
s
+=
n
;
}
else
{
return
realm
+
ns
[
1
];
}
}
else
{
String
s
=
getRealm
();
for
(
String
n:
p
.
getNameStrings
())
{
s
+=
n
;
}
return
s
;
}
}
return
s
;
}
}
/**
/**
...
@@ -525,14 +519,8 @@ public class KDC {
...
@@ -525,14 +519,8 @@ public class KDC {
EncryptedData
ed
=
apReq
.
authenticator
;
EncryptedData
ed
=
apReq
.
authenticator
;
tkt
=
apReq
.
ticket
;
tkt
=
apReq
.
ticket
;
etype
=
tkt
.
encPart
.
getEType
();
etype
=
tkt
.
encPart
.
getEType
();
EncryptionKey
kkey
=
null
;
tkt
.
sname
.
setRealm
(
tkt
.
realm
);
if
(!
tkt
.
realm
.
toString
().
equals
(
realm
))
{
EncryptionKey
kkey
=
keyForUser
(
tkt
.
sname
,
etype
);
if
(
tkt
.
sname
.
getNameString
().
equals
(
"krbtgt/"
+
realm
))
{
kkey
=
keyForUser
(
new
PrincipalName
(
"krbtgt/"
+
tkt
.
realm
.
toString
(),
realm
),
etype
);
}
}
else
{
kkey
=
keyForUser
(
tkt
.
sname
,
etype
);
}
byte
[]
bb
=
tkt
.
encPart
.
decrypt
(
kkey
,
KeyUsage
.
KU_TICKET
);
byte
[]
bb
=
tkt
.
encPart
.
decrypt
(
kkey
,
KeyUsage
.
KU_TICKET
);
DerInputStream
derIn
=
new
DerInputStream
(
bb
);
DerInputStream
derIn
=
new
DerInputStream
(
bb
);
DerValue
der
=
derIn
.
getDerValue
();
DerValue
der
=
derIn
.
getDerValue
();
...
@@ -857,10 +845,13 @@ public class KDC {
...
@@ -857,10 +845,13 @@ public class KDC {
/**
/**
* Generates a line for a KDC to put inside [realms] of krb5.conf
* Generates a line for a KDC to put inside [realms] of krb5.conf
* @param kdc the KDC
* @param kdc the KDC
* @return REALM.NAME = { kdc =
local
host:port }
* @return REALM.NAME = { kdc = host:port }
*/
*/
private
static
String
realmLineForKDC
(
KDC
kdc
)
{
private
static
String
realmLineForKDC
(
KDC
kdc
)
{
return
String
.
format
(
" %s = {\n kdc = localhost:%d\n }\n"
,
kdc
.
realm
,
kdc
.
port
);
return
String
.
format
(
" %s = {\n kdc = %s:%d\n }\n"
,
kdc
.
realm
,
kdc
.
kdc
,
kdc
.
port
);
}
}
/**
/**
...
@@ -1000,4 +991,37 @@ public class KDC {
...
@@ -1000,4 +991,37 @@ public class KDC {
}
}
}
}
}
}
public
static
class
KDCNameService
implements
NameServiceDescriptor
{
@Override
public
NameService
createNameService
()
throws
Exception
{
NameService
ns
=
new
NameService
()
{
@Override
public
InetAddress
[]
lookupAllHostAddr
(
String
host
)
throws
UnknownHostException
{
// Everything is localhost
return
new
InetAddress
[]{
InetAddress
.
getByAddress
(
host
,
new
byte
[]{
127
,
0
,
0
,
1
})
};
}
@Override
public
String
getHostByAddr
(
byte
[]
addr
)
throws
UnknownHostException
{
// No reverse lookup, PrincipalName use original string
throw
new
UnknownHostException
();
}
};
return
ns
;
}
@Override
public
String
getProviderName
()
{
return
"mock"
;
}
@Override
public
String
getType
()
{
return
"ns"
;
}
}
}
}
test/sun/security/krb5/auto/META-INF/services/sun.net.spi.nameservice.NameServiceDescriptor
浏览文件 @
58f816a4
HttpNegotiateServer
KDC$KDCNameService
test/sun/security/krb5/auto/OneKDC.java
浏览文件 @
58f816a4
/*
/*
* Copyright 2008 Sun Microsystems, Inc. All Rights Reserved.
* Copyright 2008
-2009
Sun Microsystems, Inc. All Rights Reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
*
* This code is free software; you can redistribute it and/or modify it
* This code is free software; you can redistribute it and/or modify it
...
@@ -46,35 +46,22 @@ import sun.security.krb5.Config;
...
@@ -46,35 +46,22 @@ import sun.security.krb5.Config;
*/
*/
public
class
OneKDC
extends
KDC
{
public
class
OneKDC
extends
KDC
{
// The krb5 codes would try to canonicalize hostnames before creating
// a service principal name, so let's find out the canonicalized form
// of localhost first. The following codes mimic the process inside
// PrincipalName.java.
static
String
localhost
=
"localhost"
;
static
{
try
{
localhost
=
InetAddress
.
getByName
(
localhost
)
.
getCanonicalHostName
();
}
catch
(
UnknownHostException
uhe
)
{
;
// Ignore, localhost is still "localhost"
}
}
public
static
final
String
USER
=
"dummy"
;
public
static
final
String
USER
=
"dummy"
;
public
static
final
char
[]
PASS
=
"bogus"
.
toCharArray
();
public
static
final
char
[]
PASS
=
"bogus"
.
toCharArray
();
public
static
String
SERVER
=
"server/"
+
localhost
;
public
static
String
BACKEND
=
"backend/"
+
localhost
;
public
static
final
String
KRB5_CONF
=
"localkdc-krb5.conf"
;
public
static
final
String
KRB5_CONF
=
"localkdc-krb5.conf"
;
public
static
final
String
KTAB
=
"localkdc.ktab"
;
public
static
final
String
KTAB
=
"localkdc.ktab"
;
public
static
final
String
JAAS_CONF
=
"localkdc-jaas.conf"
;
public
static
final
String
JAAS_CONF
=
"localkdc-jaas.conf"
;
public
static
final
String
REALM
=
"RABBIT.HOLE"
;
public
static
final
String
REALM
=
"RABBIT.HOLE"
;
public
static
String
SERVER
=
"server/host."
+
REALM
.
toLowerCase
();
public
static
String
BACKEND
=
"backend/host."
+
REALM
.
toLowerCase
();
public
static
String
KDCHOST
=
"kdc."
+
REALM
.
toLowerCase
();
/**
/**
* Creates the KDC and starts it.
* Creates the KDC and starts it.
* @param etype Encryption type, null if not specified
* @param etype Encryption type, null if not specified
* @throws java.lang.Exception if there's anything wrong
* @throws java.lang.Exception if there's anything wrong
*/
*/
public
OneKDC
(
String
etype
)
throws
Exception
{
public
OneKDC
(
String
etype
)
throws
Exception
{
super
(
REALM
,
0
,
true
);
super
(
REALM
,
KDCHOST
,
0
,
true
);
addPrincipal
(
USER
,
PASS
);
addPrincipal
(
USER
,
PASS
);
addPrincipalRandKey
(
"krbtgt/"
+
REALM
);
addPrincipalRandKey
(
"krbtgt/"
+
REALM
);
addPrincipalRandKey
(
SERVER
);
addPrincipalRandKey
(
SERVER
);
...
...
test/sun/security/krb5/auto/basic.sh
浏览文件 @
58f816a4
#
#
# Copyright 2008 Sun Microsystems, Inc. All Rights Reserved.
# Copyright 2008
-2009
Sun Microsystems, Inc. All Rights Reserved.
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
#
#
# This code is free software; you can redistribute it and/or modify it
# This code is free software; you can redistribute it and/or modify it
...
@@ -41,25 +41,31 @@ OS=`uname -s`
...
@@ -41,25 +41,31 @@ OS=`uname -s`
case
"
$OS
"
in
case
"
$OS
"
in
Windows_
*
)
Windows_
*
)
FS
=
"
\\
"
FS
=
"
\\
"
SEP
=
";"
;;
;;
*
)
*
)
FS
=
"/"
FS
=
"/"
SEP
=
":"
;;
;;
esac
esac
${
TESTJAVA
}${
FS
}
bin
${
FS
}
javac
-d
.
\
${
TESTJAVA
}${
FS
}
bin
${
FS
}
javac
-
XDignore
.symbol.file
-
d
.
\
${
TESTSRC
}${
FS
}
BasicKrb5Test.java
\
${
TESTSRC
}${
FS
}
BasicKrb5Test.java
\
${
TESTSRC
}${
FS
}
KDC.java
\
${
TESTSRC
}${
FS
}
KDC.java
\
${
TESTSRC
}${
FS
}
OneKDC.java
\
${
TESTSRC
}${
FS
}
OneKDC.java
\
${
TESTSRC
}${
FS
}
Action.java
\
${
TESTSRC
}${
FS
}
Action.java
\
${
TESTSRC
}${
FS
}
Context.java
\
${
TESTSRC
}${
FS
}
Context.java
\
||
exit
10
||
exit
10
${
TESTJAVA
}${
FS
}
bin
${
FS
}
java
-Dtest
.src
=
$TESTSRC
BasicKrb5Test
||
exit
100
${
TESTJAVA
}${
FS
}
bin
${
FS
}
java
-Dtest
.src
=
$TESTSRC
BasicKrb5Test des-cbc-crc
||
exit
1
# Add $TESTSRC to classpath so that customized nameservice can be used
${
TESTJAVA
}${
FS
}
bin
${
FS
}
java
-Dtest
.src
=
$TESTSRC
BasicKrb5Test des-cbc-md5
||
exit
3
J
=
"
${
TESTJAVA
}${
FS
}
bin
${
FS
}
java -cp
$TESTSRC
${
SEP
}
. BasicKrb5Test"
${
TESTJAVA
}${
FS
}
bin
${
FS
}
java
-Dtest
.src
=
$TESTSRC
BasicKrb5Test des3-cbc-sha1
||
exit
16
${
TESTJAVA
}${
FS
}
bin
${
FS
}
java
-Dtest
.src
=
$TESTSRC
BasicKrb5Test aes128-cts
||
exit
17
$J
||
exit
100
${
TESTJAVA
}${
FS
}
bin
${
FS
}
java
-Dtest
.src
=
$TESTSRC
BasicKrb5Test aes256-cts
||
exit
18
$J
des-cbc-crc
||
exit
1
${
TESTJAVA
}${
FS
}
bin
${
FS
}
java
-Dtest
.src
=
$TESTSRC
BasicKrb5Test rc4-hmac
||
exit
23
$J
des-cbc-md5
||
exit
3
$J
des3-cbc-sha1
||
exit
16
$J
aes128-cts
||
exit
17
$J
aes256-cts
||
exit
18
$J
rc4-hmac
||
exit
23
exit
0
exit
0
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录