You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@cxf.apache.org by "Daniel Kulp (JIRA)" <ji...@apache.org> on 2014/07/01 21:51:24 UTC

[jira] [Resolved] (CXF-5836) NullPointerException in AsyncHTTPConduit if http.noProxyHosts set

     [ https://issues.apache.org/jira/browse/CXF-5836?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Daniel Kulp resolved CXF-5836.
------------------------------

       Resolution: Fixed
    Fix Version/s: 3.0.1
                   2.7.12
         Assignee: Daniel Kulp

> NullPointerException in AsyncHTTPConduit if http.noProxyHosts set
> -----------------------------------------------------------------
>
>                 Key: CXF-5836
>                 URL: https://issues.apache.org/jira/browse/CXF-5836
>             Project: CXF
>          Issue Type: Bug
>          Components: Transports
>    Affects Versions: 2.7.6, 2.7.7, 2.7.8, 2.7.9, 2.7.10, 2.7.11
>         Environment: Windows or Linux
>            Reporter: Nicolas Sprauel
>            Assignee: Daniel Kulp
>            Priority: Critical
>              Labels: easyfix
>             Fix For: 2.7.12, 3.0.1
>
>
> This issue occurs when using the asynchronous conduit (use.async.http.conduit set to true), AND with the environment proxy configuration set (http.proxyHost, http.proxyPort, and http.nonProxyHosts properties set).
> The end of the AsyncHTTPConduit.setupConnection() method calls:
> <code>
>         Proxy p = proxyFactory.createProxy(csPolicy , uri);
>         if (p != null) {
> </code>
> When the http.nonProxyHosts property matches the target server host, then the ProxyFactory.createProxy() method returns Proxy.NO_PROXY, and not null. This means that because p is not null, the next 2 lines are executed:
> <code>
>             InetSocketAddress isa = (InetSocketAddress)p.address();
>             HttpHost proxy = new HttpHost(isa.getHostName(), isa.getPort());
> </code>
> p.address() returns null as expected, which means that the next line (line 200 in release 2.7.6) causes a NullPointerException, and crashes the call.
> The fix would be simple, by replacing:
> <code>
>         if (p != null) {
> </code>
> with
> <code>
>         if (p != null && !p.type() == Proxy.Type.DIRECT) {
> </code>



--
This message was sent by Atlassian JIRA
(v6.2#6252)