자바 멀티파트

JAVA/자바 2015. 11. 2. 21:58

http://egloos.zum.com/ultteky/v/3945848

파일 업로드를 위한 기본적인 폼 형태

 

웹 브라우저를 통해서 파일은 전송하기 위해서 폼 구성에 대해서 알아보자. form  태그의 속성돌중 input 태그들이 있는데

이들중 <input type="file"> 태그는 파일을 선택할 수 있는 창을 만든다.

또한 이렇게 선택된 파일을 전송하기 위해서 form 태그의 속성들 중 method외 enctype을 다음과 같이 지정한다.

 

<form name="formName" method="post" enctype="multipart/form-data">

 

<input type="file" name="selectfile">

 

Warn

 

<form method="post" enctype="multipart/form-data">으로 지정한 폼 요소에서 파일 업로드를 위한

파일 요소를 지정해야한다.

<input type="file" name="filetype"> input 태그의 속성으로 type은 file로 지정하고,

 이 태그에 대한 이름을 명시 해야한다.

 

<form method="post">의 형태로 전송한 폼에 담겨진 파라미터들은 request 객체를 통해서 이름에 해당되는 값을 얻어낼 수 있다.

하지만 이렇게 <form name="formName" method="post" enctype="multipart/form-data">에서 enctype="multipart/form-data"로

지정한 폼을 전송했을때, request 객체로 파라미터의 값을 얻어 낼수 없다.

 

그래서 enctype="multipart/form-data" 로 전송한 폼에 담겨진 파라미터들에 대한 이름과 값을 얻어내기 위해,그리고

<input type="file">로 지정된 파일을 서버상의 한 폴더에 업로드하기 위해서 특별한 컴포넌트가 필요하다.

http://servlets.com 에서 제공하는 cos.jar 파일에는 필요한 컴포넌트가 있다.

이 컴포넌트를 설치하자.

 

Tip

파일업로드 및, 폼 데이터를 파싱하는 컴포넌트로 cos.jar 이에외도 많은 컴포넌트가 있다.

 

cos.jar를 myapp/WEB-INF/lib폴더에 복사하는 이유

 

JSP에서 cos.jar의 패키지를 이용하게 되는데 , cos.jar는 톰켓에 기본적으로 내장되어 있지 않은 외부의 패키지이다.

외부의 패캐니는 WEB-INF/lib 폴더에 위치해야 하는데, 이때 WEB-INF는 각각의 웹 어플리케이션에 이 폴더가

존재한다. 본이이 작성하는 모든 예제는 myapp로 이름 지어진 웹 어플리케이션에 위치하는데, 이 어플리케이션이 실행될

때 사용되는 패키지가 해당 어플리케이션 /WEB-INF/lib 폴더에 있는 패키지 이다.

 

Constructor Summary

 

MultipartRequest(javax.servlet.http.HttpServletReqeust request,

                         java.lang.String.saveDirectory,

                         int maxPostSize,

                         java.lang.String encoding,

                         FileRenamePolicy policy)

 

Method Summary

 

java.lang.String                              getContentType(java.lang.String name)

                                                    업로드된 파일의 컨텐트 타입을 반환, 업로드된 파일이 없으면 null을 반환

 

java.io.File                                    getFile(java.lang.String name)

                                                    서버 상에 업로드된 파일의 파일 객체를 반환, 업로드된 파일이 없다면 null을 반환

 

java.util.Enumeration                      getFileNames()

                                                   폼 요소 중 input 태그 속성이 file로 된 파라미터의 이름들을 반환, upload 된

                                                   파일이 없으면 비어있는 Enumeration을 반환

 

java.lang.String                             getFilesystemName(java.lang.String name)

                                                   사용자가 지정해서 서버 상에 실제로 업로드된 파일명을 반환

 

java.lang.String                             getOrignalFileName(java.lang.String name)

                                                   사용자가 지정해서 서버상에 업로드된 파일명을 반환, 이때의 파일명은 파일 중복을

                                                   고려한 파일명 변경 전의 이름을 말한다.

 

java.lang.String                             getParameter(java.lang.String name)

                                                   스트링으로 주어진 이름에 대한 값을 반환. 값 없이 파라미터가 전송되었거나 해당되는

                                                   이름의 파라미터가 전송이 안 되었을 경우 null 를 반환

 

java.util.Enumeration                      getParameterNames()

                                                   모든 파라미터 이름을 Enumeration 으로 반환 한다.

 

java.lang.String[]                          getParameterValues(java.lang.String name)

                                                   주어진 이름에 대한 값을 스트링 배열로 반환, 파라미터가 전송되지 않았을 때는 null 반환

 

 첫 번째로 해야 할 부분은 폼 enctype 속성을 multipart/form-data로 지정한 폼에 담겨진 파라미터를 읽어오기 위해서

MultipartRequest 의 객체를 생성해야 한다. 이 객체를 통해서 파일 업로드를 구현 할 수 있다.

MultipartRequest 객체를 생성한후 객체를 통해서 MultiPartRequest 클래스에서 제공하는 메소드들을 사용하면 쉽게 파일 업로드와 파라미터를 읽어 올 수 있다.

MultipartRequest 객체를 생성한 뒤, 메소드 사용의 예를 들어 파일 업로드와 파라미터에 대한 처리를 위한 절차를 설명 하겠다.

 

MultipartRequest의 생성자

 

MultipartRequest의 생성자를 종류가 많다.

cos.jar 에 있는 MultipartRequest 클래스의 생성자 중 다음의 생성자는 한글 인코딩,업로드되는 파일이 기존에 파일과 중복될때

의 단점을 해결한 생성자이다.

 

그래서 이 생성자를 사용하여 MultipartRequest 의 객체를 생성한다.

 

MultipartRequest multi = new MultiPartRequest(request,

                                                                   folderDirectory,

                                                                   1024*10,

                                                                   "euc-kr",

                                                                   new DefaultFileRenamePolicy());

 

첫 번째 인자는 Request 객체이고,

두 번재 인자는 업로드된 파일이 저장될 파일폴더 경로 이다.

세 번째 인자를 업로드할 파일의 최대 크기이다.( 1024=1024Bytes, 즉 1KB, 1024*10 = 10KB )

네 번째는 인코딩 타입

다섯 번째 인자는 업로드 될 파일명이 기존에 업로드된 파일명과 같은 경우 덮어쓰기를 방지하기 위해 설정하는 부분이다.

 

이 객체가 생성되면서 폼에서 지정한 파일이 서버상의 폴더에 저장된다.

 

Warn!!!

 

파일 업로드를 위한 파일 선택을 위해서 <input type="file">을 사용합니다.

그리고 이 <input type="file">라는 폼 요소를 포함하는 폼은 파일 전송을 위해서

<form method="post" enctype="multipart/form-data"> 로 속성을 지정해야 한다.

 

 

 

getParameterNames() 메소드

 

Enumeration params = multi.getParameterNames();

 

multi 라는 이름을 가지는 객체를 통해서 MultipartRequest  클래스에 있는 메소드를 사용 할수 있는데,

getParameterNames() 메소드는 폼에서 전송한 파라미터들의 이름을 Enumeration 타입으로 반환한다.

폼에 있는 input 태그중 file 속성이 아닌 모든 파라미터들의 이름을 반환하는 메소드 이다.

 

 

getParameter() 메소드

 

String paramValue = multi.getParameter(java.lang.String name);

 

getParameter 메소드는 request 객체에서 사용되는 getParameter 메소드처럼 파라미터의 이름을 인자로 받아서 그 파라미터

의 값을 반환하는 메소드이다.

이 메소드에 전달될 인자는 getParameterNames() 메소드를 통해서 얻어온 파라미터 이름을 인자로 주면 그 파라미터에 담긴 값을반환한다.

 

getFileNames() 메소드

 

Enumeration files = multi.getFileNames();

 

getFileNmaes() 메소드는 폼 요소 중 file 속성으로 지정된 input 태그의 이름, 즉 file 속성을 가진 파라미터의 이름을 Enumeration 타입

으로 반환한다.

예를 들면 <input type="file" name="uploadfile"> 태그가 폼 요소에 있었다면 getFileNmaes() 메소드는 uploadfile

이란 파라미터의 이름을 담긴 Enumeration을 반환한다.

 

 

getFilesystemName() 메소드

 

String filename = multi.getFilesystemNmae(name);

 

file 속성으로 지정된 input 태그에 의해 서버 상에 실제로 업로드된 파일 이름을 스트링 타입으로 반환한다.

이 메소드가 반환하는 파일명의 file 속성을 가진 input 태그에서 사용자가 지정한 파일 이름이 아니고

사용자가 선택한 파일이 실제 서버 상의 폴더에 저장 되었을 때의 파일명을 반환한다.

아래의 getOriginalFileNmae() 메소드에서 비교 설명 하겠다.

 

getOriginalFileName() 메소드

 

String original = multi.getOriginalFileName(name);

 

getOriginalFileName() 메소드는 사용자가 직접 지정한 파일명을 반환한다.

MultipartRequest 의 생성자 중 중복된 파일을 덮어쓰는 것을 방지하기 위해 사용되는 FileRenamePolicy 인터페이스를

구현한 DefaultFileRenamePolicy 에 의해서 파일명이 변경되기 전의 파일명을 반환한다.

 

getFileSystemName() 메소드는 기존에 업로드된 파일명들 중에 새로 업로드할 파일명이 중복될 경우 파일명 뒤에

filename1.***, filename2.*** 식으로 변경된 이름을 반환한다.

중복되는 경우가 없다면 원래의 파일명을 반환한다.

 

getOriginalFileName() 은 사용자가 지정해서 업로드되는 파일명을 반환하고,

getFileSystemName()  메소드는 파일명이 중복되는 경우 변경된 파일명을 반환한다.

 

 

getContentType() 메소드

 

String type = multi.getContentType(name);

 

getContentType() 메소드는 업로드된 파일의 컨텐트 타입을 반환한다.

 

 

getFile() 메소드

 

File f = multi.getFile(name);

 

getFile() 메소드는 서버 상에 업로드된 파일에 대한 파일 객체를 반환한다.

 

'JAVA > 자바' 카테고리의 다른 글

자바 오류  (0) 2015.11.21
자바 ARC4 암호화  (0) 2015.11.21
자바 스트림 종류  (0) 2015.10.29
자바 이미지파일 전송 클라이언트쪽  (0) 2015.10.29
자바 이미지파일 전송 서버쪽  (0) 2015.10.29
블로그 이미지

왕왕왕왕

,

<!DOCTYPE html>

<html>

<body>


<form>


  <input type="radio" name="colors" id="red">Red<br>

  <input type="radio" name="colors" id="blue">Blue

</form>


<button onclick="check()">Check "Red"</button>



<script>


function check() {

  if(document.getElementById("red").checked==true){

alert("d");

 }

}

</script>


</body>

</html>



블로그 이미지

왕왕왕왕

,

자바 스트림 종류

JAVA/자바 2015. 10. 29. 23:15

I/O 입출력 클래스의 종류


JAVA의 I/O는 java.io 패키지에 클래스가 정의되어 있는 경우가 대부분이다. (최근에는 nio 등이 나왔다.)


JAVA의 초기에는 입출력 클래스도 단순하였다. 단순히 바이트 단위의 입출력만 지원했지만, 현재는 계속적으로 확장되며 문자 단위의 입출력 뿐만 아니라 다양한 기능을 지원하는 클래스들이 생겨났다.


1. I/O 클래스의 이름과 의미


Stream으로 끝나는 클래스 : 바이트 단위로 입출력을 수행하는 클래스

Reader / Writer로 끝나는 클래스 : 캐릭터 단위로 입출력을 수행하는 클래스

File로 시작하는 클래스 : 하드디스크의 파일을 사용하는 클래스

Data로 시작하는 클래스 : 자바의 원시 자료형을 출력하기 위한 클래스

Buffered로 시작하는 클래스 : 시스템의 버퍼를 사용하는 클래스


1차 스트림 : 입/출력 통로를 직접 만드는 클래스

2차 스트림 : 기존의 통로를 이용하여 새로운 기능을 더하는 클래스



2. InputStream / OutputStream (바이트 입출력)



(1) InputStream


 클래스

설 명 

 Stream

InputStream 

 바이트 입력 스트림을 위한 추상 클래스 

2차 Stream 

FileInputStream

 파일에서 바이트를 읽어들여 바이트 스트림으로 변환 

1차 Stream 

PipedInputStream 

 PipedOutputStream에서 읽어들임 

1차 Stream

FilterInputStream 

 필터 적용(filtered) 바이트 입력을 위한 추상 클래스 

2차 Stream

LineNumberInputStream 

 바이트 입력시 라인 번호를 유지 (비추천)

2차 Stream

DataInputStream 

 기본 자료형 데이터를 바이트로 입력

2차 Stream

BufferedInputStream 

 바이트 버퍼 입력

2차 Stream

PushbackInputStream 

 읽어들인 바이트를 되돌림 (pushback) 

2차 Stream

ByteArrayInputStream 

 바이트 배열에서 읽어들임 

1차 Stream

SequenceInputStream

 t서로 다른 InputStream을 입력받은 순서대로 이어줌

2차 Stream

StringBufferInputStream 

 문자열에서 읽어들임 (비추천)

1차 Stream

ObjectInputStream 

 객체로 직렬화된 데이터를 역직렬화 하여 읽는다. 

2차 Stream


(2) OutputStream


 클래스

설 명 

 Stream

OutputStream 

 바이트 출력 스트림을 위한 추상 클래스 

2차 Stream 

FileOutputStream

 바이트 스트림을 바이트 파일로 변환 

1차 Stream 

PipedOutputStream 

 PipedOutputStream에 출력

1차 Stream

FilterOutputStream 

 필터 적용(filiterd) 바이트 출력을 위한 추상 클래스 

2차 Stream

DataOutputStream 

 바이트를 기본자료형으로 출력

2차 Stream

BufferedOutputStream 

 바이트 스트림에 버퍼 출력

2차 Stream

PrintStream

 Stream 값과 객체를 프린트

2차 Stream

ByteArrayOutputStream 

 바이트 스트림에 바이트 배열 출력

1차 Stream

ObjectputStream 

 데이터를 객체로 직렬화 하여 출력

2차 Stream



3. Reader / Writer (문자 입출력)


* 문자 입출력에는 문자 Encoding이 관여된다.


(1) Reader


 클래스

설 명 

 Stream

Reader

 바이트 입력 스트림을 위한 추상 클래스 

2차 Stream 

 BufferedReader

 문자 버퍼 입력, 라인 해석 

 2차 Stream

 LineNumberReader

 문자 입력시 라인 번호를 유지 

 2차 Stream

 CharArrayReader

 문자 배열에서 읽어들임 

 1차 Stream

 InputStreamReader

 바이트 스트림을 문자 스트림으로 변환 

 2차 Stream

 FileReader

 파일에서 바이트를 읽어들여 문자 스트림으로 변환 

 1차 Stream

 FilterReader

 필터 적용(filtered) 문자 입력을 위한 추상 클래스 

 2차 Stream

 PushbackReader

 읽어들인 문자를 되돌림 (pushback) 

 2차 Stream

 PipedReader

 PipedWriter에서 읽어들임 

 1차 Stream

 StringReader

 문자열에서 읽어들임 

 1차 Stream


(2) Writer


 클래스

설 명 

 Stream

Writer

 문자 출력 스트림을 위한 추상 클래스

 2차 Stream

BufferedWriter

 문자 스트림에 버퍼 출력, 줄바꿈 사용

 2차 Stream

CharArrayWriter 

 문자 스트림에 문자배열 출력 

 1차 Stream

OutputStreamWriter 

 문자 스트림을 바이트 스트림으로 변환 

 2차 Stream

FileWriter

 문자 스트림을 바이트 파일로 변환

 1차 Stream

FilterWriter 

 필터 적용(filtered) 문자 출력을 위한 추상 클래스 

 2차 Stream

PipedWriter 

 PipedReader에 출력 

 1차 Stream

StringWriter 

 문자열 출력 

 1차 Stream

PrintWriter 

 Writer 값과 객체를 프린트 

 2차 Stream



4. 그외의 java.io 클래스


클래스

설 명 

console 

명령행에서 쉽게 입력을 받고, 정형화된 출력을 명령행에 쉽게 출력할 수 있다. 

File

파일 객체를 생성한다. 

FileDescriptor 

물리적 파일에 대한 현재의 연결을 나타내기 위한 클래스

FilePermission 

파일 및 디렉토리에 액세스접 권한을 관리하는 클래스

RandomAccessFile 

랜덤 액세스 파일로부터 읽기와 쓰기가 동시에 이루어질 수 있다.

SerializablePermission

직렬화 가능 액세스 권한을 위한 클래스

StreamTokenizer

입력 스트림을 인수에 취해, 그것을 [토큰]에 구문 분석 해, 한 번에 1개 토큰을 읽는다. 



출처http://hyeonstorage.tistory.com/250

'JAVA > 자바' 카테고리의 다른 글

자바 ARC4 암호화  (0) 2015.11.21
자바 멀티파트  (0) 2015.11.02
자바 이미지파일 전송 클라이언트쪽  (0) 2015.10.29
자바 이미지파일 전송 서버쪽  (0) 2015.10.29
자바 tess4j import 하기  (0) 2015.10.27
블로그 이미지

왕왕왕왕

,

// 소켓 생성

Socket socket = new Socket(dstAddress, dstPort);

// 데이터 전송용 스트림 생성

DataOutputStream dos = new DataOutputStream(socket.getOutputStream());

System.out.println("파일 전송 작업을 시작합니다.");


// 파일 이름 전송

// String fName = "작업용a.txt";

// String fName = "피티a.ppt";

// String fName = "작업용a.jpg";

String fName = "작업용a.png";

dos.writeUTF(fName);

System.out.printf("파일 이름(%s)을 전송하였습니다.\n", fName);


// 파일 내용을 읽으면서 전송

BufferedInputStream bis = new BufferedInputStream(new ByteArrayInputStream(bitmapToByteArray(b)));


int len;

int size = 4096;

byte[] data = new byte[size];

while ((len = bis.read(data)) != -1) {

dos.write(data, 0, len);

}


dos.flush();

dos.close();

bis.close();

System.out.println("파일 전송 작업을 완료하였습니다.");

System.out.println("보낸 파일의 사이즈 : " + bitmapToByteArray(b).length);

'JAVA > 자바' 카테고리의 다른 글

자바 멀티파트  (0) 2015.11.02
자바 스트림 종류  (0) 2015.10.29
자바 이미지파일 전송 서버쪽  (0) 2015.10.29
자바 tess4j import 하기  (0) 2015.10.27
자바 OCR 오픈소스 tess4j  (0) 2015.10.27
블로그 이미지

왕왕왕왕

,


System.out.println("from " + socket.getInetAddress() + ":" + socket.getPort());


try {

System.out.println("파일 수신 작업을 시작합니다.");

DataInputStream dis = new DataInputStream(socket.getInputStream());


// 파일명을 전송 받고 파일명 수정.

String fName = dis.readUTF();

System.out.println("파일명 " + fName + "을 전송받았습니다.");


// 파일을 생성하고 파일에 대한 출력 스트림 생성


BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream("C:/save/to.jpg"));

System.out.println(fName + "파일을 생성하였습니다.");


// 바이트 데이터를 전송받으면서 기록

ArrayList<Byte> b = new ArrayList<>();

int sum = 0;

int len;

int size = 4096;

byte[] data = new byte[size];


while ((len = dis.read(data)) != -1) {

bos.write(data, 0, len);

sum += len;

}

System.out.println(data + " " + len+" "+sum);


bos.flush();

bos.close();

dis.close();

System.out.println("파일 수신 작업을 완료하였습니다.");

System.out.println("받은 파일의 사이즈 : " + sum);



'JAVA > 자바' 카테고리의 다른 글

자바 스트림 종류  (0) 2015.10.29
자바 이미지파일 전송 클라이언트쪽  (0) 2015.10.29
자바 tess4j import 하기  (0) 2015.10.27
자바 OCR 오픈소스 tess4j  (0) 2015.10.27
자바 특정 경로 안에 파일목록 출력  (0) 2015.10.24
블로그 이미지

왕왕왕왕

,



tess4j.jar을 자바프로젝트에서 라이브러리 추가함





여기있는 라이브러리도 다추가해야줘야됨




블로그 이미지

왕왕왕왕

,

package test4j;



import java.io.File;


import net.sourceforge.tess4j.Tesseract;

import net.sourceforge.tess4j.TesseractException;


public class test {


public static void main(String[] args) {

// TODO Auto-generated method stub





       File imageFile = new File("C:/Users/swu09/Downloads/Tess4J-2.0-src/Tess4J/Korean.jpg");     Tesseract instance = Tesseract.getInstance();  // JNA Interface Mapping

       

       instance.setDatapath("C:/Users/swu09/Downloads/Tess4J-2.0-src/Tess4J/tessdata");

       // Tesseract1 instance = new Tesseract1(); // JNA Direct Mapping

       System.out.println(imageFile.canRead());

       try {

           String result = instance.doOCR(imageFile);

           System.out.println(result);

       } catch (TesseractException e) {

           System.err.println(e.getMessage());

       }

}


}



위소스가 샘플소스이고 응용하면된다. 중간에 setDatapath는 tessdata폴더 경로까지 써주면된다. 안쓰면 오류나기도함


블로그 이미지

왕왕왕왕

,

package fileFind;

import java.io.File;

public class dirFind {

    public static void main(String[] args) {
        // TODO Auto-generated method stub

        String path = "C:/";
        //c:/Users/king/Downloads/asprise-ocr-java-15.3.1-trial-windows/aocr/com/asprise/ocr
        File dirFile = new File(path);
        File[] fileList = dirFile.listFiles();
        System.out.println(fileList.length);
        for (File tempFile : fileList) {
           
           
            if (tempFile.isFile()) {
                String tempPath = tempFile.getParent();
                String tempFileName = tempFile.getName();
                System.out.println("Path=" + tempPath);
                System.out.println("FileName=" + tempFileName);
                /*** Do something withd tempPath and temp FileName ^^; ***/
            }
        }
    }

}

블로그 이미지

왕왕왕왕

,