EXPO [Android] [EAS] 启动时构建崩溃
我最近从 SDK 43 迁移到了 Expo SDK 45,并且从经典版本升级到了 EAS CLI,并且我拥有托管工作流程。
当我使用命令
eas build --profile preview --platform android
创建 android 版本时。
它成功创建了版本,但在启动画面时崩溃,没有任何堆栈跟踪。
当我使用开发客户端或 Expo GO 测试版本时,没有任何错误或警告。
在这里我分享我的 package.json
{
"name": "native",
"version": "1.0.0",
"private": "true",
"main": "./index.js",
"scripts": {
"postinstall": "patch-package; cp -f patches/manual/createKeyboardAwareNavigator.js ./node_modules/@react-navigation/native/src",
"start": "expo start --dev-client",
"android": "expo run:android",
"ios": "expo run:ios",
"eject": "expo eject",
"test": "node ./node_modules/jest/bin/jest.js --watchAll",
"prettier": "prettier --write 'src/**/*{.js,.jsx}'",
"lint": "eslint -c ../../.eslintrc 'src' --ext '.js,.jsx'",
"lint-fix": "eslint -c ../../.eslintrc 'src' --ext '.js,.jsx' --fix",
"fix-nav": "cp -f patches/manual/createKeyboardAwareNavigator.js ./node_modules/@react-navigation/native/src"
},
"jest": {
"preset": "jest-expo"
},
"dependencies": {
"@expo/browser-polyfill": "0.0.1-alpha.3",
"@expo/metro-config": "^0.5.1",
"@expo/react-native-action-sheet": "^3.0.3",
"@react-native-community/datetimepicker": "6.1.2",
"@react-native-community/segmented-control": "2.1.1",
"@react-native-picker/picker": "^2.4.8",
"babel-plugin-inline-dotenv": "^1.3.3",
"date-and-time": "2.0.1",
"deprecated-react-native-prop-types": "^3.0.1",
"expo": "^45.0.0",
"expo-app-loading": "~2.0.0",
"expo-battery": "~6.2.0",
"expo-brightness": "~10.2.0",
"expo-camera": "~12.2.0",
"expo-constants": "~13.1.1",
"expo-dev-client": "~1.0.1",
"expo-device": "~4.2.0",
"expo-document-picker": "~10.2.1",
"expo-file-system": "~14.0.0",
"expo-image-manipulator": "~10.3.1",
"expo-image-picker": "~13.1.1",
"expo-linear-gradient": "~11.3.0",
"expo-linking": "~3.1.0",
"expo-local-authentication": "~12.2.0",
"expo-localization": "~13.0.0",
"expo-location": "~14.2.2",
"expo-modules-core": "~0.9.2",
"expo-notifications": "~0.15.4",
"expo-permissions": "~13.2.0",
"expo-radio-button": "^1.0.8",
"expo-screen-capture": "~4.2.0",
"expo-screen-orientation": "~4.2.0",
"expo-splash-screen": "~0.15.1",
"expo-status-bar": "~1.3.0",
"expo-task-manager": "~10.2.1",
"expo-updates": "~0.13.4",
"expo-web-browser": "~10.2.1",
"geolib": "^3.0.4",
"gl-matrix": "^3.3.0",
"i18n-js": "^3.3.0",
"invariant": "^2.2.4",
"lodash": "^4.17.11",
"memoize-one": "^5.1.1",
"mobx": "^4.2.0",
"mobx-persist": "^0.4.1",
"mobx-react": "^5.0.0",
"moment": "^2.29.1",
"moment-timezone": "^0.5.31",
"native-base": "2.13.8",
"patch-package": "^6.2.0",
"postinstall-postinstall": "^2.0.0",
"prop-types": "^15.7.2",
"react": "17.0.2",
"react-dom": "17.0.2",
"react-native": "0.68.2",
"react-native-btr": "^1.1.4",
"react-native-calendars": "^1.1254.0",
"react-native-chart-kit": "^4.0.0",
"react-native-datepicker": "^1.7.2",
"react-native-floating-action": "^1.20.0",
"react-native-geocoding": "^0.5.0",
"react-native-gesture-handler": "~2.2.1",
"react-native-get-random-values": "~1.8.0",
"react-native-gifted-chat": "0.16.3",
"react-native-keyboard-aware-scroll-view": "^0.9.3",
"react-native-loading-spinner-overlay": "^2.0.0",
"react-native-maps": "0.30.2",
"react-native-masked-text": "^1.12.3",
"react-native-modal": "^11.10.0",
"react-native-multiple-select": "^0.5.9",
"react-native-options-menu": "^2.0.2",
"react-native-paper": "4.12.0-alpha.0",
"react-native-picker-select": "7.0.0",
"react-native-root-toast": "3.3.0",
"react-native-screens": "~3.11.1",
"react-native-slider": "^0.11.0",
"react-native-svg": "12.3.0",
"react-native-svg-transformer": "^0.14.3",
"react-native-swipe-gestures": "^1.0.5",
"react-native-table-component": "^1.2.1",
"react-native-tableview-simple": "^2.4.1",
"react-native-typography": "^1.4.0",
"react-native-vector-icons": "^8.1.0",
"react-native-web": "0.17.7",
"react-native-webview": "11.18.1",
"react-navigation": "3.11.0",
"rn-pdf-reader-js": "^4.1.1",
"rn-tooltip": "^3.0.0",
"sentry-expo": "^4.2.0",
"socket.io-client": "^1.7.1",
"superagent": "^5.0.7",
"superagent-promise": "^1.1.0",
"uuidv4": "^6.2.13"
},
"devDependencies": {
"babel-eslint": "^10.0.3",
"babel-preset-expo": "~9.1.0",
"eslint": "^5.16.0",
"eslint-config-airbnb": "^17.1.0",
"eslint-plugin-import": "^2.14.0",
"eslint-plugin-jsx-a11y": "^6.1.2",
"eslint-plugin-react": "^7.11.1",
"jest-expo": "^45.0.0",
"prettier": "^2.0.5",
"@babel/core": "^7.12.9"
}
}
app.json
{
"expo": {
"name": "Norsktimeregister",
"slug": "native-norsk-2",
"privacy": "public",
"entryPoint": "./index.js",
"platforms": [
"ios",
"android"
],
"orientation": "default",
"version": "1.16.1",
"icon": "./assets/images/app-icon2.png",
"splash": {
"image": "./assets/images/splash-logo.png",
"resizeMode": "contain",
"backgroundColor": "#222D93"
},
"hooks": {
"postPublish": [
{
"file": "sentry-expo/upload-sourcemaps",
"config": {
"organization": "Norsktime",
"project": "NorsktimeRN",
"authToken": "************************************************"
}
}
]
},
"updates": {
"enabled": false
},
"assetBundlePatterns": [
"**/*"
],
"ios": {
"bundleIdentifier": "com.tidogkontroll.norsktime",
"googleServicesFile": "./GoogleService-Info.plist",
"infoPlist": {
"NSCameraUsageDescription": "Norsktimeregister uses the camera to immediately add images to time logs.",
"NSPhotoLibraryUsageDescription": "Norsktimeregister needs access to your photo library to let you add images to time logs.",
"NSLocationAlwaysUsageDescription": "Norsktimeregister needs to access your location to automatically stamp you in/out.",
"NSLocationUsageDescription": "Norsktimeregister needs to access your location to automatically stamp you in/out.",
"NSLocationWhenInUseUsageDescription": "Norsktimeregister needs to access your location to automatically stamp you in/out.",
"NSLocationAlwaysAndWhenInUseUsageDescription": "Norsktimeregister needs to access your location to automatically stamp you in/out.",
"UIBackgroundModes": [
"location",
"fetch"
],
"LSApplicationQueriesSchemes": [
"http",
"https"
]
},
"supportsTablet": true,
"config": {
"googleMapsApiKey": "********************",
"usesNonExemptEncryption": false
},
"usesIcloudStorage": true,
"requireFullScreen": true,
"buildNumber": "1"
},
"android": {
"googleServicesFile": "./google-services.json",
"config": {
"googleMaps": {
"apiKey": "**************************"
}
},
"versionCode": 136,
"package": "com.tidogkontroll.norsktime",
"permissions": [
"ACCESS_COARSE_LOCATION",
"ACCESS_FINE_LOCATION",
"CAMERA",
"MANAGE_DOCUMENTS",
"READ_EXTERNAL_STORAGE",
"WRITE_EXTERNAL_STORAGE",
"RECEIVE_BOOT_COMPLETED",
"WRITE_SETTINGS"
],
"softwareKeyboardLayoutMode": "pan",
"useNextNotificationsApi": true
},
"extra": {
"eas": {
"projectId": "*************************"
}
}
}
}
eas.json
{
"cli": {
"version": ">= 2.9.0"
},
"build": {
"development": {
"developmentClient": true,
"distribution": "internal",
"android": {
"buildType": "apk"
},
"ios": {
"simulator": true
}
},
"preview": {
"distribution": "internal",
"android": {
"buildType": "apk"
},
"ios": {
"simulator": true
}
},
"production": {}
},
"submit": {
"production": {}
}
}
我们已经测试了不同的方法,例如创建自定义入口点和默认入口点。
有人可以看一下吗,任何帮助都将不胜感激。 提前致谢。
在您的 Android 设备上启用调试模式(如果您不知道如何操作,请在 Google/YouTube 上搜索)。完成后,使用 USB 数据线将其连接到您的计算机。
然后通过在命令提示符中输入命令“adb”确保您的计算机上安装了 adb(Android 调试桥)。如果没有,请安装它。
然后输入命令“adb devices”以查看您的 Android 设备是否对 adb 可见。如果您看到您的设备,请输入此命令:
adb logcat“*:E”
“adb”允许与 Android 设备通信。 “logcat”显示 Android 设备的系统和应用程序日志。 “*:E”:仅显示具有错误严重性级别的日志(E 代表错误)。
然后在您的手机上启动您的应用程序,一旦它崩溃,请在终端中检查您的日志。您应该看到一行:
--------- 崩溃开始
然后是有关崩溃的其他信息。以我为例,我有:
--------- 崩溃开始 严重异常:create_react_context java.lang.RuntimeException:无法加载脚本。确保您正在运行 Metro blablabla...
它应该会为您提供有关您的问题的更多信息。
我遇到了这个问题,这是由于启动画面引起的。请尝试从 app.json 中删除启动画面配置。
我必须安装“react-native-screens”、“react-native-safe-are-of-context”,然后再次在 EAS 上构建并最终成功。希望这对你有帮助。