150.18. 고급 사용


HTTP 생산자를 더 많이 제어해야 하는 경우 다양한 클래스를 설정하여 사용자 지정 동작을 제공할 수 있습니다.

150.18.1. MaxConnectionsPerHost 설정

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

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

그리고 우리는 일반적으로 우리의 경로에서하는 것처럼 사용할 수 있습니다:

150.18.2. 선점 인증 사용

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

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

Apache Commons HTTP API를 사용하여 이 작업을 수행하는 방법을 간략하게 설명하는 메일링 리스트 토론의 이 링크를 참조하십시오.

150.18.4. HTTP Client를 위한 SSL 설정

JSSE 구성 유틸리티 사용

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

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

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");

직접 Apache HTTP 클라이언트 구성

기본적으로 camel-http 구성 요소는 Apache HTTP 클라이언트 상단에 빌드되며 사용자 정의 org.apache.camel.component.http.HttpClientConfigurer 를 구현하여 http 클라이언트에서 일부 구성을 수행할 수 있습니다.

그러나 키 저장소 및 신뢰 저장소를 지정하려는 경우 Apache HTTP#159 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);

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

HttpComponent httpComponent = getContext().getComponent("http", HttpComponent.class);
httpComponent.setHttpClientConfigurer(new MyHttpClientConfigurer());

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

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

<to uri="https://myhostname.com:443/myURL?httpClientConfigurerRef=myHttpClientConfigurer"/>

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

Red Hat logoGithubRedditYoutubeTwitter

자세한 정보

평가판, 구매 및 판매

커뮤니티

Red Hat 문서 정보

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

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

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

Red Hat 소개

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

© 2024 Red Hat, Inc.