这就是我打电话的方式:
$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>
答案 0 :(得分:8)
啊哈!
显然Cordova刚刚发布了cordova-android 4.0,并且它默认阻止了http请求。
只需运行此命令:
ionic plugin add cordova-plugin-whitelist
你很高兴。