Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
56dc7b28
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看板
提交
56dc7b28
编写于
10月 03, 2013
作者:
B
bae
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8022632: Reading a PNG file fails because of WBMPImageReaderSpi.canDecodeInput()
Reviewed-by: prr, jgodinez
上级
53b4c8ee
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
131 addition
and
34 deletion
+131
-34
src/share/classes/com/sun/imageio/plugins/wbmp/WBMPImageReaderSpi.java
...sses/com/sun/imageio/plugins/wbmp/WBMPImageReaderSpi.java
+34
-34
test/javax/imageio/plugins/wbmp/StreamResetTest.java
test/javax/imageio/plugins/wbmp/StreamResetTest.java
+97
-0
未找到文件。
src/share/classes/com/sun/imageio/plugins/wbmp/WBMPImageReaderSpi.java
浏览文件 @
56dc7b28
...
...
@@ -85,42 +85,42 @@ public class WBMPImageReaderSpi extends ImageReaderSpi {
ImageInputStream
stream
=
(
ImageInputStream
)
source
;
stream
.
mark
();
int
type
=
stream
.
readByte
();
// TypeField
int
fixHeaderField
=
stream
.
readByte
();
// check WBMP "header"
if
(
type
!=
0
||
fixHeaderField
!=
0
)
{
// while WBMP reader does not support ext WBMP headers
try
{
int
type
=
stream
.
readByte
();
// TypeField
int
fixHeaderField
=
stream
.
readByte
();
// check WBMP "header"
if
(
type
!=
0
||
fixHeaderField
!=
0
)
{
// while WBMP reader does not support ext WBMP headers
return
false
;
}
int
width
=
ReaderUtil
.
readMultiByteInteger
(
stream
);
int
height
=
ReaderUtil
.
readMultiByteInteger
(
stream
);
// check image dimension
if
(
width
<=
0
||
height
<=
0
)
{
return
false
;
}
long
dataLength
=
stream
.
length
();
if
(
dataLength
==
-
1
)
{
// We can't verify that amount of data in the stream
// corresponds to image dimension because we do not know
// the length of the data stream.
// Assuming that wbmp image are used for mobile devices,
// let's introduce an upper limit for image dimension.
// In case if exact amount of raster data is unknown,
// let's reject images with dimension above the limit.
return
(
width
<
MAX_WBMP_WIDTH
)
&&
(
height
<
MAX_WBMP_HEIGHT
);
}
dataLength
-=
stream
.
getStreamPosition
();
long
scanSize
=
(
width
/
8
)
+
((
width
%
8
)
==
0
?
0
:
1
);
return
(
dataLength
==
scanSize
*
height
);
}
finally
{
stream
.
reset
();
return
false
;
}
int
width
=
ReaderUtil
.
readMultiByteInteger
(
stream
);
int
height
=
ReaderUtil
.
readMultiByteInteger
(
stream
);
// check image dimension
if
(
width
<=
0
||
height
<=
0
)
{
stream
.
reset
();
return
false
;
}
long
dataLength
=
stream
.
length
();
if
(
dataLength
==
-
1
)
{
// We can't verify that amount of data in the stream
// corresponds to image dimension because we do not know
// the length of the data stream.
// Assuming that wbmp image are used for mobile devices,
// let's introduce an upper limit for image dimension.
// In case if exact amount of raster data is unknown,
// let's reject images with dimension above the limit.
stream
.
reset
();
return
(
width
<
MAX_WBMP_WIDTH
)
&&
(
height
<
MAX_WBMP_HEIGHT
);
}
dataLength
-=
stream
.
getStreamPosition
();
stream
.
reset
();
long
scanSize
=
(
width
/
8
)
+
((
width
%
8
)
==
0
?
0
:
1
);
return
(
dataLength
==
scanSize
*
height
);
}
public
ImageReader
createReaderInstance
(
Object
extension
)
...
...
test/javax/imageio/plugins/wbmp/StreamResetTest.java
0 → 100644
浏览文件 @
56dc7b28
/*
* Copyright (c) 2013, 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 8022632
* @summary Test verifies that SPI of WBMP image reader
* restores the stream position if an IOException
* occurs during processing of image header.
* @run main StreamResetTest
*/
import
java.io.IOException
;
import
javax.imageio.ImageIO
;
import
javax.imageio.ImageReader
;
import
javax.imageio.spi.ImageReaderSpi
;
import
javax.imageio.stream.ImageInputStreamImpl
;
public
class
StreamResetTest
{
public
static
void
main
(
String
[]
args
)
{
IOException
expectedException
=
null
;
TestStream
iis
=
new
TestStream
();
ImageReader
wbmp
=
ImageIO
.
getImageReadersByFormatName
(
"WBMP"
).
next
();
if
(
wbmp
==
null
)
{
System
.
out
.
println
(
"No WBMP reader: skip the test"
);
return
;
}
ImageReaderSpi
spi
=
wbmp
.
getOriginatingProvider
();
iis
.
checkPosition
();
try
{
spi
.
canDecodeInput
(
iis
);
}
catch
(
IOException
e
)
{
expectedException
=
e
;
}
if
(
expectedException
==
null
)
{
throw
new
RuntimeException
(
"Test FAILED: stream was not used"
);
}
iis
.
checkPosition
();
System
.
out
.
println
(
"Test PASSED"
);
}
private
static
class
TestStream
extends
ImageInputStreamImpl
{
private
final
int
errorPos
=
1
;
@Override
public
int
read
()
throws
IOException
{
if
(
streamPos
==
errorPos
)
{
throw
new
IOException
(
"Test exception"
);
}
streamPos
++;
return
0x03
;
}
@Override
public
int
read
(
byte
[]
b
,
int
off
,
int
len
)
throws
IOException
{
streamPos
+=
len
;
return
len
;
}
public
void
checkPosition
()
{
if
(
streamPos
!=
0
)
{
throw
new
RuntimeException
(
"Test FAILED"
);
}
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录