384.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 항목이 포함된 "test.txt.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
과 같은 파일 이름으로 끝납니다. 이 동작을 재정의하려면 경로에서 CamelFileName
헤더 값을 명시적으로 설정할 수 있습니다.
from("direct:start") .setHeader(Exchange.FILE_NAME, constant("report.txt")) .marshal().zipFile() .to("file:output/directory");
이 경로는 출력 디렉터리에 "report.txt.txt"라는 단일 Zip 항목이 포함된 Zip 파일 "report.txt.zip"이 생성됩니다.