[급 질문] FileOutputStream 데이터 다운로드 하기

kor2u의 이미지

얼마전에 파일을 파일서버에 저장하지 않고 디비에 바로 insert하는 걸 질문한 kor2u입니다.
일단은 디비에 데이터가 들어간 것 같은데.. 이게 제대로 들어갔는지 테스트를 하고 싶거든요..
그래서 FileOutputStream 타입으로 디비에서 데이터를 가져왔는데(jsp단으로).. 그담에는
이걸 어케 다운로드를 해야 할지 길이 안 보입니다.

작업환경은 java/jsp 입니다. 디비는 오라클 10g 이구요..

저에게 길을 좀 밝혀주세요.(__) 꾸벅

cleol의 이미지

뭔가 이상한데요. 파일을 DB에 저장하셨다면 ResultSet 또는 Blob 의 getBinaryStream 메소드로 InputStream 을 얻어야 읽어올 수 있을텐데요. FileOutputStream 은 하고자 하시는 일과는 전혀 무관한 클래스입니다. 뭐 어쨌거나 jsp 코드는 대략 다음과 같으면 됩니다.

* 코드가 이상하게 나오는군요. 파일로 첨부했습니다.

<%@page contentType="application/octet-stream" buffer="32kb" pageEncoding="UTF-8" import="java.io.*, javax.sql.*, java.net.*"%><%
String filename = ~~~filename~~~;
ResultSet rs = (~~~ query ~~~);
Blob b = rs.getBlob(1);
response.setHeader("Content-Disposition","attachment; filename=\"" + URLEncoder.encode(filename, "UTF-8") + "\";");
response.setHeader("Content-Length", "" + b.length());
InputStream is = b.getBinaryStream()
OutputStream os = response.getOutputStream();
byte[] buffer = new byte[102400];
int n = -1;
while((n = is.read(buffer)) != -1) {
	os.write(buffer, 0, n);
}
is.close();
os.close();
%>

jsp 로 작성하시면 output 에 의도하지 않은 공백 문자가 출력될 가능성도 있고 os.close() 이후에 예외가 발생할 수도 있으니 jsp 보다는 Servlet 으로 작성하시는 쪽이 좋습니다. 환경에 따라서는 헤더 셋팅 부분에서 인코딩을 "UTF-8" 이 아닌 다른 인코딩으로 바꿔야하실수도 있구요. 여하튼 대략적인 코드는 위와 같습니다.

댓글 첨부 파일: 
첨부파일 크기
Binary Data tmp.jsp611바이트

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.