Aquí es una clase que utilizo para encontrar todos sdcards en un dispositivo; incorporado y extraíble. Lo he estado usando en Ice Cream Sandwich, pero debería funcionar en niveles 2x.
public class GetRemovableDevice {
private final static String TAG = "GetRemoveableDevice";
public GetRemovableDevice() {
}
public static String[] getDirectories() {
MyLog.d(TAG, "getStorageDirectories");
File tempFile;
String[] directories = null;
String[] splits;
ArrayList<String> arrayList = new ArrayList<String>();
BufferedReader bufferedReader = null;
String lineRead;
try {
arrayList.clear(); // redundant, but what the hey
bufferedReader = new BufferedReader(new FileReader("/proc/mounts"));
while ((lineRead = bufferedReader.readLine()) != null) {
MyLog.d(TAG, "lineRead: " + lineRead);
splits = lineRead.split(" ");
// System external storage
if (splits[1].equals(Environment.getExternalStorageDirectory()
.getPath())) {
arrayList.add(splits[1]);
MyLog.d(TAG, "gesd split 1: " + splits[1]);
continue;
}
// skip if not external storage device
if (!splits[0].contains("/dev/block/")) {
continue;
}
// skip if mtdblock device
if (splits[0].contains("/dev/block/mtdblock")) {
continue;
}
// skip if not in /mnt node
if (!splits[1].contains("/mnt")) {
continue;
}
// skip these names
if (splits[1].contains("/secure")) {
continue;
}
if (splits[1].contains("/mnt/asec")) {
continue;
}
// Eliminate if not a directory or fully accessible
tempFile = new File(splits[1]);
if (!tempFile.exists()) {
continue;
}
if (!tempFile.isDirectory()) {
continue;
}
if (!tempFile.canRead()) {
continue;
}
if (!tempFile.canWrite()) {
continue;
}
// Met all the criteria, assume sdcard
arrayList.add(splits[1]);
}
} catch (FileNotFoundException e) {
} catch (IOException e) {
} finally {
if (bufferedReader != null) {
try {
bufferedReader.close();
} catch (IOException e) {
}
}
}
// Send list back to caller
if (arrayList.size() == 0) {
arrayList.add("sdcard not found");
}
directories = new String[arrayList.size()];
for (int i = 0; i < arrayList.size(); i++) {
directories[i] = arrayList.get(i);
}
return directories;
}
}
El MyLog.d es una clase de seguimiento que se expande Log.d - que se puede quitar.
La clase lee/proc/mounts/e:
- comprueba si el nombre de ruta es el directorio sdcard interna
- comprobaciones para ver si es un dispositivo de bloque
- saltos mtdblock dispositivos
- se salta nada que no esté montado
- saltos directorios seguros y ASEC
- se asegura de que exista, es un directorio, y leer/escritura accesible
Si todo esto coincide, se supone que usted tiene una tarjeta sd y agrega la ruta a la lista de la matriz. Devuelve una matriz de cadenas de nombres de ruta.
llamar a la función GetDirectories, código de algo similar a:
String[] sdcardDirectories = GetRemoveableDevice.getDirectories();
Los caminos devueltos se pueden utilizar para crear una lista de selección de usuario, explorar en busca de un archivo, o lo que sea.
Finalmente, aquí está dos líneas de MyLog.d procedentes de un ensayo emulador (segunda línea es el sdcard emulador):
09-19 15: 57: 12.511: D/GetRemoveableDevice (651): lineRead:/dev/block/mtdblock2/cache yaffs2 rw, nosuid, nodev 0 0
09-19 15: 57: 12.511: D/GetRemoveableDevice (651): lineRead:/dev/block/vold/179: 0/mnt/sdcard vfat rw, dirsync, nosuid, nodev, noexec, uid = 1000, gid = 1015, fmask = 0702, dmask = 0702, allow_utime = 0020, página de códigos = cp437, iocharset = iso8859-1, shortname = mixed, utf8, errors = remontar -ro 0 0
Todo lo que vaya más allá de los métodos de 'Environment' está fuera de los límites del SDK y no será confiable. – CommonsWare