Вот мой результат вызова RestApi RestApi
В моем приложении для Android я использую библиотеку модернизации для вызова этого API для отображения элементов в моем приложении для Android, вот вызов API в Android
package com.aditmsolutions.www.foodie;
import java.util.List;
import retrofit2.Call;
import retrofit2.http.GET;
public interface Api {
String BASE_URL = "https://10.0.2.2:51087/api/";
@GET("items")
Call<List<Item>> getItems();
}
Когда я запускаю свое приложение, появляется сообщение об ошибке «Ошибка HandShake». ошибка Пожалуйста помоги
А вот и просмотр журнала
И это код для получения предметов
private void getItems() {
Retrofit retrofit = new Retrofit.Builder()
.baseUrl(Api.BASE_URL)
.addConverterFactory(GsonConverterFactory.create()) //Here we are using the GsonConverterFactory to directly convert json data to object
.build();
Api api = retrofit.create(Api.class);
Call<List<Item>> call = api.getItems();
call.enqueue(new Callback<List<Item>>() {
@Override
public void onResponse(Call<List<Item>> call, Response<List<Item>> response) {
List<Item> itemList = response.body();
//Creating an String array for the ListView
String[] items = new String[itemList.size()];
//looping through all the heroes and inserting the names inside the string array
for (int i = 0; i < itemList.size(); i++) {
items[i] = itemList.get(i).getTitle();
}
//displaying the string array into listview
listView.setAdapter(new ArrayAdapter<String>(getApplicationContext(), android.R.layout.simple_list_item_1, items));
}
@Override
public void onFailure(Call<List<Item>> call, Throwable t) {
Toast.makeText(getApplicationContext(), t.getMessage(), Toast.LENGTH_SHORT).show();
}
});
}
Также класс публикации и ответ json и ошибка Logcat
Ответ Json прикреплен как изображение
поделитесь кодом, по которому вы звоните getItems(), а также вызовите модернизацию
вероятно не имеет отношения к дооснащению. Принимает ли базовый URL-адрес HTTPS-соединения? сначала попробуйте с http и посмотрите, работает ли он
@OmarAlHalabi, спасибо, что ошибка рукопожатия исчезла, когда я включил соединение https, но теперь это исключение java.security.cert.CertPathValidatorException: Якорь доверия для пути сертификации не найден
Ваша проблема в проверке https certificate. Если вы хотите принять весь сертификат испорченный / непроверенный, используйте этот клиент в своем проекте. Ваша проблема будет решена.
Строитель реторифта:
Retrofit retrofit = new Retrofit.Builder()
.baseUrl(Api.BASE_URL)
.addConverterFactory(GsonConverterFactory.create()) //Here we are using the GsonConverterFactory to directly convert json data to object
.client(UnsafeOkHttpClient.getUnsafeOkHttpClient())
.build();
Небезопасный клиент:
public class UnsafeOkHttpClient {
public static OkHttpClient getUnsafeOkHttpClient() {
try {
// Create a trust manager that does not validate certificate chains
final TrustManager[] trustAllCerts = new TrustManager[] {
new X509TrustManager() {
@Override
public void checkClientTrusted(java.security.cert.X509Certificate[] chain, String authType) throws CertificateException {
}
@Override
public void checkServerTrusted(java.security.cert.X509Certificate[] chain, String authType) throws CertificateException {
}
@Override
public java.security.cert.X509Certificate[] getAcceptedIssuers() {
return new java.security.cert.X509Certificate[]{};
}
}
};
// Install the all-trusting trust manager
final SSLContext sslContext = SSLContext.getInstance("SSL");
sslContext.init(null, trustAllCerts, new java.security.SecureRandom());
// Create an ssl socket factory with our all-trusting manager
final SSLSocketFactory sslSocketFactory = sslContext.getSocketFactory();
OkHttpClient.Builder builder = new OkHttpClient.Builder();
builder.sslSocketFactory(sslSocketFactory, (X509TrustManager)trustAllCerts[0]);
builder.hostnameVerifier(new HostnameVerifier() {
@Override
public boolean verify(String hostname, SSLSession session) {
return true;
}
});
OkHttpClient okHttpClient = builder.build();
return okHttpClient;
} catch (Exception e) {
throw new RuntimeException(e);
}
}
}
Спасибо за ответ, но не могли бы вы прояснить, как добавить / использовать этот класс? Я имею в виду, что я создал этот класс в своем проекте, но он не сработал, поскольку такое же исключение «java.security.cert.CertPathValidatorException: Якорь доверия для пути сертификации не найден» снова появляется, пожалуйста, скажите мне после добавления этого класса, где и как мне использовать этот / вызвать его метод?
__trustAllHttpsCertificates () вызывает этот метод
опубликуйте свою полную ошибку с помощью stacktrace