149.18. 고급 사용


HTTP 프로듀서에 대한 더 많은 제어가 필요한 경우, 다양한 클래스를 설정하여 사용자 지정 동작을 지정할 수 있는ECDHE Component 를 사용해야 합니다.

149.18.1. Setting MaxConnectionsPerHost

HTTP 구성 요소에는 지정된 구성 요소에 대한 다양한 글로벌 구성을 구성할 수 있는 org.apache.commons.httpclient.HttpConnectionManager 가 있습니다.
전역적으로 구성 요소 생성에는 동일한 공유 ConnectionManager 가 있는 끝점이 있습니다. 따라서 호스트당 max 연결에 대해 다른 값을 설정하려면 일반적으로 사용하는 엔드포인트 URI가 아닌 HTTP 구성 요소에 정의해야 합니다. 다음과 같이 표시됩니다.

먼저 Spring XML에서 http 구성 요소를 정의합니다. 예, Camel이 자동 검색되고 기본 설정으로 구성 요소를 생성하기 때문에 동일한 스키마 이름 http 를 사용합니다. 이 문제를 해결하기 위해 필요한 것은 옵션을 설정할 수 있도록 하는 것입니다. 아래 샘플에서는 기본값인 2 대신 max 연결을 5로 설정합니다.

그런 다음 일반적으로 경로에서하는 것처럼 사용할 수 있습니다.

149.18.2. 선점형 인증 사용

최종 사용자는 HTTPS로 인증하는 데 문제가 있다고 보고했습니다. HTTPS 서버가 HTTP 코드 401 인증 필요를 반환하지 않으면 결국 문제가 해결되었습니다. 해결 방법은 다음 URI 옵션을 설정하는 것이었습니다. httpClient.authenticationPreemptive=true

149.18.3. 원격 서버에서 자체 서명된 인증서 수락

Apache Commons HTTP API를 사용하여 이를 수행하는 방법을 간략하게 설명하기 위해 일부 코드와의 메일링 목록 토론에서 이 링크를 참조하십시오.

149.18.4. HTTP 클라이언트에 대한 SSL 설정

JSSE 설정 사용

Camel 2.8부터 HTTP4 구성 요소는 Camel JSSE ConfigurationECDHE를 통해 SSL/TLS 구성을 지원합니다.  이 유틸리티는 작성해야 하는 구성 요소 특정 코드의 양을 크게 줄이고 끝점 및 구성 요소 수준에서 구성할 수 있습니다.  다음 예제에서는 HTTP4 구성 요소에 유틸리티를 사용하는 방법을 보여줍니다.

이 구성 요소에 사용되는 Apache HTTP 클라이언트의 버전은 글로벌 "프로토 프로토콜" 레지스트리에서 SSL/TLS 정보를 해결합니다.  이 구성 요소는 Camel JSSE Configuration 유틸리티 사용을 지원하기 위해 HTTP 클라이언트의 프로토콜 소켓 팩토리에 대한 구현인 org.apache.component.http.SSLContextParametersSecureProtocol SocketECDHEy를 제공합니다.  다음 예제에서는 프로토콜 레지스트리를 구성하고 경로에 등록된 프로토콜 정보를 사용하는 방법을 보여줍니다.

KeyStoreParameters ksp = new KeyStoreParameters();
ksp.setResource("/users/home/server/keystore.jks");
ksp.setPassword("keystorePassword");

KeyManagersParameters kmp = new KeyManagersParameters();
kmp.setKeyStore(ksp);
kmp.setKeyPassword("keyPassword");

SSLContextParameters scp = new SSLContextParameters();
scp.setKeyManagers(kmp);

ProtocolSocketFactory factory =
    new SSLContextParametersSecureProtocolSocketFactory(scp);

Protocol.registerProtocol("https",
        new Protocol(
        "https",
        factory,
        443));

from("direct:start")
        .to("https://mail.google.com/mail/").to("mock:results");
Copy to Clipboard Toggle word wrap

Apache HTTP 클라이언트 직접 구성

기본적으로 camel-http 구성 요소는 Apache HTTP 클라이언트 상단에 구축되며 사용자 지정 org.apache.camel.component.http.HttpClientConfigurer 를 구현하여 http 클라이언트에 전체 제어 권한이 필요한 경우 http 클라이언트에서 일부 구성을 수행할 수 있습니다.

그러나 키 저장소 및 신뢰 저장소를 지정하려면 Apache HTTPECDHE ClientConfigurer 를 사용하여 이 작업을 수행할 수 있습니다. 예를 들면 다음과 같습니다.

Protocol authhttps = new Protocol("https", new AuthSSLProtocolSocketFactory(
  new URL("file:my.keystore"), "mypassword",
  new URL("file:my.truststore"), "mypassword"), 443);

Protocol.registerProtocol("https", authhttps);
Copy to Clipboard Toggle word wrap

그런 다음ECDHE ClientConfigurer 를 구현하는 클래스를 만들고 위의 예제당 키 저장소 또는 신뢰 저장소를 제공하는 https 프로토콜을 등록합니다. 그런 다음, camel 경로 빌더 클래스에서 다음과 같이 후크를 수행할 수 있습니다.

HttpComponent httpComponent = getContext().getComponent("http", HttpComponent.class);
httpComponent.setHttpClientConfigurer(new MyHttpClientConfigurer());
Copy to Clipboard Toggle word wrap

Spring DSL을 사용하여 이 작업을 수행하는 경우 URI를 사용하여 ClientConfigurer 를 지정할 수 있습니다. 예를 들면 다음과 같습니다.

<bean id="myHttpClientConfigurer"
 class="my.https.HttpClientConfigurer">
</bean>

<to uri="https://myhostname.com:443/myURL?httpClientConfigurerRef=myHttpClientConfigurer"/>
Copy to Clipboard Toggle word wrap

위에서 설명한 대로ECDHEClientConfigurer를 구현하고 키 저장소 및 신뢰 저장소를 구성하는 한 제대로 작동합니다.

맨 위로 이동
Red Hat logoGithubredditYoutubeTwitter

자세한 정보

평가판, 구매 및 판매

커뮤니티

Red Hat 문서 정보

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

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

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

Red Hat 소개

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

Theme

© 2025 Red Hat