Background Image

FORUM

?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
Window7 32bit, Linux 64bit 등
CUBRID Ver.
[cubrid_rel] 수행 결과
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
java, php, odbc 등 입력

* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------


BLOB 타입 이미지를 JSP로 웹에 뿌려주려면 어떻게 해야하나요?

SQL은 다음과 같이 했습니다.


SELECT 

BLOB_TO_BIT(mem_img)

FROM 

member

  • ?
    김승훈 2014.07.08 20:37

    안녕하세요. 큐브리드를 사랑해주셔서 감사합니다.


    제가 해결한 방법을 말씀드리자면요.


    서블릿 클래스 하나를 생성하여서 blob 컬럼을 조회 해서

    ServletOutputStream 객체에 write하는 방식으로 처리했습니다.


    예제 소스코드는 아래와 같습니다.


     protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

    response.setContentType("image/jpeg");

    int num = Integer.parseInt(request.getParameter("num")); // blob 테이블의 index 번호입니다.

    String className = "cubrid.jdbc.driver.CUBRIDDriver";

    String url = "jdbc:cubrid:<ip>:<port>:<db_name>:<id>:<pwd>:";

    String sql = "select blob from blob_tbl where id=?"; // blob을 조회하는 쿼리입니다.

    Connection conn = null;

    PreparedStatement pstmt = null;

    ResultSet rs = null;

    Blob blob = null; // blob 데이터를 저장할 객체 생성

    ServletOutputStream sOut = response.getOutputStream(); // 이미지를 출력할 outputStream 객체 생성

    try {

    Class.forName(className);

    conn = DriverManager.getConnection(url);

    System.out.println("conn : " + conn);

    pstmt = conn.prepareStatement(sql);

    pstmt.setInt(1, num);

    rs = pstmt.executeQuery();

    if(rs.next()) {

    blob = rs.getBlob(1); // blob 객체에 blob 데이터 저장

    }

    sOut.write(blob.getBytes(1, (int)blob.length())); // outputStream 객체에 blob 객체를 byte[] 로 만들어서 쓰기

    } catch (Exception e) {

    e.printStackTrace();

    } finally {

    try {

    if(sOut != null) sOut.close();

    if(rs != null) rs.close();

    if(pstmt != null) pstmt.close();

    if(conn != null) conn.close();

    } catch (SQLException e) {

    e.printStackTrace();

    }

    }

    }


    위와 같은 소스코드로 서블릿 클래스를작성하여 web.xml 파일에 등록 후

    jsp 페이지에서 호출하면 정상적으로 이미지가 출력됩니다.


    감사합니다.


List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 51
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
995 임시볼륨 늘어나는 문제 1 angdoo 2023.11.21 96
994 임시볼륨 문제 문의드립니다. 1 secret 라면 2016.03.31 8
993 임시볼륨이 꽉차지는 현상 문의 1 file 라면 2016.01.05 6854
992 임시테이블 관련 1 cubrid 초보 2013.02.15 9322
991 임시테이블 지원관련 문의입니다. 1 므네모시네 2013.08.12 9359
990 임시테이블에 대한 지원 계획은 있는지 궁금합니다 2 김종언 2010.07.28 10994
989 임의용량에 대해 문의 드립니다. 1 김은지 2023.01.18 57
988 자동백업 문의 1 file 완초 2015.03.27 4241
987 자동백업 문제 1 이재구 2015.06.17 4190
986 자동백업 시간 설정한 시간과 2시간 차이가 납니다. 1 coolkkm 2017.12.16 300
985 자동백업시 폴더까지는 생성이 되는데 백업파일이 생성이 않됩니다. 1 secret 블랙 2015.03.30 8
984 자동증가 컬럼수정후 자동증가값이 들어가게 하려면? 7 초보 2010.02.27 18072
983 자동증가 트리거사용 1 kty7777 2015.07.06 4075
982 자동증가 필드 질문합니다 1 유니콘 2009.03.04 16024
981 자동증가값을 키로 사용하는 경우에 대해 질문 있습니다. 1 하늘나무 2017.07.19 752
980 자료 저장시 속도가 느려집니다. 1 푸른잔디 2009.12.11 9475
979 자바 함수 사용중에 jdbc 접속오류 발생 1 file go 2022.03.24 65
978 자바 + C 연동 끊김현상 1 secret 도제마 2014.07.14 13
977 자바 배치 쉘 수행시 큐브리드 이중화 설정 1 jeinhe 2022.04.18 79
976 자바 저장 프로시저 서버 기동 문의 1 준88 2022.09.27 72
Board Pagination Prev 1 ... 146 147 148 149 150 151 152 153 154 155 ... 200 Next
/ 200

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales