【发布时间】:2018-05-30 11:03:17
【问题描述】:
我试图在 JSP 页面中显示存储在我的 oracle 数据库中的图像。图像存储为BLOB 数据。
这是我的代码:
<%@page import="utils.MyUtils"%>
<%@ page import="java.sql.*" %>
<%@ page import="java.io.*" %>
<%
Connection con = MyUtils.getStoredConnection(request);
String strSQL = "SELECT IMAGE "
+ "FROM CUSTOMER "
+ "WHERE CUST_ID= 113";
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery(strSQL);
rs.next();
response.setHeader("expires", "0");
response.setContentType("jpeg");
out.clear();
OutputStream os = response.getOutputStream();
os.write(rs.getBytes("IMAGE"));
out.flush();
%>
这里是MyUtils类:
package utils;
import beans.CreateAcc;
import java.sql.Connection;
import javax.servlet.ServletRequest;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import beans.UserAccount;
public class MyUtils {
public static final String ATT_NAME_CONNECTION = "ATTRIBUTE_FOR_CONNECTION";
private static final String ATT_NAME_USER_NAME = "ATTRIBUTE_FOR_STORE_USER_NAME_IN_COOKIE";
// Store Connection in request attribute.
// (Information stored only exist during requests)
public static void storeConnection(ServletRequest request, Connection conn) {
request.setAttribute(ATT_NAME_CONNECTION, conn);
}
// Get the Connection object has been stored in attribute of the request.
public static Connection getStoredConnection(ServletRequest request) {
Connection conn = (Connection) request.getAttribute(ATT_NAME_CONNECTION);
return conn;
}
// Store user info in Session.
public static void storeLoginedUser(HttpSession session, UserAccount loginedUser) {
// On the JSP can access via ${loginedUser}
session.setAttribute("loginedUser", loginedUser);
}
// Get the user information stored in the session.
public static UserAccount getLoginedUser(HttpSession session) {
UserAccount loginedUser = (UserAccount) session.getAttribute("loginedUser");
return loginedUser;
}
}
但是当我运行我的代码时,它只显示存储在我的 PC 中的图像的 URL 路径,而不是图像。
我该怎么办?
【问题讨论】:
标签: java database jsp servlets blob