Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/json/15.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 使用React Native中的axios,使用参数GET方法从HTTP响应_Javascript_Json_React Native_Httprequest_Axios - Fatal编程技术网

Javascript 使用React Native中的axios,使用参数GET方法从HTTP响应

Javascript 使用React Native中的axios,使用参数GET方法从HTTP响应,javascript,json,react-native,httprequest,axios,Javascript,Json,React Native,Httprequest,Axios,我认为这可能是一个非常简单的问题,但我对Web请求还不熟悉,可以让它工作,也不能在搜索Web时得到简单的响应 我有一个网站,通过将此URL放入浏览器,我可以从中获得JSON响应:http://www.test.com/callservice.php?action=stop&x=1&y=2&ct=100 这反过来给了我一些JSON响应 现在,我正试图使用Axios在Javascript中实现同样的效果 或者直接使用URL componentWillMount() { axios.get(

我认为这可能是一个非常简单的问题,但我对Web请求还不熟悉,可以让它工作,也不能在搜索Web时得到简单的响应

我有一个网站,通过将此URL放入浏览器,我可以从中获得JSON响应:
http://www.test.com/callservice.php?action=stop&x=1&y=2&ct=100

这反过来给了我一些JSON响应

现在,我正试图使用Axios在Javascript中实现同样的效果

或者直接使用URL

 componentWillMount() {
    axios.get('http://www.test.com/callservice.php?action=stop&x=1&y=2&ct=100')
      .then(response => console.log(response));
  }
或者使用GET参数:

 componentWillMount() {
    axios.get('http://www.test.com/callservice.php', {
      params: {
        action: 'stop',
        x: 1,
        y: 2,
        ct=100
      }
    })
      .then(response => console.log(response));
  }
但这两种方法都给出了相同的错误:

Possible Unhandled Promise Rejection (id: 0):
Network Error
Error: Network Error
还有一个更详细的捕获错误:

Error: Network Error
    at createError (createError.js:15)
    at XMLHttpRequest.handleError (xhr.js:87)
    at XMLHttpRequest.dispatchEvent (event-target.js:172)
    at XMLHttpRequest.setReadyState (XMLHttpRequest.js:542)
    at XMLHttpRequest.__didCompleteResponse (XMLHttpRequest.js:378)
    at XMLHttpRequest.js:482
    at RCTDeviceEventEmitter.emit (EventEmitter.js:181)
    at MessageQueue.__callFunction (MessageQueue.js:236)
    at MessageQueue.js:108
    at guard (MessageQueue.js:46)
这似乎是个问题

如果您是脚本的所有者(在服务器上),则可以添加适当的响应头来处理此问题。在PHP中,应该是这样的:

jbssm,
看起来你在用IOS。您可以使用Xcode检查项目设置中的应用程序传输安全设置吗

默认情况下,Xcode禁用http连接只允许安全连接。
您应该在项目设置中添加“允许任意加载”

尝试添加catch子句以查看错误:axios.get(')。然后(response=>console.log(response)).catch(e=>console.log(e))@DiogoSgrillo我这样做了,并在问题中添加了完整的错误,但我仍然无法理解问题所在。官方文件的格式响应不同。你能试试这种格式吗。然后(function(response){console.log(response);})@SergChernata你能澄清一下我应该怎么做吗?另外,我已经更改为真实的URL,以防它有助于调试。但是当我在浏览器(Chrome或我尝试过的任何其他浏览器)中请求URL时,这会起作用,它不起作用的是Javascript/React Native大多数浏览器在处理Ajax请求时都有安全限制。你可以使用我建议的插件在Chrome中禁用这些限制。