亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > Android > 正文

android用java和c實現查找sd卡掛載路徑(sd卡路徑)的方法

2020-04-11 11:54:04
字體:
來源:轉載
供稿:網友

方法一:

分析 mount 命令的返回信息,例如:

復制代碼 代碼如下:

$ mount
rootfs / rootfs ro,relatime 0 0
tmpfs /dev tmpfs rw,nosuid,relatime,mode=755 0 0
devpts /dev/pts devpts rw,relatime,mode=600 0 0
proc /proc proc rw,relatime 0 0
sysfs /sys sysfs rw,relatime 0 0
debugfs /sys/kernel/debug debugfs rw,relatime 0 0
none /acct cgroup rw,relatime,cpuacct 0 0
tmpfs /mnt/asec tmpfs rw,relatime,mode=755,gid=1000 0 0
tmpfs /mnt/obb tmpfs rw,relatime,mode=755,gid=1000 0 0
none /dev/cpuctl cgroup rw,relatime,cpu 0 0
/dev/block/platform/sdhci-tegra.3/by-name/system /system ext4 ro,relatime,barrier=1,data=ordered 0 0
/dev/block/platform/sdhci-tegra.3/by-name/userdata /data ext4 rw,nosuid,nodev,noatime,barrier=1,data=ordered 0 0
/dev/block/platform/sdhci-tegra.3/by-name/cache /cache ext4 rw,nosuid,nodev,noatime,barrier=1,data=ordered 0 0
/dev/block/platform/sdhci-tegra.3/by-name/pdsb /pds ext2 ro,relatime 0 0
/dev/fuse /mnt/sdcard fuse rw,nosuid,nodev,relatime,user_id=1023,group_id=1023,default_permissions,allow_other 0 0
/dev/block/vold/179:9 /mnt/sdcard-ext vfat rw,dirsync,nosuid,nodev,noexec,relatime,uid=1000,gid=1015,fmask=0702,dmask=0702,allow_utime=0020,codepage=cp437,iocharset=iso8859-1,shortname=mixed,utf8,errors=remount-ro 0 0
/dev/block/vold/179:9 /mnt/secure/asec vfat rw,dirsync,nosuid,nodev,noexec,relatime,uid=1000,gid=1015,fmask=0702,dmask=0702,allow_utime=0020,codepage=cp437,iocharset=iso8859-1,shortname=mixed,utf8,errors=remount-ro 0 0
tmpfs /mnt/sdcard-ext/.android_secure tmpfs ro,relatime,size=0k,mode=000 0 0

Java 版代碼如下:
// 給 C/C++ 編寫的共享庫回調取得全部 SD 卡路徑的函數
public String
GetAllSDPath() throws TokenException
{
    String strMountInfo = "";

    // 1.首先獲得系統已加載的文件系統信息
    try
    {
        // 創建系統進程生成器對象
        ProcessBuilder objProcessBuilder = new ProcessBuilder();
        // 執行 mount -h 可以看到 mount : list mounted filesystems
        // 這條命令可以列出已加載的文件系統
        objProcessBuilder.command( "mount" ); // 新的操作系統程序和它的參數
        // 設置錯誤輸出都將與標準輸出合并
        objProcessBuilder.redirectErrorStream( true );
        // 基于當前系統進程生成器的狀態開始一個新進程,并返回進程實例
        Process objProcess = objProcessBuilder.start();
        // 阻塞線程至到本地操作系統程序執行結束,返回本地操作系統程序的返回值
        objProcess.waitFor();

        // 得到進程對象的輸入流,它對于進程對象來說是已與本地操作系統程序的標準輸出流(stdout)相連接的
        InputStream objInputStream = objProcess.getInputStream();

        byte[] buffer = new byte[1024];

        // 讀取 mount 命令程序返回的信息文本
        while ( -1 != objInputStream.read( buffer ) )
        {
            strMountInfo = strMountInfo + new String( buffer );
        }

        // 關閉進程對象的輸入流
        objInputStream.close();

        // 終止進程并釋放與其相關的任何流
        objProcess.destroy();
    }
    catch ( Exception e )
    {
        e.printStackTrace();
    }

    // 2.然后再在系統已加載的文件系統信息里查找 SD 卡路徑  
    // mount 返回的已加載的文件系統信息是以一行一個信息的形式體現的,
    // 所以先用換行符拆分字符串
    String[] lines = strMountInfo.split( "/n" );

    // 清空該字符串對象,下面將用它來裝載真正有用的 SD 卡路徑列表
    strMountInfo = "";

    for ( int i = 0;
              i < lines.length;
              i++ )
    {
        // 如果該行內有 /mnt/和 vfat 字符串,說明可能是內/外置 SD 卡的掛載路徑
        if ( -1 != lines[i].indexOf( " /mnt/" ) && // 前面要有空格,以防斷章取義
             -1 != lines[i].indexOf( " vfat " ) )  // 前后均有空格
        {
            // 再以空格分隔符拆分字符串
            String[] blocks = lines[i].split( "http://s" ); // //s 為空格字符
            for ( int j = 0;
                      j < blocks.length;
                      j++ )
            {
                // 如果字符串中含有/mnt/字符串,說明可能是我們要找的 SD 卡掛載路徑
                if ( -1 != blocks[j].indexOf( "/mnt/" ) )
                {
                    // 排除重復的路徑
                    if ( -1 == strMountInfo.indexOf( blocks[j] ) )
                    {
                        // 用分號符(;)分隔 SD 卡路徑列表,
                        strMountInfo += blocks[j] + ";";
                    }
                }
            }
        }
    }

    return strMountInfo;
}

C 版代碼如下:

復制代碼 代碼如下:

char caStdOutLine[1024]; // mount 命令的標準輸出中的一行信息
char* pcTmpSDPath = NULL;

// 再用 mount 命令獲得的找身份認證鎖
do // 非循環,只是為了方便控制分支層次,便于控制分支流向
{
    // 通過創建一個管道,調用 fork 產生一個子進程,
    // 執行一個 shell 以運行命令來開啟一個進程。
    // 這個進程必須由 pclose() 函數關閉。
    FILE* fp = popen( "mount", // 一個指向以 NULL 結束的 shell 命令字符串的指針,
                               // 這行命令將被傳到 bin/sh 并使用 -c 標志,
                               // 那么 shell 將執行這個命令從這個字符串中讀取。
                      "r" );   // 文件指針連接到 shell 命令的標準輸出

    if ( NULL == fp )
    {
        break;
    }

    while( NULL != fgets( caStdOutLine,
                          sizeof( caStdOutLine ),
                          fp ) )
    {
        // 如果 找到了你想要的 SD 卡掛載路徑 的話,則
        if ( 判斷條件 )
        {
            // 注:管道中的數據一定要讀完,不然會崩潰掉的
            continue; // 就不再試下一個掛載地址了
        }

        // 如果該行內有 /mnt/和 vfat 字符串,說明可能是內/外置 SD 卡的掛載路徑
        if ( NULL == strstr( caStdOutLine, " /mnt/" ) &&    // 前面要有空格,以防斷章取義
             NULL == strstr( caStdOutLine, " /storage/" ) ) // 前面要有空格,以防斷章取義
        {
            continue; // 不滿足條件說明這行不是內/外置 SD 卡的掛載路徑
        }

        if ( NULL == strstr( caStdOutLine, " vfat " ) )  // 前后均有空格
        {
            continue; // 不滿足條件說明這行不是內/外置 SD 卡的掛載路徑
        }

        // 再以空格分隔符拆分字符串
        pcTmpSDPath = strtok( caStdOutLine, " " );

        do // 這里是循環,嘗試每一個路徑
        {
            if ( ( NULL == pcTmpSDPath ) ||
                 ( '/0' == *pcTmpSDPath ) )
            {
                continue;
            }

            // 如果字符串中含有/mnt/字符串,說明可能是我們要找的 SD 卡掛載路徑
            if ( NULL == strstr( pcTmpSDPath, "/mnt/" ) &&
                 NULL == strstr( pcTmpSDPath, "/storage/" ) )
            {
                continue;
            }

            // TODO: 在此添加對 SD 卡路徑使用的語句,如果只是用其中一個,別忘了設置已找到想要 SD 卡路徑的標識

        }while ( pcTmpSDPath = strtok( NULL, " " ) );
    }

    // 關閉標準 I/O 流,等待命令執行結束,然后返回 shell 的終止狀態。
    // 如果 shell 不能被執行,
    // 則 pclose() 返回的終止狀態與 shell 已執行 exit 一樣。
    pclose( fp );

}while ( 0 );



方法二:
分析 cat /system/etc/vold.fstab 命令的返回信息,例如:
復制代碼 代碼如下:

$ cat /system/etc/vold.fstab
## Vold 2.0 fstab for Stingray
#######################
## Regular device mount
##
## Format: dev_mount <label> <mount_point> <part> <sysfs_path1...>
## label        - Label for the volume
## mount_point  - Where the volume will be mounted
## part         - Partition # (1 based), or 'auto' for first usable partition.
## <sysfs_path> - List of sysfs paths to source devices
######################

# external sd card
dev_mount sdcard-ext /mnt/sdcard-ext auto /devices/platform/sdhci-tegra.2/mmc_host/mmc1 /devices/platform/sdhci-tegra.2/mmc_host/mmc2

# flash drive connection to USB1
dev_mount usbdisk_1.0 /mnt/usbdisk_1.0 auto /devices/platform/tegra-ehci.0/usb2/2-1/2-1:1.0

# flash drive connection through hub connected to USB1
dev_mount usbdisk_1.1 /mnt/usbdisk_1.1 auto /devices/platform/tegra-ehci.0/usb2/2-1/2-1.1
dev_mount usbdisk_1.2 /mnt/usbdisk_1.2 auto /devices/platform/tegra-ehci.0/usb2/2-1/2-1.2
dev_mount usbdisk_1.3 /mnt/usbdisk_1.3 auto /devices/platform/tegra-ehci.0/usb2/2-1/2-1.3
dev_mount usbdisk_1.4 /mnt/usbdisk_1.4 auto /devices/platform/tegra-ehci.0/usb2/2-1/2-1.4
dev_mount usbdisk_1.5 /mnt/usbdisk_1.5 auto /devices/platform/tegra-ehci.0/usb2/2-1/2-1.5
dev_mount usbdisk_1.6 /mnt/usbdisk_1.6 auto /devices/platform/tegra-ehci.0/usb2/2-1/2-1.6
dev_mount usbdisk_1.7 /mnt/usbdisk_1.7 auto /devices/platform/tegra-ehci.0/usb2/2-1/2-1.7

C 版代碼如下:
char caStdOutLine[1024]; // cat 命令的標準輸出中的一行信息
char* pcTmpSDPath = NULL;
char* pcNotSpace = NULL;

// 用 /system/etc/vold.fstab 獲得的 SD 卡路徑找身份認證鎖
do // 非循環,只是為了方便控制分支層次,便于控制分支流向
{
    // 通過創建一個管道,調用 fork 產生一個子進程,
    // 執行一個 shell 以運行命令來開啟一個進程。
    // 這個進程必須由 pclose() 函數關閉。
    FILE* fp = popen( "cat /system/etc/vold.fstab", // 一個指向以 NULL 結束的 shell 命令字符串的指針,
                                                    // 這行命令將被傳到 bin/sh 并使用 -c 標志,
                                                    // 那么 shell 將執行這個命令從這個字符串中讀取。
                      "r" );                        // 文件指針連接到 shell 命令的標準輸出

    if ( NULL == fp )
    {
        break;
    }

    while( NULL != fgets( caStdOutLine,
                          sizeof( caStdOutLine ),
                          fp ) )
    {
        // 如果 找到了你想要的 SD 卡掛載路徑 的話,則
        if ( 判斷條件 )
        {
            // 注:管道中的數據一定要讀完,不然會崩潰掉的
            continue; // 就不再試下一個掛載地址了
        }

        // Format: dev_mount <label> <mount_point> <part> <sysfs_path1...>
        // 去除開頭的空格
        pcNotSpace = caStdOutLine + strspn( caStdOutLine, " " );

        if ( NULL == pcNotSpace   ||
             '/0' == *pcNotSpace  ||
             '#'  == *pcNotSpace  || // 行首字符為#說明是注釋行
             'd' != pcNotSpace[0] || // 句子開頭不是 dev_mount
             'e' != pcNotSpace[1] ||
             'v' != pcNotSpace[2] ||
             '_' != pcNotSpace[3] ||
             'm' != pcNotSpace[4] ||
             'o' != pcNotSpace[5] ||
             'u' != pcNotSpace[6] ||
             'n' != pcNotSpace[7] ||
             't' != pcNotSpace[8] )
        {
            continue; // 不滿足條件說明這行不是內/外置 SD 卡的掛載路徑
        }

        // 再以空格分隔符拆分字符串
        pcTmpSDPath = strtok( pcNotSpace, " " );

        do // 這里是循環,嘗試每一個路徑
        {
            if ( ( NULL == pcTmpSDPath ) ||
                 ( '/0' == *pcTmpSDPath ) )
            {
                continue;
            }

            // 如果字符串中含有/mnt/字符串,說明可能是我們要找的 SD 卡掛載路徑
            if ( NULL == strstr( pcTmpSDPath, "/mnt/" ) &&
                 NULL == strstr( pcTmpSDPath, "/storage/" ) )
            {
                continue;
            }

            // TODO: 在此添加對 SD 卡路徑使用的語句,如果只是用其中一個,別忘了設置已找到想要 SD 卡路徑的標識

        }while ( pcTmpSDPath = strtok( NULL, " " ) );
    }

    // 關閉標準 I/O 流,等待命令執行結束,然后返回 shell 的終止狀態。
    // 如果 shell 不能被執行,
    // 則 pclose() 返回的終止狀態與 shell 已執行 exit 一樣。
    pclose( fp );
}while ( 0 );

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩在线视频一区| 欧美国产日韩一区| 久久精品精品电影网| 久久久久久久影院| 日韩精品一区二区三区第95| 永久免费毛片在线播放不卡| 中日韩美女免费视频网站在线观看| 久久网福利资源网站| 色老头一区二区三区在线观看| 精品久久久久久电影| 欧美国产日韩视频| 日韩美女视频免费看| 黑人巨大精品欧美一区二区| 操人视频在线观看欧美| 日韩av中文字幕在线免费观看| 久久久久国产精品一区| 国产精品嫩草影院一区二区| 亚洲精品97久久| 日韩少妇与小伙激情| 久久综合久久88| 国产成人久久久精品一区| 日韩中文在线中文网在线观看| 亚洲成人激情在线观看| 国产精品人成电影| 国产欧美日韩精品丝袜高跟鞋| 亚洲成人网在线观看| 欧美精品激情blacked18| 亚洲网站在线观看| 国产日韩欧美中文在线播放| 97久久精品视频| 国产欧美最新羞羞视频在线观看| 91精品国产综合久久香蕉922| 国产自摸综合网| 日韩最新av在线| 亚洲国产成人爱av在线播放| 91亚洲精品久久久久久久久久久久| 欧美性xxxx18| 国产成人在线一区二区| 38少妇精品导航| 亚洲美女久久久| 欧美成人精品激情在线观看| 欧美成人手机在线| 国产亚洲免费的视频看| 黄色成人av网| 在线观看亚洲视频| 亚洲深夜福利在线| 国产精品直播网红| 亚洲аv电影天堂网| 久久精品国产精品亚洲| 久久99视频精品| 在线成人激情视频| 精品偷拍各种wc美女嘘嘘| 日韩欧美亚洲国产一区| 久久久久久久久久国产精品| 欧美激情一区二区三区在线视频观看| 久久视频在线播放| 美日韩精品免费视频| 欧美黑人性生活视频| 免费成人高清视频| 最近日韩中文字幕中文| 国产亚洲在线播放| 日韩在线国产精品| 亚洲欧美日韩一区二区在线| 久久久久久午夜| 日韩成人av网| 成人免费视频xnxx.com| 一区国产精品视频| 日韩风俗一区 二区| 一区二区欧美在线| 久久综合伊人77777蜜臀| 精品中文字幕视频| 国产精品久久一区主播| 亚洲午夜色婷婷在线| 亚洲欧洲午夜一线一品| 欧美激情视频免费观看| 中文字幕一区二区三区电影| 在线视频日本亚洲性| 超碰日本道色综合久久综合| 亚洲女人天堂色在线7777| 亚洲精品资源美女情侣酒店| 在线视频欧美日韩| 亚洲日本中文字幕| 国产亚洲福利一区| 久久九九有精品国产23| 精品国产自在精品国产浪潮| 国产亚洲精品美女| 亚洲性xxxx| 成人黄在线观看| 亚洲v日韩v综合v精品v| 久久精品视频在线| 九九热精品视频| 亚洲国产精品电影在线观看| 国产欧美婷婷中文| 91久久中文字幕| 欧美精品一区二区三区国产精品| 亚洲国产精品va在线| 欧美视频裸体精品| 疯狂欧美牲乱大交777| 日韩av最新在线| 欧美日韩中文字幕| 久久综合免费视频影院| 啪一啪鲁一鲁2019在线视频| 国产精品激情av电影在线观看| 亚洲男人av在线| 欧美一级淫片videoshd| 亚洲精品电影在线观看| 热99精品里视频精品| 国产精品爽黄69天堂a| 成人在线视频网站| 久久久成人精品视频| 亚洲精品成人久久久| 日韩在线中文字幕| 伊人青青综合网站| 欧美国产精品日韩| 粉嫩老牛aⅴ一区二区三区| 国产一区二区三区久久精品| 日本久久中文字幕| 久久精品视频一| 91人人爽人人爽人人精88v| 中文字幕日韩在线播放| 亚洲缚视频在线观看| 欧美激情视频一区| 国产精品美女视频网站| 久青草国产97香蕉在线视频| 日本亚洲欧美三级| 日韩美女主播视频| 动漫精品一区二区| 久久精品中文字幕免费mv| 亚洲精品丝袜日韩| 国产精品一区二区三区久久久| 91在线观看免费观看| 91精品国产色综合久久不卡98口| 国语自产精品视频在线看抢先版图片| 国产精品女主播视频| 久久久午夜视频| 国产精品一区二区久久| 亚洲一区二区久久久久久| 色哟哟入口国产精品| 国产婷婷97碰碰久久人人蜜臀| 精品丝袜一区二区三区| 欧美中文字幕视频在线观看| 欧美日韩国产在线播放| 国产精品海角社区在线观看| 在线观看国产精品91| 欧美黄色www| 中日韩美女免费视频网站在线观看| 国产精品一区二区三区成人| 午夜欧美不卡精品aaaaa| 国产99视频在线观看| 欧美日韩高清在线观看| www.久久草.com| 国产亚洲精品高潮| 国产精品亚洲美女av网站| 亚洲自拍欧美另类| 精品二区三区线观看| 亚洲精品久久久久久久久| 欧美激情va永久在线播放| 欧美电影在线观看完整版| 亚洲va男人天堂| 成人欧美一区二区三区黑人孕妇| 亚洲欧美在线磁力| 久久久99久久精品女同性| 亚洲精品国产精品国自产观看浪潮| 欧美精品在线视频观看|