`
zag132zz
  • 浏览: 11135 次
最近访客 更多访客>>
社区版块
存档分类
最新评论

通用(任何android机型)Root教程(完整版!附砖机自救方法)转自安卓网

 
阅读更多

通用(任何android机型)Root教程(完整版!附砖机自救方法)转自安卓网
2012年01月02日
  一台android终端(可能是手机、可能是平板,也可能是其它),很多功能是要取得Root权限后才能使用的。那我们就来Root它。
  取得root权限只要在机器里放两个文件就可以了
  /system/bin/su(取得root权限的命令)
  /system/xbin/su(同上,只不过是有些软件只认这个路径)
  /system/app/SuperUser.apk(Root权限管理器)
  上面明明是三个文件,为什么说两个呢?其实前面两个文件就是同一个文件,熟悉linux等系统的就知道,用ln做个软连接就可以了。
  说实在的Android就是Linux的一个分支。不信就看看你机器的内核版本就懂了。
  ln -s /system/bin/su /system/xbin/su
  在android设备上运行以上命令可以在/system/xbin路径中生成/system/bin/su的软连接文件(可以理解为windows下的“快捷方式”)
  除了放上面讲的两个文件,即:
  /system/bin/su
  /system/app/SuperUser.apk
  还需要设置/system/bin/su可以让任意用户可运行,有set uid和set gid的权限。即要在android机器上运行下面的命令:
  chmod 4755 /system/bin/su
  貌似做到这些都比较简单。在android市场中安装一个connectbot,把su和SuperUser.apk拷贝到SD卡上,然后用ConnectBot在本机上开命令窗口,cp ln chmod一下就可以了。但实际是不行的。
  为什么呢?原因有三:
  1、/system路径是只读权限,不能简单写入
  2、 chmod需要Root权才能运行(死循环了)
  3、有些系统在启动时会自动将su的4755权限设成755,甚至直接删除su
  那怎么办呢?
  本层要部分解决的就是上面遗留的三个问题。
  既然走正常程序,行不通,就要换个思路,走走后门了。
  后门在哪里呢?
  Google还是很厚道的,Android有个用于开发的后门,供Android系统和应用软件的开发者调试程序用的。
  如何打开后门?有三项工作:
  1、用数据线连接android设备到PC
  2、在PC上安装android设备的驱动程序。
  3、在android设备上设打开发调试模式(settings->applications->development->USB debugging)
  怎么用?
  google的android SDK包里面有两个小程序:1、adb 2、fastboot。fastboot用来刷机,adb可以以Root的身份让android设备执行一些命令。
  用法:
  把附件下载到电脑。
  解压附件到电脑
  参考上文,打开android设备的后门
  用资源管理器打开附件数据包解压出来的文件夹
  不要选择任何文件或文件夹,按住Shift键鼠标右击资源管理器空白部分,在弹出菜单中选择“在此处打来命令窗口”。
  (也可以先大开命令窗口,用cd等命令将当前路径切换到附件数据包解压出来的文件夹)
  在命令窗口敲命令,然后重启android完成Root
  adb remount
  adb push su /system/bin
  adb push SuperUser.apk /system/app
  adb shell ln -s /system/bin/su /system/xbin/su
  adb shell chmod 4755 /system/bin/su
  部分遗留问题:
  1、少数Android设备运行adb remount时会报错,显示/system不能被remount成可读写模式
  2、重启后/system/bin/su文件的权限被改写,失去setuid setgid的权限(即重启后不能正常取得Root权),甚至/system/bin/su直接被删除
  该怎么解决呢?呵呵,偶还留了一层备用,大家知道会怎样了吧?!
  现在要解决重启丢失Root权和 adb remount不能让/system目录转成可读写的问题。
  造成这些问题基本都是系统在启动内核的时候设置的锁。
  如何解锁呢?我们先要说说Android终端的启动。
  一般来说Android终端能启动到三种不同的模式
  1、正常启动
  2、bootloader模式
  3、revocery模式
  正常启动Android终端,系统会自动调用boot镜像中的内核,然后是到system中加载配置和启动预定程序,最后到userdata中继续加载用户配置和用户预装的程序。
  一般一个新的Android终端拿来,第一次启动时,只有boot和system中有数据,userdata中是空的,我们安装软件、修改配置等操作只能影响userdata。所以没有ROOT的Android终端是很安全的,实在是系统装的很乱、软件冲突、死机,只要清除userdata中的数据(回出厂状态)就好了。(内置的用户存储空间和外加存储都属于userdata的一部分)
  既然boot中有锁,不能取得Root权,我们就只好放弃原版boot,去寻找第三方开发的boot(简单的用“一键root”之类的软件是解决不了问题的),然后刷机...
  bootloader模式就提供了通过USB线刷机的接口。用android SDK中提供的小工具fastboot就可以完成刷机(线刷)
  recovery模式也提供了通过Android终端上的数据存储刷机的办法(卡刷),只是原版Andriod终端自带的recovery会识别刷机包的数字签名,非官方发布的刷机数据包是不太可能通过这种办法刷机的。所以玩Android终端的老鸟是不会用原版的Recovery的。
  第三方开发的recovery基本上是采用文本菜单方式操作,识几个E文的应该操作起来不会有问题,只要找到自己机器型号对应的刷机包就可以了。本楼主就不多废话了。
  重点讲bootloader模式刷机
  【如何进入bootloader】
  大家还记得顶层的adb吗? 不记得就上楼复习。
  命令窗输入
  adb reboot bootloader
  可进入重启系统进入bootloader模式
  (附:命令窗输入adb reboot recovery 可中起进入recovery模式)
  注意复习顶楼课程,输入adb命令前必须的几部操作(接数据线、装驱动、andriod终端设为usb debug模式、在adb文件夹开命令窗口)
  当然还有其他方法:比如已经Root的机器可以装个小软件,一键重启切换到bootloader或者recovery
  还有一种方法很重要,掌握了可以让你的机器永远不会因为刷机变砖,或者将砖机救回来。
  1、关机
  2、按住特定键(大部分是“上”键,不同的机型不一样)开机,或者开机,按特定键
  进入bootloader以后用fastboot刷机,当然首先要找到自己Android终端对应的刷机数据包(boot.img,revocery.img,system.img )
  当然要把刷机数据*.img放在fastboot同一文件夹(除非你喜欢敲很多相对或绝对路径)
  fastboot flash boot boot.img
  (刷boot)
  fastboot flash recovery recovery.img
  (刷recovery)
  fastboot flash system system.img
  (刷Android系统)
  fastboot flash userdata data.img
  (刷用户数据)
  fastboot reboot
  (重启到正常模式)
  各位刷成砖机的,只要能进bootloader砖机就能救回来
  现在google、百度这么强,相信各位找个自己设备对应的*.img不是什么难事。
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics