383.3. Marshal

이 예제에서는 Zip 파일 압축을 사용하여 일반 텍스트/XML 페이로드를 압축 페이로드로 마샬링하고 MY_QUEUE라는 ActiveMQ 큐로 전송합니다.

from("direct:start")
    .marshal().zipFile()
    .to("activemq:queue:MY_QUEUE");

생성된 Zip 파일 내의 Zip 항목의 이름은 파일 구성 요소에서 사용하는 표준 메시지 헤더인 수신되는 CamelFileName 메시지 헤더를 기반으로 합니다. 또한 발신 CamelFileName 메시지 헤더는 ".zip" 접미사를 사용하여 들어오는 CamelFileName 메시지 헤더의 값으로 자동 설정됩니다. 예를 들어 다음 경로에서 입력 디렉토리에서 "test.txt"라는 파일을 찾으면 출력에 "test.txt.zip"이라는 단일 Zip 항목이 포함된 Zip 파일이 생성됩니다.

from("file:input/directory?antInclude=*/.txt")
    .marshal().zipFile()
    .to("file:output/directory");

들어오는 CamelFileName 메시지 헤더(예: 파일 구성 요소가 소비자가 아닌 경우) 메시지 ID가 기본적으로 사용되고 메시지 ID는 일반적으로 고유한 생성된 ID이므로 ID-MACHINENAME-2443-1211718892437-1-0.zip.zip과 같은 파일 이름이 생성됩니다. 이 동작을 재정의하려면 경로에서 CamelFileName 헤더 값을 명시적으로 설정할 수 있습니다.

from("direct:start")
    .setHeader(Exchange.FILE_NAME, constant("report.txt"))
    .marshal().zipFile()
    .to("file:output/directory");

이 경로에는 출력 디렉토리에 "report.txt.zip"이라는 Zip 파일이 생성되어 "report.txt"라는 단일 Zip 항목이 포함됩니다.