Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
cc570da2
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看板
提交
cc570da2
编写于
1月 11, 2012
作者:
C
chegar
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
7128648: HttpURLConnection.getHeaderFields should return an unmodifiable Map
Reviewed-by: michaelm
上级
ad597661
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
152 addition
and
5 deletion
+152
-5
src/share/classes/sun/net/www/protocol/http/HttpURLConnection.java
.../classes/sun/net/www/protocol/http/HttpURLConnection.java
+3
-5
test/java/net/HttpURLConnection/UnmodifiableMaps.java
test/java/net/HttpURLConnection/UnmodifiableMaps.java
+149
-0
未找到文件。
src/share/classes/sun/net/www/protocol/http/HttpURLConnection.java
浏览文件 @
cc570da2
...
...
@@ -2633,8 +2633,7 @@ public class HttpURLConnection extends java.net.HttpURLConnection {
if
(
filteredHeaders
!=
null
)
return
filteredHeaders
;
filteredHeaders
=
new
HashMap
<>();
Map
<
String
,
List
<
String
>>
headers
;
Map
<
String
,
List
<
String
>>
headers
,
tmpMap
=
new
HashMap
<>();
if
(
cachedHeaders
!=
null
)
headers
=
cachedHeaders
.
getHeaders
();
...
...
@@ -2650,11 +2649,10 @@ public class HttpURLConnection extends java.net.HttpURLConnection {
filteredVals
.
add
(
fVal
);
}
if
(!
filteredVals
.
isEmpty
())
filteredHeaders
.
put
(
key
,
Collections
.
unmodifiableList
(
filteredVals
));
tmpMap
.
put
(
key
,
Collections
.
unmodifiableList
(
filteredVals
));
}
return
filteredHeaders
;
return
filteredHeaders
=
Collections
.
unmodifiableMap
(
tmpMap
)
;
}
/**
...
...
test/java/net/HttpURLConnection/UnmodifiableMaps.java
0 → 100644
浏览文件 @
cc570da2
/*
* Copyright (c) 2012, 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.
*
* 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.
*/
/**
* @test
* @bug 7128648
* @summary HttpURLConnection.getHeaderFields should return an unmodifiable Map
*/
import
java.io.IOException
;
import
java.net.InetAddress
;
import
java.net.InetSocketAddress
;
import
java.net.URI
;
import
java.net.HttpURLConnection
;
import
java.util.Collection
;
import
java.util.ArrayList
;
import
java.util.List
;
import
java.util.Map
;
import
com.sun.net.httpserver.HttpExchange
;
import
com.sun.net.httpserver.HttpHandler
;
import
com.sun.net.httpserver.HttpServer
;
import
com.sun.net.httpserver.Headers
;
public
class
UnmodifiableMaps
{
void
test
(
String
[]
args
)
throws
Exception
{
HttpServer
server
=
startHttpServer
();
try
{
InetSocketAddress
address
=
server
.
getAddress
();
URI
uri
=
new
URI
(
"http://"
+
InetAddress
.
getLocalHost
().
getHostAddress
()
+
":"
+
address
.
getPort
()
+
"/foo"
);
doClient
(
uri
);
}
finally
{
server
.
stop
(
0
);
}
}
void
doClient
(
URI
uri
)
throws
Exception
{
HttpURLConnection
uc
=
(
HttpURLConnection
)
uri
.
toURL
().
openConnection
();
// Test1: getRequestProperties is unmodifiable
System
.
out
.
println
(
"Check getRequestProperties"
);
checkUnmodifiable
(
uc
.
getRequestProperties
());
uc
.
addRequestProperty
(
"X"
,
"V"
);
uc
.
addRequestProperty
(
"X1"
,
"V1"
);
checkUnmodifiable
(
uc
.
getRequestProperties
());
int
resp
=
uc
.
getResponseCode
();
check
(
resp
==
200
,
"Unexpected response code. Expected 200, got "
+
resp
);
// Test2: getHeaderFields is unmodifiable
System
.
out
.
println
(
"Check getHeaderFields"
);
checkUnmodifiable
(
uc
.
getHeaderFields
());
// If the implementation does caching, check again.
checkUnmodifiable
(
uc
.
getHeaderFields
());
}
// HTTP Server
HttpServer
startHttpServer
()
throws
IOException
{
HttpServer
httpServer
=
HttpServer
.
create
(
new
InetSocketAddress
(
0
),
0
);
httpServer
.
createContext
(
"/foo"
,
new
SimpleHandler
());
httpServer
.
start
();
return
httpServer
;
}
class
SimpleHandler
implements
HttpHandler
{
@Override
public
void
handle
(
HttpExchange
t
)
throws
IOException
{
Headers
respHeaders
=
t
.
getResponseHeaders
();
// ensure some response headers, over the usual ones
respHeaders
.
add
(
"RespHdr1"
,
"Value1"
);
respHeaders
.
add
(
"RespHdr2"
,
"Value2"
);
respHeaders
.
add
(
"RespHdr3"
,
"Value3"
);
t
.
sendResponseHeaders
(
200
,
-
1
);
t
.
close
();
}
}
void
checkUnmodifiable
(
Map
<
String
,
List
<
String
>>
map
)
{
checkUnmodifiableMap
(
map
);
// Now check the individual values
Collection
<
List
<
String
>>
values
=
map
.
values
();
for
(
List
<
String
>
value
:
values
)
{
checkUnmodifiableList
(
value
);
}
}
void
checkUnmodifiableMap
(
final
Map
<
String
,
List
<
String
>>
map
)
{
expectThrow
(
new
Runnable
()
{
public
void
run
()
{
map
.
clear
();
}});
expectThrow
(
new
Runnable
()
{
public
void
run
()
{
map
.
put
(
"X"
,
new
ArrayList
<
String
>());
}});
expectThrow
(
new
Runnable
()
{
public
void
run
()
{
map
.
remove
(
"X"
);
}});
}
void
checkUnmodifiableList
(
final
List
<
String
>
list
)
{
expectThrow
(
new
Runnable
()
{
public
void
run
()
{
list
.
clear
();
}});
expectThrow
(
new
Runnable
()
{
public
void
run
()
{
list
.
add
(
"X"
);
}});
expectThrow
(
new
Runnable
()
{
public
void
run
()
{
list
.
remove
(
"X"
);
}});
}
void
expectThrow
(
Runnable
r
)
{
try
{
r
.
run
();
fail
(
"Excepted UOE to be thrown."
);
Thread
.
dumpStack
();
}
catch
(
UnsupportedOperationException
e
)
{
pass
();
}
}
volatile
int
passed
=
0
,
failed
=
0
;
void
pass
()
{
passed
++;}
void
fail
()
{
failed
++;}
void
fail
(
String
msg
)
{
System
.
err
.
println
(
msg
);
fail
();}
void
unexpected
(
Throwable
t
)
{
failed
++;
t
.
printStackTrace
();}
void
check
(
boolean
cond
,
String
failMessage
)
{
if
(
cond
)
pass
();
else
fail
(
failMessage
);}
public
static
void
main
(
String
[]
args
)
throws
Throwable
{
Class
<?>
k
=
new
Object
(){}.
getClass
().
getEnclosingClass
();
try
{
k
.
getMethod
(
"instanceMain"
,
String
[].
class
)
.
invoke
(
k
.
newInstance
(),
(
Object
)
args
);}
catch
(
Throwable
e
)
{
throw
e
.
getCause
();}}
public
void
instanceMain
(
String
[]
args
)
throws
Throwable
{
try
{
test
(
args
);}
catch
(
Throwable
t
)
{
unexpected
(
t
);}
System
.
out
.
printf
(
"%nPassed = %d, failed = %d%n%n"
,
passed
,
failed
);
if
(
failed
>
0
)
throw
new
AssertionError
(
"Some tests failed"
);}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录