zoukankan      html  css  js  c++  java
  • Android shell 下 busybox,clear,tcpdump、、众多命令的移植

    http://my.oschina.net/mopidick/blog/167372

    作为一名Android开发者,经常需要进入Android 的shell终端运行一些命令。但是我们发现Android终端下的内置命令不仅少的可怜,如基本的清屏命令(clear)都没有,而且十分难用,如 ls  命令的显示简直奇丑无比!!

    这篇文章主要专注于解决上面两个问题,或许有的牛人会告诉你,直接在Android手机上装一个busybox,然后一切都搞定了。不过除了这个方法还有别的方法没,这篇文章会让你感受到新的认识!!

    这里我主要提供一下7个命令的移植:

    1
    2
    ubuntu@ubuntu:~/wxg-pku-android-project/android-shell-command-tools$ ls
    clear  ls  procrank  screenshot  strace  su  tcpdump  busybox

    其中  screenshot 是Android 截屏的命令, su  是获取Android root权限的命令,至于别的命令,读者可以自己百度,不一一介绍

    首先贴图看看效果:

    上面这张图是原始命令 ls 的显示图,下面这张是移植以后的  ls  的效果图

    是不是很爽,很熟悉的感觉!!

    下面开始移植,准备工作

    1、需要root权限的手机一部

    2、需要基本的linux shell 知识

    3、linux系统的pc(在windows下有替代品或许也可以,如虚拟机,或者Cygwin)

    我们以移植  ls  命令为例,剩下的命令移植方法跟下面的一样,请读者自己完成!

    步骤

    1、下载所有工具

    这里的工具包括上面需要移植的各种命令,还有获取手机root权限的工具:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    ubuntu@ubuntu:~$ mkdir tmp
    ubuntu@ubuntu:~$ cd tmp/
    ubuntu@ubuntu:~/tmp$ git clone https://code.google.com/p/wxg-pku-android-project/
    Cloning into 'wxg-pku-android-project'...
    remote: Counting objects: 22, done.
    Unpacking objects: 100% (22/22), done.
    ubuntu@ubuntu:~/tmp$ cd wxg-pku-android-project/
    ubuntu@ubuntu:~/tmp/wxg-pku-android-project$ ls
    android-shell-command-tools  SuperOneClickv2.3.3  test
    ubuntu@ubuntu:~/tmp/wxg-pku-android-project$ cd android-shell-command-tools/
    ubuntu@ubuntu:~/tmp/wxg-pku-android-project/android-shell-command-tools$ ls
    clear  ls  procrank  screenshot  strace  su  tcpdump

    可以在android-shell-command-tools文件夹下看到这几个命令,这就是我们需要移植到手机的命令。

    2、获取手机的root权限(已获取的就不需要这一步)

    在下载的文件中,有一个  SuperOneClickv2.3.3  文件夹,解压文件夹下的工具,可以看到里面有一个  SuperOneClick.exe  文件,在window下双击安装,最后用这个工具root 你的手机,这个非常easy,我就不多说了。

    当你的手机获取到root权限的时候, su  命令就植入到你的手机里了

    你可以运行以下命令确认一下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    ubuntu@ubuntu:~/tmp/wxg-pku-android-project/android-shell-command-tools$ adb shell
    shell@android:/ $ cd data
    shell@android:/data $ ls
    ls: can't open '.': Permission denied
    1|shell@android:/data $ su
    shell@android:/data # ls
    anr             dalvik-cache    drm             property        tombstones
    app             data            htcfs           radio           user
    app-private     data.sys.dex    local           resource-cache
    audio           data.sys.zip    lost+found      secure
    backup          dontpanic       misc            system
    shell@android:/data #

    可以看到,普通用户查看data下的内容会出错:Permission denied ,当用su切换到root的时候,就可以查看了

    3、移植 ls 命令

    1
    2
    3
    4
    5
    6
    ubuntu@ubuntu:~/tmp/wxg-pku-android-project/android-shell-command-tools$ ls
    clear  ls  procrank  screenshot  strace  su  tcpdump
    ubuntu@ubuntu:~/tmp/wxg-pku-android-project/android-shell-command-tools$ adb push ./ls /sdcard/
    1865 KB/s (849476 bytes in 0.444s)
    ubuntu@ubuntu:~/tmp/wxg-pku-android-project/android-shell-command-tools$ adb shell
    shell@android:/ $ cd /sdcard
    1
    2
    shell@android:/sdcard $ su
    shell@android:/mnt/sdcard # chmod 777 ./ls
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    shell@android:/sdcard # cp ./ls /data/local/
    shell@android:/sdcard # cd /data/local/ 
    shell@android:/data/local # ls
    ls       strace   tcpdump  tmp      toolbox
    shell@android:/data/local # ./ls
    ls       strace   tcpdump  tmp      toolbox
    shell@android:/data/local # ./ls /sdcard
    Amap                Tencent             log                 sogou
    Android             TestTrace.trace     ls                  stericson-ls
    BaiduMapSdk         UCDownloads         make                strace
    DCIM                Vlog.xml            mapbar              su
    Download            YJFDownloads        mitc                talk_log.txt
    FetionConnect       batterywatcher.apk  moji                tcpdump.pcap
    KuwoMusic           busybox             msf                 tigermap
    LOST.DIR            capture.pcap        p2pcache            toolbox-stericson
    My Documents        clear               powerword           trepn
    PicStore            downloads           procrank            video.log
    QCDownload          gmon.out            qqsecure            videoEngine.log
    QQSecureDownload    jingdong            scriptlog.txt       wandoujia
    Qianyu              kingsoft            sina                wukongbeng.apk
    Renren              libs                sod.log             wxg

    说明:首先,我们将  ls 命令由 pc  上传  到手机的  /sdcard 目录下,然后却换到root用户,用chmod 给  ls 添加执行权限,然后将sdcard目录下的  ls  拷贝到 /data/local/目录下,执行我们自己的  ls 命令查看当前目录以及 /sdcard目录下的内容,发现我们自己的 ls 命令执行成功,显示不再是单一排列,且有了颜色!!

    4、将自己的  ls 命令拷贝到 /system/bin目录下(都需要su却换到root)

    虽然上面的步骤已经完成了 ls 命令的移植,但是结果并不满意,因为我们不想每回运行都要带上 /data/local/ls  这个字眼,这么麻烦!!

    我们尝试以下命令,将 ls 拷贝到 /system/bin目录下

    1
    2
    3
    shell@android:/ # cp /data/local/ls /system/bin
    cp: can't create '/system/bin/ls': Read-only file system
    1|shell@android:/ #

    由于/system/bin/目录是只读的,你无法拷贝进去!解决方法如下:先用mount命令找到 /system 目录是从哪个设备挂载而来 

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    <strong>shell@android:/ # 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
    /dev/block/mmcblk0p25 /system ext4 ro,relatime,user_xattr,barrier=1,data=ordered 0 0
    /dev/block/mmcblk0p26 /data ext4 rw,nosuid,nodev,relatime,user_xattr,barrier=1,data=ordered,noauto_da_alloc 0 0
    /dev/block/mmcblk0p28 /cache ext4 rw,nosuid,nodev,relatime,user_xattr,barrier=1,data=ordered 0 0
    /dev/block/mmcblk0p29 /devlog ext4 rw,nosuid,nodev,relatime,user_xattr,barrier=1,data=ordered 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
    tmpfs /data/secure/data tmpfs rw,relatime,mode=771,uid=1000,gid=1000 0 0
    tmpfs /data/secure/data tmpfs rw,relatime,mode=755,gid=1000 0 0
    htcfs /data/htcfs fuse.htcfs rw,nosuid,nodev,relatime,user_id=0,group_id=0,allow_other 0 0
    /dev/block/vold/179:32 /mnt/emmc 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:65 /mnt/sdcard 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:65 /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/.android_secure tmpfs ro,relatime,size=0k,mode=000 0 0
    /dev/block/dm-0 /mnt/asec/com.tencent.peng-2 vfat ro,dirsync,nosuid,nodev,relatime,uid=1000,fmask=0222,dmask=0222,codepage=cp437,iocharset=iso8859-1,shortname=mixed,utf8,errors=remount-ro 0 0 </strong>
    1
    shell@android:/ #

    找到这一行

    1
    /dev/block/mmcblk0p25 /system ext4 ro,relatime,user_xattr,barrier=1,data=ordered 0 0

    我们发现挂载到/system下的设备是(读者的设备很可能跟我的不一样,所以不要照搬我的命令):

    1
    /dev/block/mmcblk0p25

    那么我现在要做的就是,将这个设备重新挂载,并且挂载为可读可写(rw)

    1
    2
    shell@android:/ # mount -o remount,rw /dev/block/mmcblk0p25 /system
    shell@android:/ #

    这样我们就可以对 /system目录进行任意的读写了!!

    1
    shell@android:/ # rm /system/bin/ls
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    shell@android:/ # cp /data/local/ls /system/bin/ls
    shell@android:/ # ls
    acct                 etc                  root
    cache                init                 sbin
    config               init.goldfish.rc     sdcard
    cwkeys               init.primods.rc      sys
    d                    init.rc              system
    data                 init.usb.rc          ueventd.goldfish.rc
    default.prop         logo.rle             ueventd.primods.rc
    dev                  mnt                  ueventd.rc
    devlog               proc                 vendor
    shell@android:/ #

    我们先把系统自带的 ls 命令删除,然后将自己的 ls 命令复制到 /system/bin/ 目录下 !!

    就这样,我们大功告成了,把自己的 ls 命令移植成功,剩下的命令移植读者自己可以自己独立完成,有问题可以联系哦、

    总结:

    要点有2点:

    1、获取手机的root权限,将  su  命令移植到手机上

    2、用  mount  命令重新挂在 /system  目录为可读可写 !

  • 相关阅读:
    有趣的开源家族合照,看看你认识几个?
    fieldset 使用小案例
    java XMPPserver openfire VS tigase
    tomcat 7 jmx配置访问
    JAVA静态域及容器的内存占用探究
    checkStyle字符集不支持解决--Got an exception
    遇到一个很无语的Andorid问题! button 里 android:textColor 属性 设置一个选择器报错!
    android 关于为什么在onCreate里调用view.getChildAt(1).getLeft() 没有值!
    关于Android studio 怎么使用代码混淆的问题!
    sdk manager.exe 闪退 解决办法!
  • 原文地址:https://www.cnblogs.com/bigben0123/p/4953633.html
Copyright © 2011-2022 走看看