From an Android point of view there are an → Internal Storage and an → External Storage .
1. Internal Storage
The Internal Storage can only be accessed with a rooted device.
1.1 The app package is saved in
In order to be able to debug your app, AI2 saves the assets for → Companion on devices with
- Android ≥ 10 (API ≥ 29):
- Android < 10 :
1.2. The Private directory is
This private directory can be used with the
File component to save / read text (setting the path without a slash). It can only be accessed by your app and is automatically removed when the app is uninstalled.
2. External Storage
The root directory of the External Storage is:
/storage/emulated/0/ or /sdcard/ or file:///mnt/sdcard/ or file:///storage/emulated/0/
To access the external storage,
READ_/WRITE_EXTERNAL_STORAGE permission is required.
2.1. App-specific directory
In addition, there may be an app-specific directory (ASD) which can be created with
- Taifun’s File extension App Inventor Extensions: File | Pura Vida Apps or the
- FileTools extension FileTools : Some tools to work with files or
- Get the path of → ASD (app-specific dir) & → private data dir (internal storage).
Note: The ASD is automatically created on devices with API ≥ 29.
The path of the ASD is:
which is in the External (private) Storage, but does not require READ_ / WRITE_EXTERNAL_STORAGE permissions. The ASD can only be accessed by your app and is automatically removed when the app is uninstalled.
2.2. External (removable / micro) SD card
There may also be another External Storage: a removable (micro) SD card, eg:
that can only be read (on devices with Android ≥ 4.4 /
KitKat, API 19).
The root directory of the External Storage
is displayed on the device as Internal Storage (unfortunately this is a bit ambiguous).
When targeting Android ≥ 10
→ Scoped storage
To give users more control over their files and to limit file clutter, apps that target Android 10 (API level 29) and higher are given scoped access into external storage, or scoped storage, by default. Such apps have access only to the app-specific directory on external storage , as well as specific types of media that the app has created .
I would like to introduce these three basic terms:
Absolute path │ relative path │ full path
1. This path is an → absolute path:
2. This path is a → relative path:
Some components need a relative and others an absolute path.
3. And on top of that, some components or Android versions require a → full path:
I recommend these terms to distinguish the paths, for example:
- relative path:
- absolute path:
- full path:
EDIT (May 11, 2022):
Storage Permissions on Android 10 & 11
Since AI2 & Kodular decided to declare
requestLegacyExternalStorage=truein the Manifest (which is only ignored on Android 11+), storage permissions must also be requested on Android 10.
If you remove this from the Manifest, which I would recommend, no permission for the
Sharedfolders would be required on Android 10 either. The storage permissions would then have to be declared as follows:
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" android:maxSdkVersion="28" />
I generally prefer to request as few permissions as possible.
I don't like permissions and my users even less.