简体   繁体   English

使用 Axios 或在 android 中获取时反应本机抛出网络错误

[英]React Native throw Network Error when using Axios or Fetch in android

Hi i have this https api that behaves kinda weird, so i have this fetch/api function like this嗨,我有这个 https api,它的行为有点奇怪,所以我有这个 fetch/api function 像这样

my react native version我的反应原生版本

 "axios": "^0.21.1",
 "prop-types": "^15.7.2",
 "react": "17.0.1",
 "react-native": "0.64.1",

 try { let result = await axios({ method: 'POST', url: 'https://my.service.com/authService/accounts/login', data: { userid: 'username', password: 'password', }, headers: { ContentType: 'application/JSON', Accept: 'application/json', }, }); console.log(result); } catch (error) { console.log(error, 'error'); }

so when i test it with iOS simulator it works just fine.所以当我用 iOS 模拟器测试它时,它工作得很好。 but when i test it with android it gives me this error但是当我用 android 测试它时,它给了我这个错误在此处输入图像描述

is there any specific configuration for this case, (i've already use cleartextTrafficPermitted="true" but its not working since my api is HTTPS).是否有针对这种情况的任何特定配置,(我已经使用 cleartextTrafficPermitted="true" 但它不起作用,因为我的 api 是 HTTPS)。

react-native-ssl-pinning it works on android but not working in iOS. react-native-ssl-pinning 它适用于 android 但不适用于 iOS。 and i dont really want to use theese library since autolinking is not working而且我真的不想使用这些库,因为自动链接不起作用

update: i tried to implement this solution更新:我试图实施这个解决方案

package com.test; // replace app-name

import com.facebook.react.modules.network.OkHttpClientFactory;
import com.facebook.react.modules.network.OkHttpClientProvider;
import com.facebook.react.modules.network.ReactCookieJarContainer;

import java.util.Collections;
import java.util.concurrent.TimeUnit;
import java.net.*;
import java.io.*;
import okhttp3.OkHttpClient;
import okhttp3.*;
import java.util.List;
import java.util.ArrayList;

public class CustomClientFactory implements OkHttpClientFactory {

        @Override
        public OkHttpClient createNewNetworkModuleClient() {
        ConnectionSpec spec = new ConnectionSpec.Builder(ConnectionSpec.MODERN_TLS)
                .tlsVersions(TlsVersion.TLS_1_2)
                .cipherSuites(CipherSuite.TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256,
                                CipherSuite.TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256,
                                CipherSuite.TLS_DHE_RSA_WITH_AES_128_GCM_SHA256,
                                CipherSuite.TLS_ECDHE_PSK_WITH_AES_128_CBC_SHA,
                                CipherSuite.TLS_ECDHE_ECDSA_WITH_CHACHA20_POLY1305_SHA256)
                .build();

        List<ConnectionSpec> specs = new ArrayList<>();
        specs.add(spec);
        specs.add(ConnectionSpec.COMPATIBLE_TLS);
        specs.add(ConnectionSpec.CLEARTEXT);
        OkHttpClient.Builder client = new OkHttpClient.Builder().connectionSpecs(specs)
                .connectTimeout(0, TimeUnit.MILLISECONDS).readTimeout(0, TimeUnit.MILLISECONDS)
                .writeTimeout(0, TimeUnit.MILLISECONDS).cookieJar(new ReactCookieJarContainer());
        return OkHttpClientProvider.enableTls12OnPreLollipop(client).build();
        }
}
package com.test;

import android.app.Application;
import android.content.Context;
import com.facebook.react.PackageList;
import com.facebook.react.ReactApplication;
import com.facebook.react.ReactInstanceManager;
import com.facebook.react.ReactNativeHost;
import com.facebook.react.ReactPackage;
import com.facebook.soloader.SoLoader;
import java.lang.reflect.InvocationTargetException;
import java.util.List;
import android.os.Build;
import com.test.CustomClientFactory;  // replace <app-name>
import com.facebook.react.modules.network.OkHttpClientProvider;
import okhttp3.OkHttpClient;

public class MainApplication extends Application implements ReactApplication {

  private final ReactNativeHost mReactNativeHost =
      new ReactNativeHost(this) {
        @Override
        public boolean getUseDeveloperSupport() {
          return BuildConfig.DEBUG;
        }

        @Override
        protected List<ReactPackage> getPackages() {
          @SuppressWarnings("UnnecessaryLocalVariable")
          List<ReactPackage> packages = new PackageList(this).getPackages();
          // Packages that cannot be autolinked yet can be added manually here, for example:
          // packages.add(new MyReactNativePackage());
          return packages;
        }

        @Override
        protected String getJSMainModuleName() {
          return "index";
        }
      };

  @Override
  public ReactNativeHost getReactNativeHost() {
    return mReactNativeHost;
  }

  @Override
  public void onCreate() {
    super.onCreate();
    SoLoader.init(this, /* native exopackage */ false);
      OkHttpClientProvider.setOkHttpClientFactory(new CustomClientFactory());
    initializeFlipper(this, getReactNativeHost().getReactInstanceManager());
    
  }

  /**
   * Loads Flipper in React Native templates. Call this in the onCreate method with something like
   * initializeFlipper(this, getReactNativeHost().getReactInstanceManager());
   *
   * @param context
   * @param reactInstanceManager
   */
  private static void initializeFlipper(
      Context context, ReactInstanceManager reactInstanceManager) {
    if (BuildConfig.DEBUG) {
      try {
        /*
         We use reflection here to pick up the class that initializes Flipper,
        since Flipper library is not available in release mode
        */
        Class<?> aClass = Class.forName("com.test.ReactNativeFlipper");
        aClass
            .getMethod("initializeFlipper", Context.class, ReactInstanceManager.class)
            .invoke(null, context, reactInstanceManager);
      } catch (ClassNotFoundException e) {
        e.printStackTrace();
      } catch (NoSuchMethodException e) {
        e.printStackTrace();
      } catch (IllegalAccessException e) {
        e.printStackTrace();
      } catch (InvocationTargetException e) {
        e.printStackTrace();
      }
    }
  }
}

with axios but the error still exists使用 axios 但错误仍然存在axios

with fetch带取在此处输入图像描述

Check if there is internet permission is added in /android/app/src/main/AndroidManifext.xml检查 /android/app/src/main/AndroidManifext.xml 中是否添加了互联网权限


<manifest xmlns:android="http://schemas.android.com/apk/res/android"
  package="com.exampleapp">
     
    <uses-permission android:name="android.permission.INTERNET" />
 
    <application
      android:name=".MainApplication"
      android:label="@string/app_name"
      android:icon="@mipmap/ic_launcher"
      android:roundIcon="@mipmap/ic_launcher_round"
      android:allowBackup="false"
      android:theme="@style/AppTheme">
      <activity
        android:name=".MainActivity"
        android:label="@string/app_name"
        android:configChanges="keyboard|keyboardHidden|orientation|screenSize|uiMode"
        android:launchMode="singleTask"
        android:windowSoftInputMode="adjustResize">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
      </activity>
    </application>
</manifest>

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

相关问题 获取 .NET CORE 3 webApi 时反应本机抛出网络错误 - React Native Throw Network Error when Fetch .NET CORE 3 webApi 在 React Native 中使用 axios 时出现网络错误 - Network Error when use axios in React Native 反应原生获取抛出异常网络请求在Android上失败 - React native fetch throw exception Network request fail on android React Native android fetch 网络请求错误 - React Native android fetch network request error 错误:在 React Native 中使用 axios 的网络错误,仅在 iOS 和 Android 中出现 - Error: Network Error using axios in React Native, issue in only in iOS and Android React Native https axios resquest 在 Android 上出现网络错误,但在 iOS 上没有 - React Native https axios resquest gets Network Error on Android but not iOS React Native Axios 上传图片返回 Network Error on Android - React Native Axios upload image return Network Error on Android 在 Android 物理设备上反应本机 axios 后请求网络错误 - React native axios post request network error on Android physical device 使用 axios 访问在 localhost 上运行的 api 时,React Native 应用程序 GET 请求导致网络错误 - React Native app GET request resulting in network error when using axios to reach for api running on localhost 错误:网络错误 Axios - Image React Native - Error: Network Error Axios - Image React Native
 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM