304.7. 샘플
아래의 Spring XML 샘플에서는 헤더 값을 기반으로 필터링합니다.
<from uri="seda:orders"> <filter> <simple>${in.header.foo}</simple> <to uri="mock:fooOrders"/> </filter> </from>
메시지 필터 패턴에서 위의 조건자 테스트에 Simple 언어를 사용할 수 있습니다. 여기서 in 메시지에 foo
헤더(키 foo
가 있는 헤더)가 있는지 테스트합니다. 표현식이 true 로 평가되면 메시지가 mock:fooOrders
엔드포인트로 라우팅되고, 그렇지 않으면 메시지가 삭제됩니다.
Java DSL의 예는 다음과 같습니다.
from("seda:orders") .filter().simple("${in.header.foo}") .to("seda:fooOrders");
다음과 같은 간단한 텍스트 연결에 간단한 언어를 사용할 수도 있습니다.
from("direct:hello") .transform().simple("Hello ${in.header.user} how are you?") .to("mock:reply");
이제 Camel이 올바르게 구문 분석할 수 있도록 식에 $\{ } 자리 표시자를 사용해야 합니다.
이 샘플은 date 명령을 사용하여 현재 날짜를 출력합니다.
from("direct:hello") .transform().simple("The today is ${date:now:yyyyMMdd} and it is a great day.") .to("mock:reply");
아래 샘플에서는 빈 언어를 호출하여 반환된 문자열에 포함할 빈에서 메서드를 호출합니다.
from("direct:order") .transform().simple("OrderId: ${bean:orderIdGenerator}") .to("mock:reply");
여기서 orderIdGenerator
는 레지스트리에 등록된 빈의 ID입니다. Spring을 사용하는 경우 Spring 빈 ID입니다.
order id 생성기 빈에서 호출할 메서드를 선언하려면 generateId
메서드를 호출하는 아래와 같은 .method 이름
을 추가해야 합니다.
from("direct:order") .transform().simple("OrderId: ${bean:orderIdGenerator.generateId}") .to("mock:reply");
빈 구성 요소 자체에 익숙한 ?method=methodname
옵션을 사용할 수 있습니다.
from("direct:order") .transform().simple("OrderId: ${bean:orderIdGenerator?method=generateId}") .to("mock:reply");
또한 Camel 2.3 이후부터 본문을 지정된 유형으로 변환하여 수행할 수 있는 문자열인지 확인할 수도 있습니다.
<transform> <simple>Hello ${bodyAs(String)} how are you?</simple> </transform>
단축 표기법이 있는 몇 가지 유형이 있으므로 java.lang.
String
대신 String을 사용할 수 있습니다. 이러한 값은 byte[], String, Integer, Long
입니다. 다른 모든 유형은 FQN 이름(예: org.w3c.dom.Document
)을 사용해야 합니다.
Camel 2.3 이후의 헤더 맵에서 값을 조회할 수도 있습니다.
<transform> <simple>The gold value is ${header.type[gold]}</simple> </transform>
위의 코드에서는 이름 유형
을 사용하여 헤더를 java.util.Map
으로 조회한 다음 키 골드로 조회한 후 값을 반환합니다. 헤더가 Map으로 변환할 수 없는 경우 예외가 throw됩니다.If the header is not convertible to Map an exception is thrown. name
유형
의 헤더가 없는 경우 null
이 반환됩니다.
Camel 2.9 이후부터는 아래와 같은 기능을 중첩할 수 있습니다.
<setHeader headerName="myHeader"> <simple>${properties:${header.someKey}}</simple> </setHeader>