@H_404_0@运行react-native run android时没有配置 ANDROID_HOME导致的错误
@H_404_0@错误日志
@H_404_0@java.lang.RuntimeException: SDK location not found. Define location with sdk.dir in the local.properties file or with an ANDROID_HOME environment variable.
@H_404_0@at com.android.build.gradle.internal.SdkHandler.getAndCheckSdkFolder(SdkHandler.java:102)
@H_404_0@at com.android.build.gradle.internal.SdkHandler.getSdkLoader(SdkHandler.java:112)
@H_404_0@at com.android.build.gradle.internal.SdkHandler.initTarget(SdkHandler.java:86)
@H_404_0@at com.android.build.gradle.BasePlugin.ensureTargetSetup(BasePlugin.groovy:507)
@H_404_0@at com.android.build.gradle.BasePlugin.createAndroidTasks(BasePlugin.groovy:455)
@H_404_0@at com.android.build.gradle.BasePlugin$_createTasks_closure13_closure17.doCall(BasePlugin.groovy:415)
@H_404_0@at com.android.build.gradle.BasePlugin$_createTasks_closure13_closure17.doCall(BasePlugin.groovy)
@H_404_0@at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
@H_404_0@at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
@H_404_0@at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
@H_404_0@at java.lang.reflect.Method.invoke(Method.java:497)
@H_404_0@at org.codehaus.groovy.reflection.CachedMethod.invoke(CachedMethod.java:90)
@H_404_0@at groovy.lang.MetaMethod.doMethodInvoke(MetaMethod.java:324)
@H_404_0@at org.codehaus.groovy.runtime.Metaclass.ClosureMetaClass.invokeMethod(ClosureMetaClass.java:292)
@H_404_0@at groovy.lang.MetaClassImpl.invokeMethod(MetaClassImpl.java:1015)
@H_404_0@at org.codehaus.groovy.runtime.callsite.PogoMetaClassSite.call(PogoMetaClassSite.java:39)
@H_404_0@at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:45)
@H_404_0@at org.codehaus.groovy.runtime.callsite.PogoMetaClassSite.call(PogoMetaClassSite.java:54)
@H_404_0@at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:112)
@H_404_0@at com.android.build.gradle.internal.profile.SpanRecorders$2.call(SpanRecorders.groovy:52)
@H_404_0@at com.android.builder.profile.ThreadRecorder$1.record(ThreadRecorder.java:48)
@H_404_0@at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
@H_404_0@at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
@H_404_0@at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
@H_404_0@at java.lang.reflect.Method.invoke(Method.java:497)
@H_404_0@at org.codehaus.groovy.runtime.callsite.PojoMetaMethodSite$PojoCachedMethodSite.invoke(PojoMetaMethodSite.java:189)
@H_404_0@at org.codehaus.groovy.runtime.callsite.PojoMetaMethodSite.call(PojoMetaMethodSite.java:53)
@H_404_0@at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:124)
@H_404_0@at com.android.build.gradle.internal.profile.SpanRecorders.record(SpanRecorders.groovy:54)
@H_404_0@at com.android.build.gradle.BasePlugin$_createTasks_closure13.doCall(BasePlugin.groovy:414)
@H_404_0@at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
@H_404_0@at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
@H_404_0@at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
@H_404_0@at java.lang.reflect.Method.invoke(Method.java:497)
@H_404_0@at org.codehaus.groovy.reflection.CachedMethod.invoke(CachedMethod.java:90)
@H_404_0@at groovy.lang.MetaMethod.doMethodInvoke(MetaMethod.java:324)
@H_404_0@at org.codehaus.groovy.runtime.Metaclass.ClosureMetaClass.invokeMethod(ClosureMetaClass.java:292)
@H_404_0@at groovy.lang.MetaClassImpl.invokeMethod(MetaClassImpl.java:1015)
@H_404_0@at groovy.lang.Closure.call(Closure.java:423)
@H_404_0@at org.gradle.listener.ClosureBackedMethodInvocationDispatch.dispatch(ClosureBackedMethodInvocationDispatch.java:40)
@H_404_0@at org.gradle.listener.ClosureBackedMethodInvocationDispatch.dispatch(ClosureBackedMethodInvocationDispatch.java:25)
@H_404_0@at org.gradle.internal.event.BroadcastDispatch.dispatch(BroadcastDispatch.java:87)
@H_404_0@at org.gradle.internal.event.BroadcastDispatch.dispatch(BroadcastDispatch.java:31)
@H_404_0@at org.gradle.messaging.dispatch.ProxyDispatchAdapter$DispatchingInvocationHandler.invoke(ProxyDispatchAdapter.java:93)
@H_404_0@at com.sun.proxy.$Proxy11.afterEvaluate(Unknown Source)
@H_404_0@at org.gradle.configuration.project.LifecycleProjectEvaluator.notifyAfterEvaluate(LifecycleProjectEvaluator.java:67)
@H_404_0@at org.gradle.configuration.project.LifecycleProjectEvaluator.evaluate(LifecycleProjectEvaluator.java:61)
@H_404_0@at org.gradle.api.internal.project.AbstractProject.evaluate(AbstractProject.java:487)
@H_404_0@at org.gradle.api.internal.project.AbstractProject.evaluate(AbstractProject.java:85)
@H_404_0@at org.gradle.execution.TaskPathProjectEvaluator.configureHierarchy(TaskPathProjectEvaluator.java:47)
@H_404_0@at org.gradle.configuration.DefaultBuildConfigurer.configure(DefaultBuildConfigurer.java:35)
@H_404_0@at org.gradle.initialization.DefaultGradleLauncher.doBuildStages(DefaultGradleLauncher.java:129)
@H_404_0@at org.gradle.initialization.DefaultGradleLauncher.doBuild(DefaultGradleLauncher.java:106)
@H_404_0@at org.gradle.initialization.DefaultGradleLauncher.run(DefaultGradleLauncher.java:86)
@H_404_0@at org.gradle.launcher.exec.InProcessBuildActionExecuter$DefaultBuildController.run(InProcessBuildActionExecuter.java:90)
@H_404_0@at org.gradle.tooling.internal.provider.ExecuteBuildActionRunner.run(ExecuteBuildActionRunner.java:28)
@H_404_0@at org.gradle.launcher.exec.ChainingBuildActionRunner.run(ChainingBuildActionRunner.java:35)
@H_404_0@at org.gradle.launcher.exec.InProcessBuildActionExecuter.execute(InProcessBuildActionExecuter.java:41)
@H_404_0@at org.gradle.launcher.exec.InProcessBuildActionExecuter.execute(InProcessBuildActionExecuter.java:28)
@H_404_0@at org.gradle.launcher.exec.DaemonUsageSuggestingBuildActionExecuter.execute(DaemonUsageSuggestingBuildActionExecuter.java:50)
@H_404_0@at org.gradle.launcher.exec.DaemonUsageSuggestingBuildActionExecuter.execute(DaemonUsageSuggestingBuildActionExecuter.java:27)
@H_404_0@at org.gradle.launcher.cli.RunBuildAction.run(RunBuildAction.java:40)
@H_404_0@at org.gradle.internal.Actions$RunnableActionAdapter.execute(Actions.java:169)
@H_404_0@at org.gradle.launcher.cli.CommandLineActionFactory$ParseAndBuildAction.execute(CommandLineActionFactory.java:237)
@H_404_0@at org.gradle.launcher.cli.CommandLineActionFactory$ParseAndBuildAction.execute(CommandLineActionFactory.java:210)
@H_404_0@at org.gradle.launcher.cli.JavaRuntimeValidationAction.execute(JavaRuntimeValidationAction.java:35)
@H_404_0@at org.gradle.launcher.cli.JavaRuntimeValidationAction.execute(JavaRuntimeValidationAction.java:24)
@H_404_0@at org.gradle.launcher.cli.CommandLineActionFactory$WithLogging.execute(CommandLineActionFactory.java:206)
@H_404_0@at org.gradle.launcher.cli.CommandLineActionFactory$WithLogging.execute(CommandLineActionFactory.java:169)
@H_404_0@at org.gradle.launcher.cli.ExceptionReportingAction.execute(ExceptionReportingAction.java:33)
@H_404_0@at org.gradle.launcher.cli.ExceptionReportingAction.execute(ExceptionReportingAction.java:22)
@H_404_0@at org.gradle.launcher.Main.doAction(Main.java:33)
@H_404_0@at org.gradle.launcher.bootstrap.EntryPoint.run(EntryPoint.java:45)
@H_404_0@at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
@H_404_0@at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
@H_404_0@at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
@H_404_0@at java.lang.reflect.Method.invoke(Method.java:497)
@H_404_0@at org.gradle.launcher.bootstrap.ProcessBootstrap.runNoExit(ProcessBootstrap.java:54)
@H_404_0@at org.gradle.launcher.bootstrap.ProcessBootstrap.run(ProcessBootstrap.java:35)
@H_404_0@at org.gradle.launcher.GradleMain.main(GradleMain.java:23)
@H_404_0@at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
@H_404_0@at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
@H_404_0@at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
@H_404_0@at java.lang.reflect.Method.invoke(Method.java:497)
@H_404_0@at org.gradle.wrapper.BootstrapMainStarter.start(BootstrapMainStarter.java:30)
@H_404_0@at org.gradle.wrapper.WrapperExecutor.execute(WrapperExecutor.java:127)
@H_404_0@at org.gradle.wrapper.GradleWrapperMain.main(GradleWrapperMain.java:61)
@H_404_0@
@H_404_0@FAILURE: Build Failed with an exception.
@H_404_0@
@H_404_0@* Where:
@H_404_0@Build file '/Users/qxian/Desktop/AwesomeProject/android/app/build.gradle' line: 103
@H_404_0@
@H_404_0@* What went wrong:
@H_404_0@A problem occurred evaluating project ':app'.
@H_404_0@> SDK location not found. Define location with sdk.dir in the local.properties file or with an ANDROID_HOME environment variable.
@H_404_0@
@H_404_0@* Try:
@H_404_0@Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output.
@H_404_0@
@H_404_0@BUILD Failed
@H_404_0@
@H_404_0@Total time: 8.827 secs
@H_404_0@Could not install the app on the device,read the error above for details.
@H_404_0@Make sure you have an Android emulator running or a device connected and have
@H_404_0@set up your Android development environment:
@H_404_0@https://facebook.github.io/react-native/docs/android-setup.html
@H_404_0@---------------解决方法--------------------
@H_404_0@配置下android环境变量即可解决
@H_404_0@具体方法参见这里