我是第一次尝试阿波罗。 我的后端服务器是Phoenix框架(elixir)。并在http://localhost:4000/api中运行 因此,我尝试在代码中使用像这样的apollo进行第一次查询。
import React from 'react';
import { StyleSheet, Text, View } from 'react-native';
import ApolloClient from 'apollo-boost';
import { gql } from 'apollo-boost';
const client = new ApolloClient(
{
uri: 'http://localhost:4000/api',
}
);
client.query({
query: gql`
{
users {
name
email
}
`}
}).then(result => console.log(result));
但是我出错了。
[Network error]: TypeError: Network request failed
node_modules/expo/build/logs/LogSerialization.js:166:14 in _captureConsoleStackTrace
node_modules/expo/build/logs/LogSerialization.js:41:24 in serializeLogDataAsync
... 9 more stack frames from framework internals
[Unhandled promise rejection: Error: Network error: Network request failed]
http://192.168.1.8:19001/node_modules/expo/AppEntry.bundle?platform=android&dev=true&minify=false&hot=false:124432:28 in new ApolloError
node_modules/apollo-client/bundle.umd.js:1587:12 in <anonymous>
node_modules/apollo-client/bundle.umd.js:2007:12 in info.listeners.forEach$argument_0
<anonymous>:null in Set.forEach
node_modules/apollo-client/bundle.umd.js:2005:17 in queries.forEach$argument_0
<anonymous>:null in Map.forEach
node_modules/apollo-client/bundle.umd.js:2003:11 in QueryManager.prototype.broadcastQueries
http://192.168.1.8:19001/node_modules/expo/AppEntry.bundle?platform=android&dev=true&minify=false&hot=false:125823:31 in <unknown>
node_modules/promise/setimmediate/core.js:37:11 in tryCallOne
node_modules/promise/setimmediate/core.js:123:14 in setImmediate$argument_0
在我的服务器日志中什么也没说。我认为我的客户甚至不接触服务器。 我想念什么?有任何想法吗? :(
答案 0 :(得分:1)
事实是,iOS在模拟器中运行,而Android在模拟器中运行。
localhost指向运行代码的环境。仿真器仅在模拟设备时模拟真实设备。 因此,Android上的localhost指向仿真的Android设备。而不是运行服务器的计算机。 解决方案是用计算机的IP地址替换localhost。
尝试将http://localhost:4000
更改为http://10.0.2.2:4000/