Невозможно сделать запрос https от Android - ошибка - соединение закрыто - PullRequest
0 голосов
/ 06 октября 2019

Я пытаюсь запросить https от Android к конечной точке API 'https://api_chamakah.ivilleinc.com/'. Однако, независимо от того, какие варианты я пытаюсь получить, я получаю "Соединение близко к узлу", запросы от администратора почты и браузера работают нормально.

String webUrl = EndPointMethods.BASE_URL  + EndPointMethods.CATEGORIES;
                URL url = new URL(webUrl);
                HttpsURLConnection urlConnection = (HttpsURLConnection)url.openConnection();
                try {
                    urlConnection.setSSLSocketFactory(new SSLSocketFactoryExtended());
                } catch (NoSuchAlgorithmException e) {  e.printStackTrace();  }
                catch (KeyManagementException e) { e.printStackTrace();}

                urlConnection.setRequestMethod("GET");
                BufferedReader in = new BufferedReader(new InputStreamReader(urlConnection.getInputStream()));
                String inputLine;
                StringBuffer response = new StringBuffer();

                while ((inputLine = in.readLine()) != null) {
                    response.append(inputLine);
                }
                in.close();

Ответы [ 2 ]

0 голосов
/ 07 октября 2019

После использования этого инструмента я считаю, что проблема заключается в подчеркивании имени хоста. См. эту ветку , которая подтверждает ваш обходной путь для вашего JDK и может объяснить, почему другие инструменты не затрагиваются.

0 голосов
/ 06 октября 2019

Вызов этого метода перед выполнением вызова Https решил проблему, однако я до сих пор не понимаю, в чем собственно проблема и как этот метод решает проблему, может кто-нибудь объяснить мне, что эта функция достигает в отношении рассматриваемой проблемы

private void trustEveryone(Context appContext) {

        try{

            ProviderInstaller.installIfNeeded(appContext);

            HttpsURLConnection.setDefaultHostnameVerifier(new HostnameVerifier(){

                public boolean verify(String hostname, SSLSession session) {
                    return true;
                }});

            SSLContext context = SSLContext.getInstance("TLS");

            context.init(null, new X509TrustManager[]{new X509TrustManager(){

                public void checkClientTrusted(X509Certificate[] chain, String authType) {}
                public void checkServerTrusted(X509Certificate[] chain, String authType) {}
                public X509Certificate[] getAcceptedIssuers() {
                    return new X509Certificate[0];
                }}}, new SecureRandom());

            HttpsURLConnection.setDefaultSSLSocketFactory(
                    context.getSocketFactory());

        } catch (
            NoSuchAlgorithmException |  GooglePlayServicesNotAvailableException | KeyManagementException |  GooglePlayServicesRepairableException e) {
            e.printStackTrace();
        }

    }

Спасибо

...