Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
5e31c17d
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看板
提交
5e31c17d
编写于
1月 10, 2011
作者:
C
chegar
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
6997851: Create NTLM AuthenticationCallBack class to avoid NTLM info leakage on client side
Reviewed-by: michaelm
上级
99d10947
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
108 addition
and
3 deletion
+108
-3
make/sun/net/FILES_java.gmk
make/sun/net/FILES_java.gmk
+1
-0
src/share/classes/sun/net/www/protocol/http/HttpURLConnection.java
.../classes/sun/net/www/protocol/http/HttpURLConnection.java
+7
-0
src/share/classes/sun/net/www/protocol/http/NTLMAuthenticationProxy.java
...es/sun/net/www/protocol/http/NTLMAuthenticationProxy.java
+19
-3
src/share/classes/sun/net/www/protocol/http/ntlm/NTLMAuthenticationCallback.java
...et/www/protocol/http/ntlm/NTLMAuthenticationCallback.java
+59
-0
src/solaris/classes/sun/net/www/protocol/http/ntlm/NTLMAuthentication.java
...es/sun/net/www/protocol/http/ntlm/NTLMAuthentication.java
+11
-0
src/windows/classes/sun/net/www/protocol/http/ntlm/NTLMAuthentication.java
...es/sun/net/www/protocol/http/ntlm/NTLMAuthentication.java
+11
-0
未找到文件。
make/sun/net/FILES_java.gmk
浏览文件 @
5e31c17d
...
@@ -100,6 +100,7 @@ FILES_java = \
...
@@ -100,6 +100,7 @@ FILES_java = \
sun/net/www/protocol/http/NegotiateAuthentication.java \
sun/net/www/protocol/http/NegotiateAuthentication.java \
sun/net/www/protocol/http/Negotiator.java \
sun/net/www/protocol/http/Negotiator.java \
sun/net/www/protocol/http/ntlm/NTLMAuthentication.java \
sun/net/www/protocol/http/ntlm/NTLMAuthentication.java \
sun/net/www/protocol/http/ntlm/NTLMAuthenticationCallback.java \
sun/net/www/protocol/http/spnego/NegotiatorImpl.java \
sun/net/www/protocol/http/spnego/NegotiatorImpl.java \
sun/net/www/protocol/http/spnego/NegotiateCallbackHandler.java \
sun/net/www/protocol/http/spnego/NegotiateCallbackHandler.java \
sun/net/www/protocol/http/logging/HttpLogFormatter.java \
sun/net/www/protocol/http/logging/HttpLogFormatter.java \
...
...
src/share/classes/sun/net/www/protocol/http/HttpURLConnection.java
浏览文件 @
5e31c17d
...
@@ -2173,6 +2173,13 @@ public class HttpURLConnection extends java.net.HttpURLConnection {
...
@@ -2173,6 +2173,13 @@ public class HttpURLConnection extends java.net.HttpURLConnection {
if
(
tryTransparentNTLMServer
)
{
if
(
tryTransparentNTLMServer
)
{
tryTransparentNTLMServer
=
tryTransparentNTLMServer
=
NTLMAuthenticationProxy
.
proxy
.
supportsTransparentAuth
;
NTLMAuthenticationProxy
.
proxy
.
supportsTransparentAuth
;
/* If the platform supports transparent authentication
* then check if we are in a secure environment
* whether, or not, we should try transparent authentication.*/
if
(
tryTransparentNTLMServer
)
{
tryTransparentNTLMServer
=
NTLMAuthenticationProxy
.
proxy
.
isTrustedSite
(
url
);
}
}
}
a
=
null
;
a
=
null
;
if
(
tryTransparentNTLMServer
)
{
if
(
tryTransparentNTLMServer
)
{
...
...
src/share/classes/sun/net/www/protocol/http/NTLMAuthenticationProxy.java
浏览文件 @
5e31c17d
...
@@ -36,12 +36,14 @@ import sun.util.logging.PlatformLogger;
...
@@ -36,12 +36,14 @@ import sun.util.logging.PlatformLogger;
*/
*/
class
NTLMAuthenticationProxy
{
class
NTLMAuthenticationProxy
{
private
static
Method
supportsTA
;
private
static
Method
supportsTA
;
private
static
Method
isTrustedSite
;
private
static
final
String
clazzStr
=
"sun.net.www.protocol.http.ntlm.NTLMAuthentication"
;
private
static
final
String
clazzStr
=
"sun.net.www.protocol.http.ntlm.NTLMAuthentication"
;
private
static
final
String
supportsTAStr
=
"supportsTransparentAuth"
;
private
static
final
String
supportsTAStr
=
"supportsTransparentAuth"
;
private
static
final
String
isTrustedSiteStr
=
"isTrustedSite"
;
static
final
NTLMAuthenticationProxy
proxy
=
tryLoadNTLMAuthentication
();
static
final
NTLMAuthenticationProxy
proxy
=
tryLoadNTLMAuthentication
();
static
final
boolean
supported
=
proxy
!=
null
?
true
:
false
;
static
final
boolean
supported
=
proxy
!=
null
?
true
:
false
;
static
final
boolean
supportsTransparentAuth
=
supported
?
supportsTransparentAuth
(
supportsTA
)
:
false
;
static
final
boolean
supportsTransparentAuth
=
supported
?
supportsTransparentAuth
()
:
false
;
private
final
Constructor
<?
extends
AuthenticationInfo
>
threeArgCtr
;
private
final
Constructor
<?
extends
AuthenticationInfo
>
threeArgCtr
;
private
final
Constructor
<?
extends
AuthenticationInfo
>
fiveArgCtr
;
private
final
Constructor
<?
extends
AuthenticationInfo
>
fiveArgCtr
;
...
@@ -82,9 +84,22 @@ class NTLMAuthenticationProxy {
...
@@ -82,9 +84,22 @@ class NTLMAuthenticationProxy {
* authentication (try with the current users credentials before
* authentication (try with the current users credentials before
* prompting for username and password, etc).
* prompting for username and password, etc).
*/
*/
private
static
boolean
supportsTransparentAuth
(
Method
method
)
{
private
static
boolean
supportsTransparentAuth
()
{
try
{
try
{
return
(
Boolean
)
method
.
invoke
(
null
);
return
(
Boolean
)
supportsTA
.
invoke
(
null
);
}
catch
(
ReflectiveOperationException
roe
)
{
finest
(
roe
);
}
return
false
;
}
/* Transparent authentication should only be tried with a trusted
* site ( when running in a secure environment ).
*/
public
static
boolean
isTrustedSite
(
URL
url
)
{
try
{
return
(
Boolean
)
isTrustedSite
.
invoke
(
null
,
url
);
}
catch
(
ReflectiveOperationException
roe
)
{
}
catch
(
ReflectiveOperationException
roe
)
{
finest
(
roe
);
finest
(
roe
);
}
}
...
@@ -112,6 +127,7 @@ class NTLMAuthenticationProxy {
...
@@ -112,6 +127,7 @@ class NTLMAuthenticationProxy {
int
.
class
,
int
.
class
,
PasswordAuthentication
.
class
);
PasswordAuthentication
.
class
);
supportsTA
=
cl
.
getDeclaredMethod
(
supportsTAStr
);
supportsTA
=
cl
.
getDeclaredMethod
(
supportsTAStr
);
isTrustedSite
=
cl
.
getDeclaredMethod
(
isTrustedSiteStr
,
java
.
net
.
URL
.
class
);
return
new
NTLMAuthenticationProxy
(
threeArg
,
return
new
NTLMAuthenticationProxy
(
threeArg
,
fiveArg
);
fiveArg
);
}
}
...
...
src/share/classes/sun/net/www/protocol/http/ntlm/NTLMAuthenticationCallback.java
0 → 100644
浏览文件 @
5e31c17d
/*
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
package
sun.net.www.protocol.http.ntlm
;
import
java.net.URL
;
/**
* This class is used to call back to deployment to determine if a given
* URL is trusted. Transparent authentication (try with logged in users
* credentials without prompting) should only be tried with trusted sites.
*/
public
abstract
class
NTLMAuthenticationCallback
{
private
static
volatile
NTLMAuthenticationCallback
callback
=
new
DefaultNTLMAuthenticationCallback
();
public
static
void
setNTLMAuthenticationCallback
(
NTLMAuthenticationCallback
callback
)
{
NTLMAuthenticationCallback
.
callback
=
callback
;
}
public
static
NTLMAuthenticationCallback
getNTLMAuthenticationCallback
()
{
return
callback
;
}
/**
* Returns true if the given site is trusted, i.e. we can try
* transparent Authentication.
*/
public
abstract
boolean
isTrustedSite
(
URL
url
);
static
class
DefaultNTLMAuthenticationCallback
extends
NTLMAuthenticationCallback
{
@Override
public
boolean
isTrustedSite
(
URL
url
)
{
return
true
;
}
}
}
src/solaris/classes/sun/net/www/protocol/http/ntlm/NTLMAuthentication.java
浏览文件 @
5e31c17d
...
@@ -68,6 +68,9 @@ import sun.net.www.protocol.http.HttpURLConnection;
...
@@ -68,6 +68,9 @@ import sun.net.www.protocol.http.HttpURLConnection;
public
class
NTLMAuthentication
extends
AuthenticationInfo
{
public
class
NTLMAuthentication
extends
AuthenticationInfo
{
private
static
final
long
serialVersionUID
=
170L
;
private
static
final
long
serialVersionUID
=
170L
;
private
static
final
NTLMAuthenticationCallback
NTLMAuthCallback
=
NTLMAuthenticationCallback
.
getNTLMAuthenticationCallback
();
private
String
hostname
;
private
String
hostname
;
private
static
String
defaultDomain
;
/* Domain to use if not specified by user */
private
static
String
defaultDomain
;
/* Domain to use if not specified by user */
...
@@ -81,6 +84,14 @@ public class NTLMAuthentication extends AuthenticationInfo {
...
@@ -81,6 +84,14 @@ public class NTLMAuthentication extends AuthenticationInfo {
return
false
;
return
false
;
}
}
/**
* Returns true if the given site is trusted, i.e. we can try
* transparent Authentication.
*/
public
static
boolean
isTrustedSite
(
URL
url
)
{
return
NTLMAuthCallback
.
isTrustedSite
(
url
);
}
private
void
init0
()
{
private
void
init0
()
{
hostname
=
java
.
security
.
AccessController
.
doPrivileged
(
hostname
=
java
.
security
.
AccessController
.
doPrivileged
(
...
...
src/windows/classes/sun/net/www/protocol/http/ntlm/NTLMAuthentication.java
浏览文件 @
5e31c17d
...
@@ -45,6 +45,9 @@ public class NTLMAuthentication extends AuthenticationInfo {
...
@@ -45,6 +45,9 @@ public class NTLMAuthentication extends AuthenticationInfo {
private
static
final
long
serialVersionUID
=
100L
;
private
static
final
long
serialVersionUID
=
100L
;
private
static
final
NTLMAuthenticationCallback
NTLMAuthCallback
=
NTLMAuthenticationCallback
.
getNTLMAuthenticationCallback
();
private
String
hostname
;
private
String
hostname
;
private
static
String
defaultDomain
;
/* Domain to use if not specified by user */
private
static
String
defaultDomain
;
/* Domain to use if not specified by user */
...
@@ -142,6 +145,14 @@ public class NTLMAuthentication extends AuthenticationInfo {
...
@@ -142,6 +145,14 @@ public class NTLMAuthentication extends AuthenticationInfo {
return
true
;
return
true
;
}
}
/**
* Returns true if the given site is trusted, i.e. we can try
* transparent Authentication.
*/
public
static
boolean
isTrustedSite
(
URL
url
)
{
return
NTLMAuthCallback
.
isTrustedSite
(
url
);
}
/**
/**
* Not supported. Must use the setHeaders() method
* Not supported. Must use the setHeaders() method
*/
*/
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录