昨天在Play商店发布了一个新的应用程序已经使用/测试应用程序数月没有问题,但从Play商店下载的版本无法访问互联网(假设)。从Cordova CLI运行应用程序时从未遇到此问题。
该应用程序在启动时有一个连接到服务器的登录页面 - 我可以在应用程序设置中看到该应用程序根本没有使用任何数据,并且在应用程序或日志中没有引发任何错误({ {1}})。
可能是什么问题?详情如下;
经过测试的设备
的Config.xml
adb logcat
清单
<access origin="*" />
CSP
<uses-sdk android:minSdkVersion="16" android:targetSdkVersion="25" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.WAKE_LOCK" />
<uses-permission android:name="android.permission.VIBRATE" />
<uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" />
<uses-permission android:name="${applicationId}.permission.C2D_MESSAGE" />
<uses-permission android:name="${applicationId}.permission.PushHandlerActivity" />
<permission android:name="${applicationId}.permission.C2D_MESSAGE" android:protectionLevel="signature" />
<permission android:name="${applicationId}.permission.PushHandlerActivity" android:protectionLevel="signature" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
验证模型
<meta http-equiv="Content-Security-Policy" content="default-src * gap://ready; connect-src * ws: wss:; style-src 'self' 'unsafe-inline'; script-src 'self' 'unsafe-inline' 'unsafe-eval'; img-src 'self' data: *">
验证控制器
login: function(un, pw, onProgress, onSuccess, onAbort, onError) {
var params = {
username: un,
password: pw,
};
var httpHeaders = {
'X-CSRF-Token': app.token
};
app.authRemote.restClient.call(config.serverURL + '/' + config.serviceEndPoint + '/endpoint/login', JSON.stringify(params), {requestMethod: 'POST', requestDataType: 'application/json', httpHeaders: httpHeaders, responseDataType: 'json'},
function _onProgress() {
onProgress(app.authRemote.restClient);
},
function _onSuccess(result) {
onSuccess(result);
},
function _onAbort() {
onAbort();
},
function _onError(error) {
onError(error);
}
);
},
来自logcat的控制台
this.login = function(username, password, onSuccess, onError){
app.authRemote.login(username, password,
function _onProgress(restClient) {
console.log('Sent = ' + restClient.bytesSent + ' | received = ' + restClient.bytesReceived);
},
function _onSuccess(data) {
onSuccess(data);
},
function _onAbort() {
},
function _onError(error) {
onError(error);
}
);
};
答案 0 :(得分:1)
实际上终于找到了答案......
Ajax请求被阻止HTTPS
,因为我使用的是自签名SSL
证书。
虽然不建议这样做(你应该使用有效的证书进行制作),但这里有一个快速的方法;
cordova-plugin-certificates
plugin cordova.plugins.certificates.trustUnsecureCerts(true);