Ponieważ polityka uprawnień na moim urządzeniu jest trochę paranoiczna (nie mogę danych aplikacji adb pull
), napisałem skrypt do rekurencyjnego kopiowania plików.
Uwaga: ten skryptowy skrypt rekurencyjny jest przeznaczony dla systemu Android!
kopiowaniem r:
#! /system/bin/sh
src="$1"
dst="$2"
dir0=`pwd`
myfind() {
local fpath=$1
if [ -e "$fpath" ]
then
echo $fpath
if [ -d "$fpath" ]
then
for fn in $fpath/*
do
myfind $fn
done
fi
else
: echo "$fpath not found"
fi
}
if [ ! -z "$dst" ]
then
if [ -d "$src" ]
then
echo 'the source is a directory'
mkdir -p $dst
if [[ "$dst" = /* ]]
then
: # Absolute path
else
# Relative path
dst=`pwd`/$dst
fi
cd $src
echo "COPYING files and directories from `pwd`"
for fn in $(myfind .)
do
if [ -d $fn ]
then
echo "DIR $dst/$fn"
mkdir -p $dst/$fn
else
echo "FILE $dst/$fn"
cat $fn >$dst/$fn
fi
done
echo "DONE"
cd $dir0
elif [ -f "$src" ]
then
echo 'the source is a file'
srcn="${src##*/}"
if [ -z "$srcn" ]
then
srcn="$src"
fi
if [[ "$dst" = */ ]]
then
mkdir -p $dst
echo "copying $src" '->' "$dst/$srcn"
cat $src >$dst/$srcn
elif [ -d "$dst" ]
then
echo "copying $src" '->' "$dst/$srcn"
cat $src >$dst/$srcn
else
dstdir=${dst%/*}
if [ ! -z "$dstdir" ]
then
mkdir -p $dstdir
fi
echo "copying $src" '->' "$dst"
cat $src >$dst
fi
else
echo "$src is neither a file nor a directory"
fi
else
echo "Use: copy-r src-dir dst-dir"
echo "Use: copy-r src-file existing-dst-dir"
echo "Use: copy-r src-file dst-dir/"
echo "Use: copy-r src-file dst-file"
fi
Tu podać źródło lekkiej find
dla Androida, ponieważ na niektórych urządzeniach tego narzędzia jest zaginionych. Zamiast myfind
można użyć find
, jeśli jest zdefiniowany na urządzeniu.
Wyposażenie:
$ adb push copy-r /sdcard/
, pracującym w adb shell
(korzenie)
# . /sdcard/copy-r files/ /sdcard/files3
lub
# source /sdcard/copy-r files/ /sdcard/files3
(Wartość mieszania #
powyżej jest su
szybka, a .
jest polecenie co powoduje, że powłoka uruchamia określony plik, prawie taki sam jak source
).
Po skopiowaniu mogę adb pull
pliki z karty SD.
Zapisywanie plików w katalogu aplikacji było trudniejsze, próbowałem ustawić uprawnienia r/w na files
i jego podkatalogach, to nie działało (no cóż, pozwalało mi to czytać, ale nie pisać, co jest dziwne), więc musiałem zrobić:
String[] cmdline = { "sh", "-c", "source /sdcard/copy-r /sdcard/files4 /data/data/com.example.myapp/files" };
try {
Runtime.getRuntime().exec(cmdline);
} catch (IOException e) {
e.printStackTrace();
}
w aplikacji onCreate().
PS tylko w przypadku, gdy ktoś potrzebuje kod do usunięcia ochrony katalogów aplikacji, aby umożliwić adb shell
dostęp on non-zakorzenione telefon,
setRW(appContext.getFilesDir().getParentFile());
public static void setRW(File... files) {
for (File file : files) {
if (file.isDirectory()) {
setRW(file.listFiles()); // Calls same method again.
} else {
}
file.setReadable(true, false);
file.setWritable(true, false);
}
}
chociaż dla jakiegoś nieznanego powodu mogę czytać ale nie pisać.
Czy któreś z dostarczonych rozwiązań działają dla Ciebie? – gnclmorais
@MEGA: jak już powiedziałem, nie ma zainstalowanego adb. Mogę skopiować za pomocą polecenia "cat src> dst", ale nie wiem jak zrobić to rekursywnie? – psihodelia
Nie rozumiem. Aby uzyskać dostęp do powłoki, wpisz './adb shell'. Jeśli mówisz, że nie masz dostępnego "Adb'a", w jaki sposób możesz uzyskać dostęp do powłoki? – gnclmorais