因为我是新的反应本机,所以如果有任何错误的步骤,让我知道。

我已经按照文档使用命令构建了一个react原生android应用程序

react-native安卓

在设备上运行时,使用了以下命令

react-native运行android

这给了我2 apk文件在我的projectfolder/android/app/build/outputs/apk的输出

现在,当我安装这个apk安装后,它要求一个开发服务器连接到捆绑JS。但我的要求是,用户不需要与开发服务器作斗争,他只需要安装apk,一切都完成了。

已经通过了一些stackoverflow问题,但对构建不需要开发服务器的unsigned apk没有帮助。

你们能帮我找到如何在react native中构建和unsigned apk的方法吗?


当前回答

不使用dev-server生成调试APK

如果您想生成一个调试APK(用于测试),它可以在没有开发服务器的情况下运行。

在你的react原生项目中,去/android/app/src/main创建一个文件夹assets 编辑android >应用> build.gradle

universalApk true  // If true, also generate a universal APK

在react native项目的根目录下运行这个命令

npx react-native bundle --platform android --dev false --entry-file index.js --bundle-output android/app/src/main/assets/index.android.bundle --assets-dest android/app/src/main/res

现在,进入android文件夹:cd android 并且,运行这个命令:./gradlew assembleDebug (如果构建失败,尝试从android studio构建assembleDebug)

做这些事。

如果你想在设备中安装应用程序,只需运行CMD

adb install 'path/add-debug.apk'

其他回答

派对已经很晚了,但至少第一页上的解决方案对我来说都没用。因此,我对react注册的年级任务进行了更深入的研究;

只需添加bundleInDebug: true,如@Er Suman G的回答所示

运行。/gradlew assembleDebug或gradle.bat assembleDebug在你的android文件夹根据你的环境。

这将在android/app/build/outputs/apk/debug中生成可调试的非服务器所需的应用程序

React版本

在根项目目录中

确保你已经有了android/app/src/main/assets/目录,如果没有创建目录,在那之后创建一个新文件并保存为index.android.bundle,然后把你的文件放在这样的android/app/src/main/assets/index.android.bundle中

然后运行这个

react-native bundle --platform android --dev false --entry-file index.js --bundle-output android/app/src/main/assets/index.android.bundle --assets-dest android/app/src/main/res/

cd android && ./gradlew assembleDebug

然后你可以在app/build/outputs/apk/debug/app-debug.apk中获取apk

以防其他人最近遇到同样的问题,我使用React Native 0.59.8(也用RN 0.60测试),我可以确认一些其他答案,以下是步骤:

卸载您设备上安装的应用程序的最新编译版本 运行react-native bundle——platform android——dev false——entry-file index.js——bundle-output android/app/src/main/assets/index.android。Bundle——assets-dest android/app/src/main/res 执行cd android/ && ./gradlew assembleDebug命令 在android/app/build/outputs/apk/debug文件夹中获取你的app-debug.apk

好运!

不使用dev-server生成调试APK

如果您真的想生成一个调试APK(用于测试),它可以在没有开发服务器的情况下运行,那么恭喜您!我来帮你。:) 每个人都说我们需要运行两个命令react-native bundle…然后gradlew assembleDebug,但生成的APK仍然不能在没有开发服务器的情况下工作。经过许多研究和尝试后,我发现我们需要在gradle文件中进行更改(如在步骤2中)。只需遵循以下步骤:

在你的react原生项目中,去/android/app/src/main创建一个文件夹assets 编辑android >应用> build.gradle

project.ext.react = [
    ...
    bundleInDebug: true, // add this line
]

在react native项目的根目录下运行这个命令

react-native bundle --platform android --dev false --entry-file index.js --bundle-output android/app/src/main/assets/index.android.bundle --assets-dest android/app/src/main/res

现在,进入android文件夹:cd android 并且,运行这个命令:gradlew assembleDebug (如果构建失败,尝试从android studio构建assembleDebug)

这将在android/app/build/outputs/apk/debug目录下创建app-debug.apk文件,您可以在没有dev-server的情况下安装和运行该文件。

您需要为调试版本手动创建包。

包调试构建:

#React-Native 0.59
react-native bundle --dev false --platform android --entry-file index.js --bundle-output ./android/app/src/main/assets/index.android.bundle --assets-dest ./android/app/src/main/res

#React-Native 0.49.0+
react-native bundle --dev false --platform android --entry-file index.js --bundle-output ./android/app/build/intermediates/assets/debug/index.android.bundle --assets-dest ./android/app/build/intermediates/res/merged/debug

#React-Native 0-0.49.0
react-native bundle --dev false --platform android --entry-file index.android.js --bundle-output ./android/app/build/intermediates/assets/debug/index.android.bundle --assets-dest ./android/app/build/intermediates/res/merged/debug

然后在捆绑后构建APK:

$ cd android
#Create debug build:
$ ./gradlew assembleDebug
#Create release build:
$ ./gradlew assembleRelease #Generated `apk` will be located at `android/app/build/outputs/apk`

附注:另一种方法可能是修改gradle脚本。