安卓玩机----解锁system分区 可读写系统分区 magisk面具模块

2023-10-08 08:36

本文主要是介绍安卓玩机----解锁system分区 可读写系统分区 magisk面具模块,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

玩机教程----安卓机型解锁system分区 任意修改删除系统文件

system分区可读写

参考上个博文可以了解到解锁system分区的有关常识。但目前很多机型都在安卓12  13  基础上。其实最简单的方法就在于刷写一个解锁system分区的第三方补丁包。在面具更新不能解锁系统分区的前提下。我们也可以通过刷写一个解锁模块来达到解锁分区的目的。

官方资源下载地址在博文最后。

测试机型与信息

机型;小米11

芯片:骁龙888

安卓版本:安卓13

面具模块:Magisk Overlayfs

系统版本:miui14

操作步骤为:

解锁bl后有面具root权限。这个可以参考自己机型的解锁bl与root方法操作

然后在面具里刷入此模块。

重启后,查看模块运行开启正常。此时就可以任意系统分区读写。使用re管理器可以直观查看效果

操作效果

目前就可以任意删减系统分区文件。

部分源代码如下:

SKIPUNZIP=1if [ "$BOOTMODE" ] && [ "$KSU" ]; thenui_print "- Installing from KernelSU app"ui_print "- KernelSU version: $KSU_KERNEL_VER_CODE (kernel) + $KSU_VER_CODE (ksud)"ui_print "- Please note that KernelSU modules mount will make"ui_print "  your system partitions unable to mount as rw"ui_print "- If you are using KernelSU, "ui_print "  please unmount all ksu overlayfs"ui_print "  when you want to modify system partitions"
elif [ "$BOOTMODE" ] && [ "$MAGISK_VER_CODE" ]; thenui_print "- Installing from Magisk app"
elseui_print "*********************************************************"ui_print "! Install from recovery is not supported"ui_print "! Please install from KernelSU or Magisk app"abort    "*********************************************************"
filoop_setup() {unset LOOPDEVlocal LOOPlocal MINORX=1[ -e /dev/block/loop1 ] && MINORX=$(stat -Lc '%T' /dev/block/loop1)local NUM=0while [ $NUM -lt 1024 ]; doLOOP=/dev/block/loop$NUM[ -e $LOOP ] || mknod $LOOP b 7 $((NUM * MINORX))if losetup $LOOP "$1" 2>/dev/null; thenLOOPDEV=$LOOPbreakfiNUM=$((NUM + 1))done
}randdir="$TMPDIR/.$(head -c21 /dev/urandom | base64)"
mkdir -p "$randdir"ABI="$(getprop ro.product.cpu.abi)"# Fix ABI detection
if [ "$ABI" == "armeabi-v7a" ]; thenABI32=armeabi-v7a
elif [ "$ABI" == "arm64" ]; thenABI32=armeabi-v7a
elif [ "$ABI" == "x86" ]; thenABI32=x86
elif [ "$ABI" == "x64" ] || [ "$ABI" == "x86_64" ]; thenABI=x86_64ABI32=x86
fiunzip -oj "$ZIPFILE" "libs/$ABI/overlayfs_system" -d "$TMPDIR" 1>&2
chmod 777 "$TMPDIR/overlayfs_system"if ! $TMPDIR/overlayfs_system --test; thenui_print "! Kernel doesn't support overlayfs, are you sure?"abort
fiui_print "- Extract files"unzip -oj "$ZIPFILE" post-fs-data.sh \service.sh \util_functions.sh \mode.sh \mount.sh \uninstall.sh \module.prop \"libs/$ABI/overlayfs_system" \-d "$MODPATH"
unzip -oj "$ZIPFILE" util_functions.sh  -d "/data/adb/modules/${MODPATH##*/}"ui_print "- Setup module"chmod 777 "$MODPATH/overlayfs_system"resize_img() {e2fsck -pf "$1" || return 1if [ "$2" ]; thenresize2fs "$1" "$2" || return 1elseresize2fs -M "$1" || return 1fireturn 0
}test_mount_image() {loop_setup /data/adb/overlay[ -z "$LOOPDEV" ] && return 1result_mnt=1mount -t ext4 -o rw "$LOOPDEV" "$randdir" && \"$MODPATH/overlayfs_system" --test --check-ext4 "$randdir" && result_mnt=0# ensure that uppderdir does not override my binaryrm -rf "$randdir/upper/system/bin/overlayfs_system" \"$randdir/upper/system/bin/magic_remount_rw" \"$randdir/upper/system/bin/magic_remount_ro"umount -l "$randdir"return $result_mnt
}create_ext4_image() {dd if=/dev/zero of="$1" bs=1024 count=100/system/bin/mkfs.ext4 "$1" && return 0return 1
}if [ ! -f "/data/adb/overlay" ] || ! test_mount_image; thenrm -rf "/data/adb/overlay"ui_print "- Setup 2GB ext4 image at /data/adb/overlay"ui_print "  Please wait..."if ! create_ext4_image "/data/adb/overlay" || ! resize_img "/data/adb/overlay" 2000M || ! test_mount_image; thenrm -rf /data/adb/overlayabort "! Setup ext4 image failed, abort"fi
fimkdir -p "$MODPATH/system/bin"
chcon -R u:object_r:system_file:s0 "$MODPATH/system"
chmod -R 755 "$MODPATH/system"ln "$MODPATH/overlayfs_system" "$MODPATH/system/bin"
ln -s "./overlayfs_system" "$MODPATH/system/bin/magic_remount_rw"
ln -s "./overlayfs_system" "$MODPATH/system/bin/magic_remount_ro"
. "$MODPATH/util_functions.sh"
support_overlayfs && rm -rf "$MODPATH/system"ui_print

MODDIR="${0%/*}"

set -o standalone

export MAGISKTMP="$(magisk --path)"

chmod 777 "$MODDIR/overlayfs_system"

OVERLAYDIR="/data/adb/overlay"
OVERLAYMNT="/dev/mount_overlayfs"
MODULEMNT="/dev/mount_loop"


mv -fT /cache/overlayfs.log /cache/overlayfs.log.bak
rm -rf /cache/overlayfs.log
echo "--- Start debugging log ---" >/cache/overlayfs.log
echo "init mount namespace: $(readlink /proc/1/ns/mnt)" >>/cache/overlayfs.log
echo "current mount namespace: $(readlink /proc/self/ns/mnt)" >>/cache/overlayfs.log

mkdir -p "$OVERLAYMNT"
mkdir -p "$OVERLAYDIR"
mkdir -p "$MODULEMNT"

mount -t tmpfs tmpfs "$MODULEMNT"

loop_setup() {
  unset LOOPDEV
  local LOOP
  local MINORX=1
  [ -e /dev/block/loop1 ] && MINORX=$(stat -Lc '%T' /dev/block/loop1)
  local NUM=0
  while [ $NUM -lt 2048 ]; do
    LOOP=/dev/block/loop$NUM
    [ -e $LOOP ] || mknod $LOOP b 7 $((NUM * MINORX))
    if losetup $LOOP "$1" 2>/dev/null; then
      LOOPDEV=$LOOP
      break
    fi
    NUM=$((NUM + 1))
  done
}

if [ -f "$OVERLAYDIR" ]; then
    loop_setup /data/adb/overlay
    if [ ! -z "$LOOPDEV" ]; then
        mount -o rw -t ext4 "$LOOPDEV" "$OVERLAYMNT"
        ln "$LOOPDEV" /dev/block/overlayfs_loop
    fi
fi

if ! "$MODDIR/overlayfs_system" --test --check-ext4 "$OVERLAYMNT"; then
    echo "unable to mount writeable dir" >>/cache/overlayfs.log
    exit
fi

num=0

for i in /data/adb/modules/*; do
    [ ! -e "$i" ] && break;
    module_name="$(basename "$i")"
    if [ ! -e "$i/disable" ] && [ ! -e "$i/remove" ]; then
        if [ -f "$i/overlay.img" ]; then
            loop_setup "$i/overlay.img"
            if [ ! -z "$LOOPDEV" ]; then
                echo "mount overlayfs for module: $module_name" >>/cache/overlayfs.log
                mkdir -p "$MODULEMNT/$num"
                mount -o rw -t ext4 "$LOOPDEV" "$MODULEMNT/$num"
            fi
            num="$((num+1))"
        fi
        if [ "$KSU" == "true" ]; then
            mkdir -p "$MODULEMNT/$num"
            mount --bind "$i" "$MODULEMNT/$num"
            num="$((num+1))"
        fi
    fi
done

OVERLAYLIST=""

for i in "$MODULEMNT"/*; do
    [ ! -e "$i" ] && break;
    if [ -d "$i" ] && [ ! -L "$i" ] && "$MODDIR/overlayfs_system" --test --check-ext4 "$i"; then
        OVERLAYLIST="$i:$OVERLAYLIST"
    fi
done

mkdir -p "$OVERLAYMNT/upper"
rm -rf "$OVERLAYMNT/worker"
mkdir -p "$OVERLAYMNT/worker"

if [ ! -z "$OVERLAYLIST" ]; then
    export OVERLAYLIST="${OVERLAYLIST::-1}"
    echo "mount overlayfs list: [$OVERLAYLIST]" >>/cache/overlayfs.log
fi

# overlay_system <writeable-dir>
. "$MODDIR/mode.sh"
"$MODDIR/overlayfs_system" "$OVERLAYMNT" | tee -a /cache/overlayfs.log

if [ ! -z "$MAGISKTMP" ]; then
    mkdir -p "$MAGISKTMP/overlayfs_mnt"
    mount --bind "$OVERLAYMNT" "$MAGISKTMP/overlayfs_mnt"
fi


umount -l "$OVERLAYMNT"
rmdir "$OVERLAYMNT"
umount -l "$MODULEMNT"
rmdir "$MODULEMNT"

rm -rf /dev/.overlayfs_service_unblock
echo "--- Mountinfo (post-fs-data) ---" >>/cache/overlayfs.log
cat /proc/mounts >>/cache/overlayfs.log
(
    # block until /dev/.overlayfs_service_unblock
    while [ ! -e "/dev/.overlayfs_service_unblock" ]; do
        sleep 1
    done
    rm -rf /dev/.overlayfs_service_unblock

    echo "--- Mountinfo (late_start) ---" >>/cache/overlayfs.log
    cat /proc/mounts >>/cache/overlayfs.log
) &

resize_img() {e2fsck -pf "$1" || return 1if [ "$2" ]; thenresize2fs "$1" "$2" || return 1elseresize2fs -M "$1" || return 1fireturn 0
}loop_setup() {unset LOOPDEVlocal LOOPlocal MINORX=1[ -e /dev/block/loop1 ] && MINORX=$(stat -Lc '%T' /dev/block/loop1)local NUM=0while [ $NUM -lt 2048 ]; doLOOP=/dev/block/loop$NUM[ -e $LOOP ] || mknod $LOOP b 7 $((NUM * MINORX))if losetup $LOOP "$1" 2>/dev/null; thenLOOPDEV=$LOOPbreakfiNUM=$((NUM + 1))done
}sizeof(){EXTRA="$2"[ -z "$EXTRA" ] && EXTRA=0[ "$EXTRA" -gt 0 ] || EXTRA=0size="$(du -s "$1" | awk '{ print $1 }')"# append more 20Mbsize="$((size + EXTRA))"echo -n "$((size + 20000))"
}handle() {if [ ! -L "/$1" ] && [ -d "/$1" ] && [ -d "$MODPATH/system/$1" ]; thenrm -rf "$MODPATH/overlay/$1"mv -f "$MODPATH/overlay/system/$1" "$MODPATH/overlay"ln -s "../$1" "$MODPATH/overlay/system/$1"fi
}create_ext4_image() {dd if=/dev/zero of="$1" bs=1024 count=100/system/bin/mkfs.ext4 "$1" && return 0return 1
}support_overlayfs() {#OVERLAY_IMAGE_EXTRA - number of kb need to be added to overlay.img
#OVERLAY_IMAGE_SHRINK - shrink overlay.img or not?if [ -d "$MODPATH/system" ]; thenOVERLAY_IMAGE_SIZE="$(sizeof "$MODPATH/system" "$OVERLAY_IMAGE_EXTRA")"rm -rf "$MODPATH/overlay.img"create_ext4_image "$MODPATH/overlay.img"resize_img "$MODPATH/overlay.img" "${OVERLAY_IMAGE_SIZE}M" || { ui_print "! Setup failed"; return 1; }ui_print "- Created overlay image with size: $(du -shH "$MODPATH/overlay.img" | awk '{ print $1 }')"loop_setup "$MODPATH/overlay.img"if [ ! -z "$LOOPDEV" ]; thenrm -rf "$MODPATH/overlay"mkdir "$MODPATH/overlay"mount -t ext4 -o rw "$LOOPDEV" "$MODPATH/overlay"chcon u:object_r:system_file:s0 "$MODPATH/overlay"cp -afT "$MODPATH/system" "$MODPATH/overlay/system"# fix context( cd "$MODPATH" || exit find "system" | while read line; dochcon "$(ls -Zd "$line" | awk '{ print $1 }')" "$MODPATH/overlay/$line"if [ -e "$line/.replace" ]; thensetfattr -n trusted.overlay.opaque -v y "$MODPATH/overlay/$line"fidone)# handle partitionhandle vendorhandle producthandle system_extumount -l "$MODPATH/overlay"if [ "$OVERLAY_IMAGE_SHRINK" == "true" ] || [ -z "$OVERLAY_IMAGE_SHRINK" ]; thenui_print "- Shrink overlay image"resize_img "$MODPATH/overlay.img"ui_print "- Overlay image new size: $(du -shH "$MODPATH/overlay.img" | awk '{ print $1 }')"firm -rf "$MODPATH/overlay"return 0fi
fireturn 1
}

 这个是一个开源的解锁系统分区资源。官方下载链接:官方开源地址

整体操作步骤还是比较简单。适合任意阶段的玩友使用。

关注我。了解一些玩机常识和基本的故障解决。

这篇关于安卓玩机----解锁system分区 可读写系统分区 magisk面具模块的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/164048

相关文章

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

10. 文件的读写

10.1 文本文件 操作文件三大类: ofstream:写操作ifstream:读操作fstream:读写操作 打开方式解释ios::in为了读文件而打开文件ios::out为了写文件而打开文件,如果当前文件存在则清空当前文件在写入ios::app追加方式写文件ios::trunc如果文件存在先删除,在创建ios::ate打开文件之后令读写位置移至文件尾端ios::binary二进制方式

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、