Retrofit 2无法解析主机

时间:2016-09-06 15:33:40

标签: android android-manifest retrofit2

在我以前的应用程序版本中,我使用了Apache Client,一切正常并且仍然​​有效。但是,由于性能的提高,我们决定转向Retrofit。问题是我每次都得到“无法解析主机”xxxxxx“:没有与主机名关联的地址”。

我把它放在清单

with temp as (select -1 i union all
 select i+1 i from temp where i < 8) 
select DATEADD(s,-1,DATEADD(mm, DATEDIFF(m,0,GETDATE())+i*-1,0)) from temp

我忘了还有别的吗?

这是网址:https://www.hbapimanager.azure-api.net/Wallet/CheckNumber

P.S。我差不多一周都在苦苦挣扎

已编辑:这是我的retrofitFactory类:

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

这是请求的接口

private static HttpLoggingInterceptor logging = new HttpLoggingInterceptor()
        .setLevel(BuildConfig.DEBUG ? HttpLoggingInterceptor.Level.BODY : HttpLoggingInterceptor.Level.NONE);

private static OkHttpClient.Builder httpClient = new OkHttpClient.Builder()
        .addInterceptor(logging);

private static HttpUrl url = new HttpUrl.Builder()
        .scheme("https")
        .host(Constants.Network.HOST)
        .build();

private static Retrofit.Builder builder =
        new Retrofit.Builder()
                .baseUrl(url)
                .addConverterFactory(GsonConverterFactory.create());

public static <T> T createRetrofitService(final Class<T> clazz) {
    Retrofit retrofit = builder.client(httpClient.build()).build();
    return retrofit.create(clazz);
}

我得到了

    @Headers({
        Constants.Network.HEADER_TYPE,
        Constants.Network.HEADER_KEY
})
@POST(Constants.Network.CHECK_NUMBER)
Call<StatusData> postCheckNumber(@Body CheckNumberPoRD checkNumberPoRD);

@Headers({
        Constants.Network.HEADER_TYPE,
        Constants.Network.HEADER_KEY
})
@GET(Constants.Network.CHECK_NUMBER)
Call<CheckNumberGRD> getCheckNumber(
        @Query("PrimaryKey") String primaryKey,
        @Query("RowKey") String rowKey
);

3 个答案:

答案 0 :(得分:0)

我的问题是我试图向https://www.example.com发送请求。但是,服务器主机中没有www.example.com,只有example.com。

答案 1 :(得分:-1)

HttpUrl baseUrl = new HttpUrl.Builder()
                .scheme("https")
                .host("www.hbapimanager.azure-api.net")
                .encodedPath("/Wallet/")
                .build();

OkHttpClient okHttpClient = new OkHttpClient.Builder()
                .addInterceptor(new AdditionalHttpHeadersInterceptor(headersProvider))
                .addInterceptor(httpLoggingInterceptor)
                .build();

ApiService apiService = new Retrofit.Builder()
                .baseUrl(baseUrl)
                .client(okHttpClient)
                .addConverterFactory(MoshiConverterFactory.create(moshi))
                .build()
                .create(ApiService.class);

ApiService.java

@Headers({
        Constants.Network.HEADER_TYPE,
        Constants.Network.HEADER_KEY
})
@GET(Constants.Network.CHECK_NUMBER)
Call<CheckNumberGRD> getCheckNumber(
        @Query("PrimaryKey") String primaryKey,
        @Query("RowKey") String rowKey
);

Constants.Network.CHECK_NUMBER "CheckNumber"没有斜杠的地方

但是,由于 https ,您可能必须设置自定义 ssl套接字工厂。最简单的方法是下一步:

创建自定义SSL工厂类

public class TLSSocketFactory extends SSLSocketFactory {

    private SSLSocketFactory internalSSLSocketFactory;

    public TLSSocketFactory() {
        SSLContext context = null;
        try {
            context = SSLContext.getInstance("TLS");
            context.init(null, null, null);
        } catch (NoSuchAlgorithmException | KeyManagementException e) {
            //TODO check it and fix
            throw new RuntimeException(e);
        }
        internalSSLSocketFactory = context.getSocketFactory();
    }

    @Override
    public String[] getDefaultCipherSuites() {
        return internalSSLSocketFactory.getDefaultCipherSuites();
    }

    @Override
    public String[] getSupportedCipherSuites() {
        return internalSSLSocketFactory.getSupportedCipherSuites();
    }

    @Override
    public Socket createSocket(Socket s, String host, int port, boolean autoClose) throws IOException {
        return enableTLSOnSocket(internalSSLSocketFactory.createSocket(s, host, port, autoClose));
    }

    @Override
    public Socket createSocket(String host, int port) throws IOException, UnknownHostException {
        return enableTLSOnSocket(internalSSLSocketFactory.createSocket(host, port));
    }

    @Override
    public Socket createSocket(String host, int port, InetAddress localHost, int localPort) throws IOException, UnknownHostException {
        return enableTLSOnSocket(internalSSLSocketFactory.createSocket(host, port, localHost, localPort));
    }

    @Override
    public Socket createSocket(InetAddress host, int port) throws IOException {
        return enableTLSOnSocket(internalSSLSocketFactory.createSocket(host, port));
    }

    @Override
    public Socket createSocket(InetAddress address, int port, InetAddress localAddress, int localPort) throws IOException {
        return enableTLSOnSocket(internalSSLSocketFactory.createSocket(address, port, localAddress, localPort));
    }

    private Socket enableTLSOnSocket(Socket socket) {
        if (socket != null && (socket instanceof SSLSocket)) {
            ((SSLSocket) socket).setEnabledProtocols(new String[]{"TLSv1.1", "TLSv1.2"});
        }
        return socket;
    }
}

和您的自定义X509信任管理器类

public class CustomX509TrustManager implements X509TrustManager {

    @SuppressLint("TrustAllX509TrustManager")
    @Override
    public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
    }

    @SuppressLint("TrustAllX509TrustManager")
    @Override
    public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
    }

    @Override
    public X509Certificate[] getAcceptedIssuers() {
        return new X509Certificate[]{};
    }
}

并创建您的http客户端

OkHttpClient okHttpClient = new OkHttpClient.Builder()
                .sslSocketFactory(new CustomX509TrustManager(), new TLSSocketFactory())
                .addInterceptor(new AdditionalHttpHeadersInterceptor(headersProvider))
                .addInterceptor(httpLoggingInterceptor)
                .build();

答案 2 :(得分:-2)

您肯定会遇到基本网址如下所示的问题:

http://blah.com/v1/blah

您的服务看起来像

@GET("/blah/blah/blah")

但实际上你必须让它看起来像这样:

http://blah.com/v1/blah/

您的服务需要看起来像

@GET("blah/blah/blah")