我想在从数据库中检索到的 JSP 中显示图像。现在,在互联网上进行了大量研究后,我想出了这段代码。
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>View Item</title>
</head>
<body>
<center>
<h1>View Item</h1>
<%
Connection con = DefaultConnection.establishSqlConnection();
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM Items WHERE ItemCode='"+request.getParameter("itemCode")+"'");
Blob image = rs.getBlob("ItemImage");
InputStream imageInputStream = image.getBinaryStream();
int bufferSize = 1024;
byte[] buffer = new byte[bufferSize];
int len=0;
%>
<form action="addItem.jsp" method="post">
<table>
<tr><%=rs.getInt("ItemCode")%></tr>
<tr><%=rs.getString("ItemName")%></tr>
<tr><%while ((len=imageInputStream.read(buffer)) != -1) {
out.write(buffer, 0, len);
}%></tr>
</table>
</form>
</center>
</body>
</html>
现在我的问题是,无论我在哪里看到,out.write() 方法都与 (byte[], int, int) 参数一起使用。但是我的 NetBeans 拒绝接受这些论点。API 说 out.write() 只支持 (char[], int, int) 参数。我不知道这种方式是否正确。
请告诉我是否做错了什么,或者是否有其他绝对的方法可以做到这一点。