Android安全入门基础-ADB详解

ADB是什么

adb的全称为Android Debug Bridge,就是起到调试桥的作用。通过adb我们可以在IDE中方面通过DDMS来调试Android程序,说白了就是debug工具。 adb的工作方式比较特殊,采用监听Socket TCP 5554等端口的方式让IDE和Qemu通讯,默认情况下adb会daemon相关的网络端口,所以当我们运行IDE时adb进程就会自动运行。

adb的全称为Android Debug Bridge,就是起到调试桥的作用。通过adb我们可以在Eclipse中方面通过DDMS来调试Android程序,说白了就是debug工具。 adb的工作方式比较特殊,采用监听Socket TCP 5554等端口的方式让IDE和Qemu通讯,默认情况下adb会daemon相关的网络端口,所以当我们运行Eclipse时adb进程就会自动运行。
对于安卓开发与测试来说就像一把“瑞士军刀”

ADB可能存在的安全隐患

ADB本身是Android手机开发时的调试工具,但是也可以用来作为手机管理工具。
基本上现在的豌豆荚(豌豆荚会自动在手机上安装其APP-静默安装)、360手机助手、qq手机助手对手机的管理功能都是通过ADB来实现。
ADB的管理功能需要手机打开调试选项,这为手机管理提供了方便,同时也造成了安全隐患。
因为ADB工具可以实现查看手机内容、向手机写入文件、给手机安装软件等功能,这些都不需要root权限。
当我们打开手机的调试选项,并使用USB线将手机连接到PC时,不仅仅是手机管理工具可以控制手机,只要调用ADB命令,任何PC端的程序都可以访问手机内容。
假设有一个运行在PC端的间谍程序,那么就很容易检测到手机与PC的连接,而且只要一条很简单的命令"adb.exe shell ls /"就可以列出手机根目录下的所有文件了。
其实如果打开了手机的调试选项,那么手机连接到PC后就是在“裸奔",手机中的所有信息都可以被PC端抓取,其实这也就是现在流行的手机管理工具的基本原理。
所以如果需要保护手机上的私密信息,那么最好谨慎打开手机的USB调试选项

ADB常见命令

  • 设备列表
    adb devices // 显示连接到计算机的设备

  • 序列号
    adb get-serialno

  • 终止&重启adb服务进程
    adb kill-server // 终止adb服务进程
    adb start-server // 重启adb服务进程

  • 发送命令到设备
    adb [-d|-e|-s <serialNumber>] <command>
    -d 发送命令给usb连接的设备
    -e 发送命令到模拟器设备
    -s <serialNumber> 发送命令到指定设备

  • 文件传输
    adb push <local> <remote> // 从本地复制文件到设备
    adb pull <remote> <local> // 从设备复制文件到本地

  • 静默安装&缷载
    adb install <apkfile> // 安装apk
    adb install -r <apkfile> // 保留数据和缓存文件,重新安装apk
    adb install -s <apkfile> // 安装apk到sd卡
    adb uninstall <package> // 卸载app
    adb uninstall -k <package> // 卸载app但保留数据和缓存文件

  • 无线连接
    adb connect 192.168.1.101 确保手机与PC在同一WIFI环境下

ADB高级命令

  • adb shell

    1. am

      • 启动一个activity :adb shell am start[options]
        adb shell am start -a com.lt.test.action.SECOND
        adb shell am start -n com.lt.test/.MyActivity
      • 启动一个service :am startservice [options]
        adb shell am startservice -acom.lt.test.action.ONESERVICE
        adb shell am startservice -n com.lt.test/.MyService
      • 强制关闭一个应用程序: adb shell am force-stop package
      • 发送一个广播:am broadcast [options]
        adb shell am broadcast -a "action_finish"(发送一个广播去关闭一个activity)
        adb shell am broadcast -n com.lt.test/.MyBroadcast
    2. pm

      • adb shell pm list package [option]列出所有已安装包
        -3 第三方
        -s 系统
        -i 安装来源
        -f 安装路径
      • adb shell pm clear <PACKAGE> 对指定的package删除所有数据
    3. wm

      • 获取屏幕分辨率 adb shell wm size
      • 获取屏幕密度 adb shell wm density
    4. settings
      从4.2开始,Android提供了一个命令行工具settings。这个工具用于帮助构造SettingProvider的客户端代理,从而可以方便的进行系统设置项的读取和设置。但是这个工具和adb配合起来,将对Android的安全构成极大的威胁。

      • adb shell settings put secure install_non_market_apps 1 设置开启未知来源APK安装
      • adb shell settings get secure default_input_method 获取默认输入法
      • adb shell settings put secure default_input_method com.sohu.inputmethod.sogouoem/.SogouIME
      • adb shell settings get global wifi_on 获取wifi状态
      • adb shell settings put global wifi_on 1 设置wifi状态
      • adb shell settings get system screen_off_timeout 获取屏幕休眠时间
    5. 获取当前屏幕Activity
      adb shell dumpsys activity | findstr "mFocusedActivity"

    6. WIFI密码
      adb shell cat /data/misc/wifi/*.conf

  • 其它命令

    1. 截屏工具
      adb shell screencap -p 使用adb命令进行截屏操作
    2. 录屏工具
      adb shell screenrecord [options] 使用 adb 命令进行视屏录制
      [options] 可以填写:
      size WIDTH*HEIGHT
      bit -rete
      -time -limit 时间限制等

手机&&应用安全案例

  • 破解手机开发密码&手势密码
    adb shell
    cd data/system
    rm rm gesture.key
    rm password.key
    reboot

  • 绕过APP手势解锁

  • allowbackup安全风险
    Android API Level 8及其以上Android系统提供了为应用程序数据的备份和恢复功能,此功能的开关决定于该应用程序中AndroidManifest.xml文件中的allowBackup属性值[1]. ,其属性值默认是True。当allowBackup标志为true时,用户即可通过adb backup和adb restore来进行对应用数据的备份和恢复,这可能会带来一定的安全风险。

    Android属性allowBackup安全风险源于adb backup容许任何一个能够打开USB 调试开关的人从Android手机中复制应用数据到外设,一旦应用数据被备份之后,所有应用数据都可被用户读取;adb restore容许用户指定一个恢复的数据来源(即备份的应用数据)来恢复应用程序数据的创建。因此,当一个应用数据被备份之后,用户即可在其他Android手机或模拟器上安装同一个应用,以及通过恢复该备份的应用数据到该设备上,在该设备上打开该应用即可恢复到被备份的应用程序的状态。

    尤其是通讯录应用,一旦应用程序支持备份和恢复功能,攻击者即可通过adb backup和adb restore进行恢复新安装的同一个应用来查看聊天记录等信息;对于支付金融类应用,攻击者可通过此来进行恶意支付、盗取存款等;因此为了安全起见,开发者务必将allowBackup标志值设置为false来关闭应用程序的备份和恢复功能,以免造成信息泄露和财产损失。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,670评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,928评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,926评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,238评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,112评论 4 356
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,138评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,545评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,232评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,496评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,596评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,369评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,226评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,600评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,906评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,185评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,516评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,721评论 2 335

推荐阅读更多精彩内容

  • android开发环境中,ADB是我们进行android开发经常要用的调试工具,它的使用当然是我们Android开...
    Memebox阅读 6,044评论 0 32
  • 1、adb 简介 Android Debug Brige 安卓调试桥 2、安装 1)Windows: 1、按照...
    Jane_cd88阅读 1,158评论 1 1
  • Android 调试桥 Android 调试桥 (adb) 是一个通用命令行工具,其允许您与模拟器实例或连接的 A...
    guanjm阅读 1,432评论 0 1
  • ADB Android 调试桥 (adb) 是一个通用命令行工具,其允许您与模拟器实例或连接的 Android 设...
    Mr槑阅读 3,889评论 1 8
  • 请给我一束光 在黑夜 我的声音多么渺小 人们都清醒着 他们安乐而富足 在黑夜挣扎的人 缺少光明指引 多么苛且 月亮...
    我形我素阅读 571评论 3 7