尽管在清单中启用了明文流量,Android 仍无法发送请求

问题描述

在尝试了许多常见解决方案后,我一直使用 unirest 调用天气 API (https://rapidapi.com/community/api/open-weather-map/),但它仍然提供错误

这里重新创建了导致错误的原因。

// Java
    @RequiresApi(api = VERSION_CODES.O)
    public void GetWeather(View view) throws UnirestException {
        Thread thread = new Thread(new Runnable() {
            @Override
            public void run() {
                HttpResponse<JsonNode> response = Unirest.get("https://community-open-weather-map.p.rapidapi.com/find?q=london&cnt=0&mode=null&lon=0&type=link%2C%20accurate&lat=0&units=imperial%2C%20metric")
                        .header("x-rapidapi-key","<KEY>")
                        .header("x-rapidapi-host","community-open-weather-map.p.rapidapi.com")
                        .asJson();

                System.out.println(response.getBody());
                System.out.println("Test");
            }
        });
        thread.start();
    }

以及它造成的错误

2021-07-03 20:59:40.553 15665-15783/com.example.weather E/AndroidRuntime:致命异常:Thread-2 进程:com.example.weather,PID:15665 java.lang.NoSuchFieldError: 没有 Lorg/apache/http/conn/ssl/AllowAllHostnameVerifier 类型的静态字段 INSTANCE;在类 Lorg/apache/http/conn/ssl/AllowAllHostnameVerifier 中;或其超类('org.apache.http.conn.ssl.AllowAllHostnameVerifier' 的声明出现在 /system/framework/framework.jar!classes4.dex 中) 在 org.apache.http.conn.ssl.SSLConnectionSocketFactory.(SSLConnectionSocketFactory.java:151) 在 org.apache.http.conn.ssl.SSLConnectionSocketFactory.getSocketFactory(SSLConnectionSocketFactory.java:194) 在 kong.unirest.apache.SecurityConfig.createDefaultRegistry(SecurityConfig.java:85) 在 kong.unirest.apache.SecurityConfig.buildSocketFactory(SecurityConfig.java:75) 在 kong.unirest.apache.SecurityConfig.createManager(SecurityConfig.java:59) 在 kong.unirest.apache.ApacheClient.(ApacheClient.java:54) 在 kong.unirest.-$$Lambda$LzMzt6m8SiUmve_yOIZRwHx_kH8.apply(未知来源:4) 在 kong.unirest.Config.buildClient(Config.java:755) 在 kong.unirest.Config.getClient(Config.java:740) 在 kong.unirest.BaseRequest.asJson(BaseRequest.java:241) 在 com.example.weather.MainActivity$1.run(MainActivity.java:43) 在 java.lang.Thread.run(Thread.java:923) 2021-07-03 20:59:40.645 15665-15783/com.example.weather I/Process:发送信号。 PID:15665 SIG:9

我试图解决这个问题:

  • 如上所示,我首先尝试对请求进行线程化
  • 然后是@RequiresApi(api = VERSION_CODES.O)
  • 在 androidManifest 中我添加了:
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    android:usesCleartextTraffic="true">
<?xml version="1.0" encoding="utf-8"?>
<network-security-config>
    <base-config cleartextTrafficPermitted="true" >
    </base-config>
</network-security-config>

为了检查请求是否有问题,我在能够返回数据的 IntelliJ 中运行它,那么我错过了什么?

或者我不应该将 Unirest 与 android 一起使用,我过去曾使用过改造,虽然 Unirest 似乎更简洁,但这种方法奏效了。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...