Ionic 3 android permissions internet
I'm writing an app that sends requests to a REST API.
The API calls work in the web browser, but not in the emulator and not on a device.
Ionic CLI 4.4.0
Cordova 8.1.2
What i did:
I use android-permissions like on this side:
app.modules.ts
import { AndroidPermissions } from '@ionic-native/android-permissions';
@NgModule({
declarations: [
],
imports: [
],
entryComponents: [
],
providers: [
AndroidPermissions
],
bootstrap: [IonicApp]
})
export class AppModule {}
api-call.ts
import { AndroidPermissions } from '@ionic-native/android-permissions';
export class ApiCallPage {
constructor(private androidPermissions: AndroidPermissions) {
this.androidPermissions.checkPermission(this.androidPermissions.PERMISSION.INTERNET).then(
result => console.log('Has permission?', result.hasPermission),
err => this.androidPermissions.requestPermission(this.androidPermissions.PERMISSION.INTERNET)
);
}
}
The target device (device and emulator in AVD manager) has API 22 (Android 5.1).
config.xml
<access origin="*" />
<preference name="android-minSdkVersion" value="19" />
<plugin name="cordova-plugin-android-permissions" spec="1.0.0" />
<engine name="android" spec="^7.1.1" />
The last one (engine name) is probably for the cordova-android version and does not have to be 5.1. In package.json is under dependencies "cordova-android": "^7.1.1"
.
- /platforms/android/app/build/intermediates/manifests/full/debug/AndroidManifest.xml
- /platforms/android/app/src/main/AndroidManifest.xml
...both files includes (not written by hand):
<uses-permission android:name="android.permission.INTERNET" />
It is not a CORS problem. The REST API runs on a different server than the web browser and it works with the web browser.
I think I did everything. Is something missing or wrong?
What do you have to do to have Ionic (cordova) Internet access?
[UPDATE]
The app info shows me the permissions that the app has full network access. Now I'm at a loss.
In the API, I log every request at boot time. A request of the app from the device does not arrive. The app in the browser arrives.
cordova ionic-framework ionic3 android-permissions ionic-native
add a comment |
I'm writing an app that sends requests to a REST API.
The API calls work in the web browser, but not in the emulator and not on a device.
Ionic CLI 4.4.0
Cordova 8.1.2
What i did:
I use android-permissions like on this side:
app.modules.ts
import { AndroidPermissions } from '@ionic-native/android-permissions';
@NgModule({
declarations: [
],
imports: [
],
entryComponents: [
],
providers: [
AndroidPermissions
],
bootstrap: [IonicApp]
})
export class AppModule {}
api-call.ts
import { AndroidPermissions } from '@ionic-native/android-permissions';
export class ApiCallPage {
constructor(private androidPermissions: AndroidPermissions) {
this.androidPermissions.checkPermission(this.androidPermissions.PERMISSION.INTERNET).then(
result => console.log('Has permission?', result.hasPermission),
err => this.androidPermissions.requestPermission(this.androidPermissions.PERMISSION.INTERNET)
);
}
}
The target device (device and emulator in AVD manager) has API 22 (Android 5.1).
config.xml
<access origin="*" />
<preference name="android-minSdkVersion" value="19" />
<plugin name="cordova-plugin-android-permissions" spec="1.0.0" />
<engine name="android" spec="^7.1.1" />
The last one (engine name) is probably for the cordova-android version and does not have to be 5.1. In package.json is under dependencies "cordova-android": "^7.1.1"
.
- /platforms/android/app/build/intermediates/manifests/full/debug/AndroidManifest.xml
- /platforms/android/app/src/main/AndroidManifest.xml
...both files includes (not written by hand):
<uses-permission android:name="android.permission.INTERNET" />
It is not a CORS problem. The REST API runs on a different server than the web browser and it works with the web browser.
I think I did everything. Is something missing or wrong?
What do you have to do to have Ionic (cordova) Internet access?
[UPDATE]
The app info shows me the permissions that the app has full network access. Now I'm at a loss.
In the API, I log every request at boot time. A request of the app from the device does not arrive. The app in the browser arrives.
cordova ionic-framework ionic3 android-permissions ionic-native
add a comment |
I'm writing an app that sends requests to a REST API.
The API calls work in the web browser, but not in the emulator and not on a device.
Ionic CLI 4.4.0
Cordova 8.1.2
What i did:
I use android-permissions like on this side:
app.modules.ts
import { AndroidPermissions } from '@ionic-native/android-permissions';
@NgModule({
declarations: [
],
imports: [
],
entryComponents: [
],
providers: [
AndroidPermissions
],
bootstrap: [IonicApp]
})
export class AppModule {}
api-call.ts
import { AndroidPermissions } from '@ionic-native/android-permissions';
export class ApiCallPage {
constructor(private androidPermissions: AndroidPermissions) {
this.androidPermissions.checkPermission(this.androidPermissions.PERMISSION.INTERNET).then(
result => console.log('Has permission?', result.hasPermission),
err => this.androidPermissions.requestPermission(this.androidPermissions.PERMISSION.INTERNET)
);
}
}
The target device (device and emulator in AVD manager) has API 22 (Android 5.1).
config.xml
<access origin="*" />
<preference name="android-minSdkVersion" value="19" />
<plugin name="cordova-plugin-android-permissions" spec="1.0.0" />
<engine name="android" spec="^7.1.1" />
The last one (engine name) is probably for the cordova-android version and does not have to be 5.1. In package.json is under dependencies "cordova-android": "^7.1.1"
.
- /platforms/android/app/build/intermediates/manifests/full/debug/AndroidManifest.xml
- /platforms/android/app/src/main/AndroidManifest.xml
...both files includes (not written by hand):
<uses-permission android:name="android.permission.INTERNET" />
It is not a CORS problem. The REST API runs on a different server than the web browser and it works with the web browser.
I think I did everything. Is something missing or wrong?
What do you have to do to have Ionic (cordova) Internet access?
[UPDATE]
The app info shows me the permissions that the app has full network access. Now I'm at a loss.
In the API, I log every request at boot time. A request of the app from the device does not arrive. The app in the browser arrives.
cordova ionic-framework ionic3 android-permissions ionic-native
I'm writing an app that sends requests to a REST API.
The API calls work in the web browser, but not in the emulator and not on a device.
Ionic CLI 4.4.0
Cordova 8.1.2
What i did:
I use android-permissions like on this side:
app.modules.ts
import { AndroidPermissions } from '@ionic-native/android-permissions';
@NgModule({
declarations: [
],
imports: [
],
entryComponents: [
],
providers: [
AndroidPermissions
],
bootstrap: [IonicApp]
})
export class AppModule {}
api-call.ts
import { AndroidPermissions } from '@ionic-native/android-permissions';
export class ApiCallPage {
constructor(private androidPermissions: AndroidPermissions) {
this.androidPermissions.checkPermission(this.androidPermissions.PERMISSION.INTERNET).then(
result => console.log('Has permission?', result.hasPermission),
err => this.androidPermissions.requestPermission(this.androidPermissions.PERMISSION.INTERNET)
);
}
}
The target device (device and emulator in AVD manager) has API 22 (Android 5.1).
config.xml
<access origin="*" />
<preference name="android-minSdkVersion" value="19" />
<plugin name="cordova-plugin-android-permissions" spec="1.0.0" />
<engine name="android" spec="^7.1.1" />
The last one (engine name) is probably for the cordova-android version and does not have to be 5.1. In package.json is under dependencies "cordova-android": "^7.1.1"
.
- /platforms/android/app/build/intermediates/manifests/full/debug/AndroidManifest.xml
- /platforms/android/app/src/main/AndroidManifest.xml
...both files includes (not written by hand):
<uses-permission android:name="android.permission.INTERNET" />
It is not a CORS problem. The REST API runs on a different server than the web browser and it works with the web browser.
I think I did everything. Is something missing or wrong?
What do you have to do to have Ionic (cordova) Internet access?
[UPDATE]
The app info shows me the permissions that the app has full network access. Now I'm at a loss.
In the API, I log every request at boot time. A request of the app from the device does not arrive. The app in the browser arrives.
cordova ionic-framework ionic3 android-permissions ionic-native
cordova ionic-framework ionic3 android-permissions ionic-native
edited Nov 23 '18 at 11:05
asked Nov 23 '18 at 7:27
bitkorn
166213
166213
add a comment |
add a comment |
1 Answer
1
active
oldest
votes
It was a CORS issue, but not on the API side, but on the client side.
In the config.xml <preference name="CordovaWebViewEngine" value="CDVWKWebViewEngine" />
solves my problem.
Take a look at github ionic-team issue
For me it was Android 5.1 & 8.0.
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53442314%2fionic-3-android-permissions-internet%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
It was a CORS issue, but not on the API side, but on the client side.
In the config.xml <preference name="CordovaWebViewEngine" value="CDVWKWebViewEngine" />
solves my problem.
Take a look at github ionic-team issue
For me it was Android 5.1 & 8.0.
add a comment |
It was a CORS issue, but not on the API side, but on the client side.
In the config.xml <preference name="CordovaWebViewEngine" value="CDVWKWebViewEngine" />
solves my problem.
Take a look at github ionic-team issue
For me it was Android 5.1 & 8.0.
add a comment |
It was a CORS issue, but not on the API side, but on the client side.
In the config.xml <preference name="CordovaWebViewEngine" value="CDVWKWebViewEngine" />
solves my problem.
Take a look at github ionic-team issue
For me it was Android 5.1 & 8.0.
It was a CORS issue, but not on the API side, but on the client side.
In the config.xml <preference name="CordovaWebViewEngine" value="CDVWKWebViewEngine" />
solves my problem.
Take a look at github ionic-team issue
For me it was Android 5.1 & 8.0.
answered Nov 23 '18 at 16:57
bitkorn
166213
166213
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53442314%2fionic-3-android-permissions-internet%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown