$ http电话赢得了Ionic Android版本的支持

时间:2015-05-16 02:56:59

标签: android angularjs http ionic

这就是我打电话的方式:

$http.get( url, {
    params : {
        empId: $scope.empId
    }
}).then(function(data, status){
    $scope.workOrders = data.data;
}, function(data, status){
    $scope.message = data;
});

它在Chrome上运行得很好,如果我在手机浏览器上导航到该网址,我可以得到一个很好的响应。

但是,每当我使用构建的.apk时,我都会得到:

{"data":"",
 "status":404,
 "config":{
     "method":"GET",
     "transformRequest":[null],
     "transformResponse":[null],
     "params":{"empId":"123"},
     "url":"http://...",
     "headers":{"Accept":"application/json, text/plain, */*"}
 },"statusText":Not Found"}

有点丢失了。奇怪的是,我可以通过手机浏览器点击URL,但不能在Ionic / Cordova内置.apk

根据要求,这是我的config.xml文件:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<widget id="com.ionicframework.myapp397384" version="0.0.1" xmlns="http://www.w3.org/ns/widgets" xmlns:cdv="http://cordova.apache.org/ns/1.0">
  <name>myApp</name>
  <description>
        An Ionic Framework and Cordova project.
    </description>
  <author email="hi@ionicframework" href="http://ionicframework.com/">
      Ionic Framework Team
    </author>
  <content src="index.html"/>
  <access origin="*"/>
  <preference name="webviewbounce" value="false"/>
  <preference name="UIWebViewBounce" value="false"/>
  <preference name="DisallowOverscroll" value="true"/>
  <preference name="BackupWebStorage" value="none"/>
  <feature name="StatusBar">
    <param name="ios-package" value="CDVStatusBar" onload="true"/>
  </feature>
</widget>

1 个答案:

答案 0 :(得分:8)

啊哈!

显然Cordova刚刚发布了cordova-android 4.0,并且它默认阻止了http请求。

只需运行此命令:

ionic plugin add cordova-plugin-whitelist

你很高兴。