在我以前的应用程序版本中,我使用了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
);
答案 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")