Android inte rnet доступ вызывает IOException - PullRequest
0 голосов
/ 11 апреля 2020

Я пытаюсь написать приложение для проверки связи с веб-страницей, которое затем запустит действие.

package com.anton.lightcontrol;

import android.graphics.Color;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Switch;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;

import javax.net.ssl.HttpsURLConnection;

public class MainActivity extends AppCompatActivity {

    Switch onOffSwitch;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        onOffSwitch = (Switch) findViewById(R.id.onOffSwitch);
        onOffSwitch.setChecked(true);
        onOffSwitch.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if (onOffSwitch.isChecked()==true) {
                    onOffSwitch.setTextColor(Color.GREEN);
                    LightConnection("http://raspberrypi/toggle_on.py");



                }
                else if (onOffSwitch.isChecked()==false){
                    onOffSwitch.setTextColor(Color.RED);
                    LightConnection("http://raspberrypi/toggle_off.py");

                }
            }
        });
    }

    private void LightConnection(final String accessUrl){
        (new Thread(new Runnable() {
            @Override
            public void run() {
                try{
                Log.d("EXEC", "#1");
                URL url = new URL(accessUrl);
                Log.d("EXEC", "#2");
                HttpURLConnection conn = (HttpURLConnection) url.openConnection();
                Log.d("EXEC", "#3");

                InputStreamReader input = new InputStreamReader(conn.getInputStream(), "utf-8");
                Log.d("EXEC", "#4");

                BufferedReader reader = new BufferedReader(input,2000);
                Log.d("EXEC", "#5");
                String line = reader.readLine();
                Log.d("EXEC", "#6");


            }
                catch (IOException e){
                    Log.d("EXEC", "#10 - CATCH");
                    onOffSwitch.setTextColor(Color.YELLOW);
                }

            }
        })).start();
    }
}

Мой отладочный вывод выглядит следующим образом:

D/EXEC: #1
D/EXEC: #2
D/NetworkSecurityConfig: No Network Security Config specified, using platform default
D/EXEC: #3
I/System.out: (HTTPLog)-Static: isSBSettingEnabled false
D/EXEC: #10 - CATCH

I Я искал решение для ошибки isSBSettingEnabled false, но не смог найти ничего, что помогло бы мне.

Я запускаю свое приложение на смартфоне Samsung M20.

1 Ответ

1 голос
/ 11 апреля 2020

Технически это не ошибка, так как он предупреждает вас, что вы не используете конфигурацию безопасности сети. Подробнее об этом здесь: Конфигурация безопасности сети: Android Документы для разработчиков .

Однако, если вы ограничены использованием HTTP, вы можете решить проблемы с подключением, разрешив трафик с открытым текстом c добавив это в ваш <application> тег в AndroidManifext.xml:

android:usesCleartextTraffic="true"

...