permission文件的处理
在PMS的构造方法中初始化了PermissionManagerService,通过PermissionManagerService.create()方法,相关调用如下:
public static PermissionManagerInternal create(......) {
......
new PermissionManagerService(context, defaultGrantCallback, externalLock);
......
}
PermissionManagerService(......) {
......
mHandlerThread = new ServiceThread(TAG,
Process.THREAD_PRIORITY_BACKGROUND, true /*allowIo*/);
mHandlerThread.start();
mHandler = new Handler(mHandlerThread.getLooper());
Watchdog.getInstance().addThread(mHandler);
......
SystemConfig systemConfig = SystemConfig.getInstance();
mSystemPermissions = systemConfig.getSystemPermissions();
......
}
上面列出来PermissionManagerService初始化的过程中两个操作:
- 注册
Watchdog监听,此处列出它来主要是为了呼应前面的章节。哈哈哈,重点是第二点 - 通过
SystemConfig的getSystemPermissions方法来获取系统的Permission列表public SparseArray<ArraySet<String>> getSystemPermissions() { return mSystemPermissions; }
而对于mSystemPermissions,是在SystemConfig的构造方法中完成的,相关代码如下:
//单例模式
SystemConfig() {
// 读取 /system/etc/sysconfig 目录下的 permission 文件
readPermissions(Environment.buildPath(
Environment.getRootDirectory(), "etc", "sysconfig"), ALLOW_ALL);
// 读取 /system/etc/permissions 目录下的 permission 文件
readPermissions(Environment.buildPath(
Environment.getRootDirectory(), "etc", "permissions"), ALLOW_ALL);
......
// 读取 /vendor/etc/sysconfig 目录下的 permission 文件
readPermissions(Environment.buildPath(
Environment.getVendorDirectory(), "etc", "sysconfig"), vendorPermissionFlag);
// 读取 /vendor/etc/permissions 目录下的 permission 文件
readPermissions(Environment.buildPath(
Environment.getVendorDirectory(), "etc", "permissions"), vendorPermissionFlag);
...// 省略 /oem、/odm、/product对应分区目录下 readPermissions()
}
不用说,核心是这个readPermissions()方法,看看:
void readPermissions(File libraryDir, int permissionFlag) {
// Read permissions from given directory.
if (!libraryDir.exists() || !libraryDir.isDirectory()) {
return;// 如果目录不存在或者libraryDir不是目录,直接返回
}
if (!libraryDir.canRead()) {
return;// 如果目录不可读,直接返回
}
File platformFile = null;
// 循环能处理目录文件
for (File f : libraryDir.listFiles()) {
if (f.getPath().endsWith("etc/permissions/platform.xml")) {
// 检测到platform.xml文件,先记录,循环中不做处理
platformFile = f;
continue;
}
if (!f.getPath().endsWith(".xml")) {
// 跳过非xml文件
continue;
}
if (!f.canRead()) {
// 跳过不可读文件
continue;
}
readPermissionsFromXml(f, permissionFlag);// 解析xml
}
// 最后,解析platform.xml文件
if (platformFile != null) {
readPermissionsFromXml(platformFile, permissionFlag);
}
}
readPermissions()方法先检测指定目录下的xml文件,然后调用readPermissionsFromXml方法来解析文件并将解析结果填充到SystemConfig对应的数据结构中。
readPermissionsFromXml()方法内容如下:
private void readPermissionsFromXml(File permFile, int permissionFlag) {
FileReader permReader = new FileReader(permFile);
......
try {
XmlPullParser parser = Xml.newPullParser();
parser.setInput(permReader);
int type;
// 查找 START_TAG 或 END_DOCUMENT
while ((type=parser.next()) != parser.START_TAG
&& type != parser.END_DOCUMENT) {
;
}
// 从 START_TAG 开始解析
if (type != parser.START_TAG) {
throw new XmlPullParserException("No start tag found");
}
// 只针对<permissions/>和<config/>标签进行解析
if (!parser.getName().equals("permissions") && !parser

最低0.47元/天 解锁文章
2183

被折叠的 条评论
为什么被折叠?



