Я не могу использовать RestApi в приложении для Android

Вот мой результат вызова 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();
        }
    });
}

опубликуйте свою полную ошибку с помощью stacktrace

userI 31.07.2018 12:39

Также класс публикации и ответ json и ошибка Logcat

Quick learner 31.07.2018 12:40

Ответ Json прикреплен как изображение

Asim Javaid 31.07.2018 12:42

поделитесь кодом, по которому вы звоните getItems(), а также вызовите модернизацию

Navneet Krishna 31.07.2018 12:50

вероятно не имеет отношения к дооснащению. Принимает ли базовый URL-адрес HTTPS-соединения? сначала попробуйте с http и посмотрите, работает ли он

Omar El Halabi 31.07.2018 12:54

@OmarAlHalabi, спасибо, что ошибка рукопожатия исчезла, когда я включил соединение https, но теперь это исключение java.security.cert.CertPathValidatorException: Якорь доверия для пути сертификации не найден

Asim Javaid 31.07.2018 13:18
0
6
77
1

Ответы 1

Ваша проблема в проверке 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: Якорь доверия для пути сертификации не найден» снова появляется, пожалуйста, скажите мне после добавления этого класса, где и как мне использовать этот / вызвать его метод?

Asim Javaid 31.07.2018 21:29

__trustAllHttpsCertificates () вызывает этот метод

GolamMazid Sajib 01.08.2018 05:43

Другие вопросы по теме