- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我在尝试创建指向安全 URL 的端点时遇到了问题(它要求个人证书),我的目标是创建具有相同输入参数的内部服务,并使用获得的有效证书调用外部服务响应并将其重定向到调用者,从而避免调用者拥有有效证书。
这是我的路线:
<blueprint xmlns="http://www.osgi.org/xmlns/blueprint/v1.0.0"
xmlns:camel="http://camel.apache.org/schema/blueprint"
xmlns:cxf="http://camel.apache.org/schema/blueprint/cxf"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="
http://www.osgi.org/xmlns/blueprint/v1.0.0
http://www.osgi.org/xmlns/blueprint/v1.0.0/blueprint.xsd
http://camel.apache.org/schema/blueprint/cxf
http://camel.apache.org/schema/blueprint/cxf/camel-cxf.xsd
http://camel.apache.org/schema/blueprint
http://camel.apache.org/schema/blueprint/camel-blueprint.xsd">
<cxf:cxfEndpoint address="/validate_nif/" id="validateNifEndpoint" serviceClass="validationservice.nif.ValidateNifEndpoint"/>
<camel:sslContextParameters id="mySslContextParameters">
<camel:keyManagers keyPassword="">
<camel:keyStore password="XXXXX" resource="etc/certs/truststore.jks"/>
</camel:keyManagers>
<camel:clientParameters>
<camel:secureSocketProtocols>
<camel:secureSocketProtocol>SSLv3</camel:secureSocketProtocol>
</camel:secureSocketProtocols>
</camel:clientParameters>
</camel:sslContextParameters>
<bean class="org.apache.camel.component.http4.HttpComponent" id="my-http4">
<property name="sslContextParameters" ref="mySslContextParameters"/>
</bean>
<camelContext id="camelContext-83032cb1-6f93-4d6f-b22f-2cef908fcc8b" xmlns="http://camel.apache.org/schema/blueprint">
<contextScan/>
<route id="_route1" trace="true">
<!-- route starts from the cxf webservice -->
<from id="_from1" uri="cxf:bean:validateNifEndpoint"/>
<!-- log input received -->
<log id="_log1" message="Input: ${body}"/>
<removeHeaders id="_removeHeaders1" pattern="CamelHttp*"/>
<!-- call external service -->
<to id="_to2" uri="my-http4://www1.agenciatributaria.gob.es/wlpl/BURT-JDIT/ws/VNifV1SOAP?sslContextParametersRef=mySslContextParameters&proxyAuthHost=myproxy&proxyAuthPort=8080&proxyAuthScheme=http4"/>
<!-- log answer from real web service -->
<log id="_log2" message="Output: ${body}"/>
<transform id="_transform1">
<constant>OK</constant>
</transform>
</route>
</camelContext>
</blueprint>
http4 组件正确解析了代理设置,但它似乎没有解析 ssl 设置:
2017-06-14 13:48:40,237 | DEBUG | cxf/validate_nif | SendProcessor | 323 - org.apache.camel.camel-core - 2.17.0.redhat-630187 | >>>> Endpoint[my-http4://www1.agenciatributaria.gob.es/wlpl/BURT-JDIT/ws/VNifV1SOAP?proxyAuthScheme=http4&proxyAuthPort=8080&sslContextParametersRef=mySslContextParameters&proxyAuthHost=myproxy] Exchange[ID-010668-57070-1497438180654-4-6]
2017-06-14 13:48:40,242 | DEBUG | cxf/validate_nif | HttpProducer | 391 - org.apache.camel.camel-http4 - 2.17.0.redhat-630187 | Executing http GET method: http://www1.agenciatributaria.gob.es/wlpl/BURT-JDIT/ws/VNifV1SOAP?sslContextParametersRef=mySslContextParameters
2017-06-14 13:48:40,242 | DEBUG | cxf/validate_nif | RequestAddCookies | 392 - org.apache.httpcomponents.httpclient - 4.5.2 | CookieSpec selected: default
2017-06-14 13:48:40,242 | DEBUG | cxf/validate_nif | RequestAuthCache | 392 - org.apache.httpcomponents.httpclient - 4.5.2 | Auth cache not set in the context
2017-06-14 13:48:40,242 | DEBUG | cxf/validate_nif | olingHttpClientConnectionManager | 392 - org.apache.httpcomponents.httpclient - 4.5.2 | Connection request: [route: {}->http4://myproxy:8080->http://www1.agenciatributaria.gob.es:80][total kept alive: 3; route allocated: 1 of 20; total allocated: 3 of 200]
2017-06-14 13:48:40,247 | DEBUG | cxf/validate_nif | olingHttpClientConnectionManager | 392 - org.apache.httpcomponents.httpclient - 4.5.2 | Connection leased: [id: 10][route: {}->http4://myproxy:8080->http://www1.agenciatributaria.gob.es:80][total kept alive: 2; route allocated: 1 of 20; total allocated: 3 of 200]
2017-06-14 13:48:40,247 | DEBUG | cxf/validate_nif | MainClientExec | 392 - org.apache.httpcomponents.httpclient - 4.5.2 | Executing request GET http://www1.agenciatributaria.gob.es/wlpl/BURT-JDIT/ws/VNifV1SOAP?sslContextParametersRef=mySslContextParameters HTTP/1.1
2017-06-14 13:48:40,247 | DEBUG | cxf/validate_nif | MainClientExec | 392 - org.apache.httpcomponents.httpclient - 4.5.2 | Target auth state: UNCHALLENGED
2017-06-14 13:48:40,247 | DEBUG | cxf/validate_nif | MainClientExec | 392 - org.apache.httpcomponents.httpclient - 4.5.2 | Proxy auth state: UNCHALLENGED
2017-06-14 13:48:40,247 | DEBUG | cxf/validate_nif | headers | 392 - org.apache.httpcomponents.httpclient - 4.5.2 | http-outgoing-10 >> GET http://www1.agenciatributaria.gob.es/wlpl/BURT-JDIT/ws/VNifV1SOAP?sslContextParametersRef=mySslContextParameters HTTP/1.1
关于如何让它发挥作用有什么想法吗?
最佳答案
参见 https://camel.apache.org/manual/latest/camel-configuration-utilities.html注意:“secureSocketProtocol(属性)”所以,也许这会起作用:
<camel:sslContextParameters id="mySslContextParameters" secureSocketProtocol="SSLv3">
<camel:keyManagers keyPassword="">
<camel:keyStore password="XXXXX" resource="etc/certs/truststore.jks"/>
</camel:keyManagers>
</camel:sslContextParameters>
很长一段时间以来,我都试图克服通过 https4 发送的错误。到处建议使用:
<camel:clientParameters>
<camel:secureSocketProtocols>
<camel:secureSocketProtocol>TLSv1.2</camel:secureSocketProtocol>
</camel:secureSocketProtocols>
</camel:clientParameters>
一位同事建议使用属性 secureSocketProtocol="TLSv1.2",它奏效了。
关于java - Camel :sslContextParameters is not being used in an http4 connection,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44544216/
我正在使用 Apache Camel 2.20.0 并使用 REST DSL 和 HTTP 方案部署 REST 服务。 我正在使用硬编码值引用 sslContextParameters,一切正常。 我
我在尝试创建指向安全 URL 的端点时遇到了问题(它要求个人证书),我的目标是创建具有相同输入参数的内部服务,并使用获得的有效证书调用外部服务响应并将其重定向到调用者,从而避免调用者拥有有效证书。 这
我正在使用 Camel-HTTP4 2.10.4 组件从我的应用程序调用远程 REST 服务。此通信需要 SSL 配置。我成功使用 resource 和 password 的硬编码值测试了我的配置。
我是一名优秀的程序员,十分优秀!