修改Android系统的文件的权限

引言:
这个总结的起因是因为,有一个自定义的.sh文件,例如init.qcom.testscripts.sh脚本,它的作用就是我在重新将它编译到 Android系统中的时候,烧录完系统,他可以在开机的时候自己执行脚本内容.

总结:文章所要描述的就是如何将自己定义的一个.sh文件在编译成系统版本后从“无执行权限”,变成“有执行权限”,而不是等系统启动后自己去手动新修改chmod权限

1.先来放一段博主查询过的资料:

根据相关资料 生成System.img 的原理

【打包命令:./make_ext4fs -l 1024M -s -a system system_new.img systemimg 】

参数解析:
①1024M代表你要打包的system.img大小,这个值可以参考挂载前system.img的大小

②"-a system",是指这个img用于android系统,-a 应该是a 分区 ,还有 -b 分区

挂载点是/system,
使用这个参数,make_ext4fs会根据private/android_filesystem_config.h里定义好的权限来给文件夹里的所有文件重新设置权限,如果你刷机以后发现有文件权限不对,可以手工修改android_filesystem_config.h来添加权限,重新编译make_ext4fs,也可以不使用
“-a system”参数,这样就会使用文件的默认权限。 配置以下文件,对文件的具体权限进行配置

重点就是:make_ext4fs会根据private/android_filesystem_config.h里定义好的权限来给文件夹里的所有文件重新设置权限 这句话,至于查到资料里的make_ext4fs ,我并没有使用,因为不符合需求,需求就是无论怎么打包,或者说是项目其他人打包也能要使得这个 init.qcom.testscripts.sh脚本可以被执行。

2.于是根据android_filesystem_config.h线索继续查找有用资料:

通常在BSP开发过程中需要对Android
system镜像进行改动,新追加的文件可能需要配置其默认权限,也有可能需要给新追加的native进程分配用户组,那么如何配置文件系统的权限呢?
Android N版本中可以配置以下文件追加用户及用户组
/android_n/alps/system/core/include/private/android_filesystem_config.h
配置以下文件,对文件的具体权限进行配置system/core/libcutils/fs_config.c

重点来了,这段文字完全就是我所需要的信息:fs_config.c

3.于是分别去查看了 ①android_filesystem_config.h ②fs_config.c

结果:
/android_n/alps/system/core/include/private/android_filesystem_config.h
并没有可以修改权限的地方放以及可操作空间.
system/core/libcutils/fs_config.c 中很明显就看的到权限的一些信息。
粘贴一些源代码供参考:

1.这个函数里的意思就很明显了:修改整个文件夹的权限

// Rules for directories.
// These rules are applied based on "first match", so they
// should start with the most specific path and work their
// way up to the root.
static const struct fs_path_config android_dirs[] = {
   
    // clang-format off
    {
    00770, AID_SYSTEM,       AID_CACHE,        0, "cache" },
    {
    00500, AID_ROOT,         AID_ROOT,         0, "config" },
    {
    00771, AID_SYSTEM,       AID_SYSTEM,       0, "data/app" },
    {
    00771, AID_SYSTEM,       AID_SYSTEM,       0, "data/app-private" },
    {
    00771, AID_SYSTEM,       AID_SYSTEM,       0, "data/app-ephemeral" },
    {
    00771, AID_ROOT,         AID_ROOT,         0, "data/dalvik-cache" },
    {
    00771, AID_SYSTEM,       AID_SYSTEM,       0, "data/data" },
    {
    00771, AID_SHELL,        AID_SHELL,        0, "data/local/tmp" },
    {
    00771, AID_SHELL
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android中,写文件权限是指应用程序获得在设备上创建、修改或删除文件的能力。可以通过在AndroidManifest.xml文件中声明权限来获取写文件权限,例如: <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> 使用此权限,应用程序可以在外部存储设备(如SD卡)上创建、修改或删除文件。但自Android 4.4(API级别19)开始,写入外部存储的应用程序必须请求额外的权限,即WRITE_EXTERNAL_STORAGE不再授予应用的默认权限。 在应用程序中,可以通过以下方式检查和请求写文件权限: 1. 检查权限: 可以使用ContextCompat.checkSelfPermission()方法来检查应用是否具有写文件权限,代码示例如下: if (ContextCompat.checkSelfPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE) == PackageManager.PERMISSION_GRANTED) { // 已经具有写文件权限,可以执行文件操作 } else { // 没有写文件权限,需要申请权限 } 2. 请求权限: 可以使用ActivityCompat.requestPermissions()方法来请求写文件权限,代码示例如下: ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, requestCode); 在请求权限时,可以传递一个请求码用于标识此次请求,同时需要在Activity的onRequestPermissionsResult()方法中处理权限请求结果。 需要注意的是,为了提高应用程序的安全性,应该遵循权限最小化原则,即只请求应用程序所需的最少权限。同时,在进行文件操作时,还需要注意文件路径的获取和权限检查,以确保在访问文件时不会发生权限异常或造成数据丢失等问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值