react-native - 在 react-native 和 native-android 之间设置桥梁后,apk 不起作用。但虚拟完成
问题描述
我应该从 native-android 调用函数到 react-native,所以我设置了 bridge。在设置桥之前,apk 运行和虚拟运行运行良好。
但是设置后,vertual run也可以,但是apk run不起作用。
我找不到原因。
KeyStoreApi.java
package com.tovidapp;
import com.facebook.react.bridge.Callback;
import com.facebook.react.bridge.ReactContextBaseJavaModule;
import com.facebook.react.bridge.ReactApplicationContext;
import com.facebook.react.bridge.ReactMethod;
import com.facebook.react.uimanager.IllegalViewOperationException;
public class KeyStoreApi extends ReactContextBaseJavaModule {
public KeyStoreApi(ReactApplicationContext reactContext){
super(reactContext);
}
@Override
public String getName(){
return "KeyStoreApi";
}
@ReactMethod
public void sayHi(Callback errCallBack, Callback successCallBack){
try{
System.out.println("Hello, i am from java");
successCallBack.invoke("Callback: Greeting from java");;
}catch (IllegalViewOperationException e){
errCallBack.invoke(e.getMessage());
}
}
}
KeyStoreApiPackage.java
package com.tovidapp;
import com.facebook.react.ReactPackage;
import com.facebook.react.bridge.NativeModule;
import com.facebook.react.bridge.ReactApplicationContext;
import com.facebook.react.uimanager.ViewManager;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class KeyStoreApiPackage implements ReactPackage {
@Override
public List<ViewManager> createViewManagers(ReactApplicationContext reactContext){
return Collections.emptyList();
}
@Override
public List<NativeModule> createNativeModules(ReactApplicationContext reactContext){
List<NativeModule> modules = new ArrayList<>();
modules.add(new KeyStoreApi(reactContext));
return modules;
}
}
构建等级
apply plugin: "com.android.application"
import com.android.build.OutputFile
project.ext.react = [
entryFile: "index.js"
]
apply from: "../../node_modules/react-native/react.gradle"
def enableSeparateBuildPerCPUArchitecture = false
def enableProguardInReleaseBuilds = false
android {
compileSdkVersion rootProject.ext.compileSdkVersion
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
defaultConfig {
applicationId "com.tovidapp"
minSdkVersion rootProject.ext.minSdkVersion
targetSdkVersion rootProject.ext.targetSdkVersion
versionCode 1
versionName "1.0"
}
signingConfigs {
release {
if (project.hasProperty('MYAPP_RELEASE_STORE_FILE')) {
storeFile file(MYAPP_RELEASE_STORE_FILE)
storePassword MYAPP_RELEASE_STORE_PASSWORD
keyAlias MYAPP_RELEASE_KEY_ALIAS
keyPassword MYAPP_RELEASE_KEY_PASSWORD
}
}
}
splits {
abi {
reset()
enable enableSeparateBuildPerCPUArchitecture
universalApk false // If true, also generate a universal APK
include "armeabi-v7a", "x86", "arm64-v8a", "x86_64"
}
}
buildTypes {
release {
minifyEnabled enableProguardInReleaseBuilds
proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro"
signingConfig signingConfigs.release
}
}
// applicationVariants are e.g. debug, release
applicationVariants.all { variant ->
variant.outputs.each { output ->
// For each separate APK per architecture, set a unique version code as described here:
// http://tools.android.com/tech-docs/new-build-system/user-guide/apk-splits
def versionCodes = ["armeabi-v7a":1, "x86":2, "arm64-v8a": 3, "x86_64": 4]
def abi = output.getFilter(OutputFile.ABI)
if (abi != null) { // null for the universal-debug, universal-release variants
output.versionCodeOverride =
versionCodes.get(abi) * 1048576 + defaultConfig.versionCode
}
}
}
}
dependencies {
implementation project(':react-native-youtube')
implementation project(':react-native-vector-icons')
implementation project(':react-native-gesture-handler')
implementation fileTree(dir: "libs", include: ["*.jar"])
implementation "com.android.support:appcompat-v7:${rootProject.ext.supportLibVersion}"
implementation "com.facebook.react:react-native:+" // From node_modules
}
// Run this once to be able to run the application with BUCK
// puts all compile dependencies into folder libs for BUCK to use
task copyDownloadableDepsToLibs(type: Copy) {
from configurations.compile
into 'libs'
}
调用.js
import React, {Component} from 'react';
import {View, Text, NativeModules, TouchableOpacity,} from 'react-native';
const keyStoreApi = NativeModules.KeyStoreApi;
class Account extends Component {
async sayHiFromJava() {
keyStoreApi.sayHi(err => {
alert(err);
}, msg => {
alert(msg);
})
}
render() {
return (
<View>
<TouchableOpacity onPress={this.sayHiFromJava}>
<Text>TEST</Text>
</TouchableOpacity>
</View>
);
}
}
export default Account;
package.json 中的脚本
"android-apk": "react-native run-android --variant=release",
"android-virtual": "react-native run-android",
"android-build": "rm android/app/build/outputs/apk/release/app-release.apk & cd android && ./gradlew assembleRelease",
结果图片
- 在apk中
- 在简单的虚拟机中
解决方案
推荐阅读
- amazon-web-services - 跨账户 Lambda 到 API 网关设置
- javascript - React Router - 处理来自服务器和渲染组件的 403 响应
- vue.js - 在 render() 中以编程方式访问 Vue 过滤器
- mysql - 运行 MYSQL 生成数据库
- java - 在循环中将 1 添加到 Integer.MAX_VALUE 会导致意外行为(而不是它转到 Integer.MIN_VALUE 的行为)
- c - 如果我 printf 一个没有匹配参数的整数,具体确定输出的是什么?
- exception - React 和 sequelize 错误处理以显示来自前端的消息
- javascript - Openlayers 3 地图,如何在没有焦点的情况下刷新
- java - 将元素分配给空数组
- javascript - 测试使用 mongoDB 和 mocha/chai 的 ejs/nodejs 函数