304.7. 샘플


아래 Spring XML 샘플에서는 헤더 값을 기반으로 필터링합니다.

<from uri="seda:orders">
   <filter>
       <simple>${in.header.foo}</simple>
       <to uri="mock:fooOrders"/>
   </filter>
</from>

Message Filter 패턴에서 위의 조건자 테스트에 Simple language를 사용할 수 있으며, 여기서 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");

아래 샘플에서는 scaling 언어를 호출하여 반환된 문자열에 포함할ans에서 메서드를 호출합니다.

from("direct:order")
    .transform().simple("OrderId: ${bean:orderIdGenerator}")
    .to("mock:reply");

여기서 orderIdGenerator 는 레지스트리에 등록된 8080의 ID입니다. Spring을 사용하는 경우 Spring 빈 ID입니다.

주문 ID 생성기 빈에서 호출할 메서드를 선언하려면 generateId 메서드를 호출하는 아래와 같은 .method 이름을 추가해야 합니다.

from("direct:order")
    .transform().simple("OrderId: ${bean:orderIdGenerator.generateId}")
    .to("mock:reply");

?method=methodname 구성 요소 자체에 익숙한 ?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 대신 문자열을 사용할 수 있습니다. 이는 byte[], string, Integer, Long 입니다. 다른 모든 유형은 FQN 이름(예: org.w3c.dom.Document )을 사용해야 합니다.

Camel 2.3 이후의 헤더 에서 값을 조회할 수도 있습니다.

<transform>
  <simple>The gold value is ${header.type[gold]}</simple>
</transform>

위의 코드에서 name type 으로 헤더를 조회하고 java.util.Map 과 관련하여 key gold 로 조회하고 값을 반환합니다. 헤더가 예외를 매핑하도록 변환되지 않으면 예외가 발생합니다. name 유형의 헤더가 없는 경우 null 이 반환됩니다.

Camel 2.9 이후부터 다음과 같은 기능을 중첩할 수 있습니다.

<setHeader headerName="myHeader">
  <simple>${properties:${header.someKey}}</simple>
</setHeader>
Red Hat logoGithubRedditYoutubeTwitter

자세한 정보

평가판, 구매 및 판매

커뮤니티

Red Hat 문서 정보

Red Hat을 사용하는 고객은 신뢰할 수 있는 콘텐츠가 포함된 제품과 서비스를 통해 혁신하고 목표를 달성할 수 있습니다.

보다 포괄적 수용을 위한 오픈 소스 용어 교체

Red Hat은 코드, 문서, 웹 속성에서 문제가 있는 언어를 교체하기 위해 최선을 다하고 있습니다. 자세한 내용은 다음을 참조하세요.Red Hat 블로그.

Red Hat 소개

Red Hat은 기업이 핵심 데이터 센터에서 네트워크 에지에 이르기까지 플랫폼과 환경 전반에서 더 쉽게 작업할 수 있도록 강화된 솔루션을 제공합니다.

© 2024 Red Hat, Inc.