【问题标题】:Android internet access throws IOExceptionAndroid 上网抛出 IOException
【发布时间】:2020-07-24 07:52:29
【问题描述】:

我正在尝试编写一个对网页执行 ping 操作的应用程序,然后它将触发一个操作。

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

我一直在寻找解决 isSBSettingEnabled false 错误的方法,但找不到任何对我有帮助的方法。

我正在三星 M20 智能手机上运行我的应用程序。

【问题讨论】:

  • 始终记录异常。您的详细信息在IOException e。因此,将Log.d("EXEC", "#10 - CATCH"); 更改为Log.e("EXEC", "#10 - CATCH", e);。然后,检查异常及其堆栈跟踪以了解有关您的问题的更多信息。我怀疑它会抱怨默认情况下不允许明文通信,因为您使用的是http 而不是https
  • 谢谢,我按照您的指示进行操作,但实际上不允许使用明文。所以我在AndroidManifest.xml中添加了权限

标签: java android inputstream httpurlconnection ioexception


【解决方案1】:

这在技术上不是错误,因为它会提醒您您没有使用网络安全配置。更多信息请点击此处:Network security configuration: Android Developer Docs

但是,如果您仅限于使用 HTTP,则可以通过将其添加到 AndroidManifext.xml 中的 <application> 标记来允许明文流量来解决连接问题:

android:usesCleartextTraffic="true"

【讨论】:

  • 谢谢,这正是我在@CommonsWave 的帮助下所做的
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2012-06-14
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多