我已提及https://github.com/apache/cordova-plugin-whitelist并在下面添加到我的config.xml:
<plugin name="cordova-plugin-whitelist" spec="~1.3.0"/>
<access origin="*" subdomains="true"/>
<!-- A wildcard can be used to whitelist the entire network,
over HTTP and HTTPS.
*NOT RECOMMENDED* -->
<allow-navigation href="*"/>
<allow-intent href="*"/>
<allow-intent href="http://*/*" />
<allow-intent href="https://*/*" />
<allow-intent href="tel:*" />
<allow-intent href="sms:*" />
<allow-intent href="mailto:*" />
<allow-intent href="geo:*" />
<platform name="android">
<allow-intent href="market:*" />
</platform>
我的AndroidManifest.xml中也有以下权限:
<uses-permission android:name="android.permission.INTERNET" />
以下是index.html中的CSP声明:
<meta http-equiv="Content-Security-Policy"
content="default-src 'self' data: gap: https://ssl.gstatic.com; style-src 'self' 'unsafe-inline'; media-src *;script-src 'self' localhost:35729 84.254.133.91:8080 'unsafe-inline' 'unsafe-eval';connect-src *">
服务器正在运行@ 84.254.133.91:8080
以下是http post call:
的代码var req = {
method: 'POST',
url: $rootScope.labels.IP + $rootScope.labels.USER_ID_CREATE_URL,
data: {
userId: $scope.newUserIdCreate.username,
password: $scope.newUserIdCreate.password,
}
};
var res = $http(req);
res.success(function (data, status, headers, config) {
alert("request success:" + JSON.stringify({ data: data }));
});
res.error(function (data, status, headers, config) {
alert("request failed:" + JSON.stringify({ data: data }));
});
$ http请求都没有通过。我花了将近2天的时间来推荐'n'篇文章,但仍然无法解决这个问题。
此外,我添加了一个href链接到'google / facebook',我可以从应用程序访问这些网站。
通过运行'ionic serve'来使用网络应用程序非常正常。从Android apk,没有任何请求到达服务器。
缺少什么配置?
答案 0 :(得分:1)
经过几天的大量调查,问题与CORS issue with Tomcat and Android Webview
相同如上述问题中的一个答案所述,添加CordovaOriginWrapper解决了这个问题。
这很棘手,离子文档从不谈论这种行为。需要使用此行为更新离子文档。