Android Root原理初探
Root
Linux:Root == Windows:Adminstrator
Android是Linux系统吗?
操作系统 = 系统内核 + 文件系统
Linux发行版:Linux内核 + 文件系统(ext3/4)
Android:Linux内核 + 文件系统(ext3/4)
Android 没有本地窗体系统
而Linux是能够脱离X窗体的。
Android 没有glibc library
Android并不包含一整套标准的Linux应用程序
而Linux也是能够脱离这两点的。
Android内置了专有的驱动程序
然并卵。Linux的内核也分主次,驱动程序也不是不能脱离的,仅仅是去掉后无法识别相应的设备。并不影响Linux的内核的装载和运行。并且在Linux Kernel Configuration里能够自由配置须要卸载的项目。不能由于添加了驱动就觉得不是Linux。并非决定操作系统性质的关键。
推断操作系统种类的并非其上层建筑,而是深层的系统内核和文件结构。
Linux内核中与驱动相关且比較核心的是驱动接口(Linux驱动运行和安装规范)。是一套二进制规范。
综上。Android实质上是Linux。
那么,Root对于Android意味着什么?
用su命令切换到root用户
Android为什么要Root?
删除非官方或定制系统预装的垃圾应用
- 拥有root权限后直接复制
- 依据Android Rom复制
- 通过Recovery升级包方式复制
控制开机载入项
拥有很多其它权限
调试Linux驱动
改动启动画面
提取Root权限的步骤
1.刷一个合适的Recovery
方法一:在bootloader模式下复制整个文件系统
方法二:在Recovery模式将文件拷贝到Android设备的指定文件夹
通过adb reboot bootloader命令或者关机下按组合按键进入bootloader模式。
fastboot:
危急的命令:
fastboot flash bootloader bootloader.img
// 假设bootloader.img错误。则须要更换主板
自毁命令:
fastboot erase bootloader
// 擦除
刷Recovery:
fastboot flash recovery recovery.img
重新启动设备
fastboot reboot
2.改造su命令的源码
Android自带的su命令仅仅同意root和shell用户(adb shell)调用
3.制作Recovery刷机文件(*.zip)
主要由待复制的文件和Edify语言(用于对文件和文件夹进行操作)编写的脚本文件组成
编写Recovery升级包中的updater-script脚本文件,将su命令拷贝到/system/xbin文件夹中。
4.运行su命令提取Root权限
改造后的su命令,能够被终端和App调用。
5.让ROM本身拥有Root权限(非必需)
不然进入终端运行su命令后才拥有Root权限。
Edify
Android内嵌脚本语言。用于编写updater-script脚本文件。
updater-script是Recovery Rom和升级包的核心。全然由函数组成。
ui_print(msg_1,…,msg_N);
用于在Recovery界面输出字符串,至少须要一个參数。指定多个參数,会将參数值连起来输出。
run_program(prog, arg1,…,argN);
该函数用于运行程序,prog參数是必需的,表示要运行程序文件的完整路径。
其它參数可选。如:
run_program(“/sbin/busybox”,”mount”,”/system”);
delete(file1,…,fileN);
删除一个或多个文件,參数为文件的路径。如:
delete(“/system/xbin/su”);
package_extract_dir(package_path, destination_path);
用于提取刷机包指定文件夹package_path的全部文件到目标文件夹destination_path。
set_perm(uid, gid, mode, file1,…fileN);
设置一个或多个文件的权限。
uid是用户id。gid是用户组id。
假设想让文件的用户和用户组都是Root,须要将uid和gid设为0。
mount(fs_type, partition_type, location, mount_point);
挂载分区。如:
mount(“ext4”, “EMMC”, “/dev/block/paltform/s3c-sdhci.0/by-name/system”, “/system”);
unmount(mount_point);
卸载分区。
如:
unmount(“/system”);
$(function () {
$('pre.prettyprint code').each(function () {
var lines = $(this).text().split('\n').length;
var $numbering = $('
$(this).addClass('has-numbering').parent().append($numbering);
for (i = 1; i ').text(i));
};
$numbering.fadeIn(1700);
});
});
Android Root原理初探的更多相关文章
- Android root 原理
Android root 原理 0x00 关于root linux和类Unix系统的最初设计都是针对多用户的操作系统,对于用户权限的管理很非常严格的,而root用户(超级用户)就是整个系统的唯一管理员 ...
- Android Root原理
概述:通过阅读本文可以深刻理解Android系统中获得Root权限的方法和原理.本文会详细介绍Root的目的,原理和代码层次的具体实现方法. Android Root介绍: 1. Root目的 手机获 ...
- Android系统Root原理初探(转)
http://www.imooc.com/learn/126 chkconfig setup 解压update.zip这个文件,可发现它一般打包了如下这几个文件: 或者没有updates而是syste ...
- [转] Android root 原理
欢迎转载,转载请注明出处:http://www.cnblogs.com/lanrenxinxin/p/5572640.html 0x00 关于root linux和类Unix系统的最初设计都是针对多用 ...
- Android root检测方法小结
转载目的,之前主要应用这里的原理解决了,手机被某个APP检测为root过的手机的问题,记录后续可能参考. 出于安全原因,我们的应用程序不建议在已经root的设备上运行,所以需要检测是否设备已经root ...
- [Android Pro] android root权限破解分析
许 多机友新购来的Android机器没有破解过Root权限,无法使用一些需要高权限的软件,以及进行一些高权限的操作,其实破解手机Root权限是比较简 单及安全的,破解Root权限的原理就是在手机的/s ...
- 基于unity3d游戏的android版本逆向初探
https://bbs.pediy.com/thread-212532.htm [文章标题]: 基于unity3d游戏的android版本逆向初探 [文章作者]: dreaman [作者邮箱]: [e ...
- Android ADB原理及常用命令
Android调试桥(ADB, Android Debug Bridge)是一个Android命令行工具,包含在SDK 平台工具包中,adb可以用于连接Android设备,或者模拟器,实现对设备的控制 ...
- NFC(6)NFC编程的几个重要类,NFC硬件启动android应用原理
用于NFC编程的几个重要类 Tag NFC 标签 NfcAdapter Nfc 的适配类 NdefMessage 描述NDEF格式的信息 NdefRecord 描述NDEF信息的一个信息段,类似tab ...
随机推荐
- 开发中关于Git那些事
如果你想精通Git,直接到 Git官网 把这本ProGit掌握已足以Pro Git 此文主要介绍一切开发中常用的git命令和一些配置技巧(诸如git别名配置,log打印技巧,版本回退以及分支管理等). ...
- 第一章 Linux系统介绍与环境搭建准备
1.操作系统: Operating System,简称OS,它是应用程序运行以及用户操作必备的基础环境支撑,是计算机系统的核心. 操作系统就是处于用户与计算机系统硬件之间用于传递信息的系统程序软件. ...
- StringBulider与StringBuffer的异同
相同点:两者的功能都是相同的,没有任何差别. 不同点:StringBulider 不是同步的,也是线程不安全的,当使用多线程处理缓冲区时,不能使用.但是单线程访问的时候效率高,如果是单线程处理缓冲区资 ...
- Python 面向对象基础知识
面向对象基础知识 1.什么是面向对象编程? - 以前使用函数 - 类 + 对象 2.什么是类什么是对象,又有什么关系? class 类: def 函数1(): pass def 函数2(): pass ...
- 基于gitHub+hexo搭建的个人博客
文章导航 前期准备 安装hexo 修改hexo主题 自定义主题 部署本地文件到github查看 我的第一篇博客 前期准备 下载安装git命令行工具.node及npm环境 注册自己的GitHub账号 安 ...
- phpcms 的getcache()函数
一直没有去研究phpcms 的getcache()函数是干嘛的,今天有空去看了一下,原来就那样. 1 function getcache($name, $filepath='', $type='fil ...
- python基础阶段练习题 拾英札记(1)
python很灵活,学起来有人机交互的快乐感,贵在坚持. 做题对自学python很有帮助,融汇贯通-查漏补缺-巩固提高. 写了一些注释,希望能对您有所帮助. #1.输入一个3位数,计算个位.百位.十位 ...
- [转载] 十五分钟介绍 Redis数据结构
转载自http://blog.nosqlfan.com/html/3202.html?ref=rediszt Redis是一种面向“键/值”对类型数据的分布式NoSQL数据库系统,特点是高性能,持久存 ...
- TweenMax动画库学习
之前在做HTML5移动端开发的时候,用的都是Animate.css,这个插件封装的的确很好,但是在做一些缓动方面的动画,它也有一定的不足之处,比如手要写一个连续的动画,需要不停的去重复写函数,使得代码 ...
- 脱掉Golang的第一层衣裳 golang入坑系列
读前必读,博客园的文章并非最新,想看最新还是建议点击这里.博客园的文章是为了方便不能FQ的同学,同步而来的.不放在博客园,不是不支持国产,而是博客园的排版太难看了,太难看了,太难看了!而且还没有客户端 ...