Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/320.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/database/9.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 在jsp页面中显示图像而不是图像url_Java_Database_Jsp_Servlets_Blob - Fatal编程技术网

Java 在jsp页面中显示图像而不是图像url

Java 在jsp页面中显示图像而不是图像url,java,database,jsp,servlets,blob,Java,Database,Jsp,Servlets,Blob,我试图在JSP页面中显示存储在oracle数据库中的图像。图像存储为BLOB数据 这是我的密码: <%@page import="utils.MyUtils"%> <%@ page import="java.sql.*" %> <%@ page import="java.io.*" %> <% Connection con = MyUtils.getStoredConnection(request); String strSQL = "SE

我试图在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(); 

%> 
但当我运行代码时,它只显示存储在我电脑中的图像的URL路径,而不是图像


我应该怎么做?

从blob对象获取字节流。将字节流转换为base 64编码字符串。然后在img标记中使用base64编码字符串。您可以使用base64编码字符串html图像标记。浏览器将渲染图像

你会得到很多关于堆栈溢出的帖子,如下几点

  • 如何按流/数组将blob数据转换为
  • 如何将字节流转换为Base 64编码字符串
  • 如何在HTML图像标记中使用Base64编码字符串

不要这样做。这种方法效率非常低,因为这不会给webbrowser任何缓存图像的机会。这最多只能用于上传图像的“预览”功能,当然不能用于持久图像。@BalusC我知道Base64编码的图像不会被缓存。但由于问题是为了检索单个图像,(基于他提供的查询),我提供了这个答案。如果问题是幻灯片或类似的东西,我不会发布这个答案。
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;
    }
}