Deprecated: Creation of dynamic property Typecho\Widget\Request::$feed is deprecated in /www/wwwroot/blog.iletter.top/var/Widget/Archive.php on line 253
白荼日记 - 技术笔记 技术笔记,我的思考,bug还有一些奇奇怪怪的问题 2026-06-03T01:00:00+08:00 Typecho https://blog.iletter.top/feed/atom/category/ji-shu-bi-ji/ <![CDATA[红米k20刷入ubuntu]]> https://blog.iletter.top/archives/526/ 2026-06-03T01:00:00+08:00 2026-06-03T01:00:00+08:00 DelLevin https://blog.iletter.top 建议刷机前将设备使用官方线刷包线刷为 安卓 10 底层。

一、前置准备
1.设备已完成 Bootloader 解锁。
2.电脑端配置好 adb/fastboot 环境变量。
3.解压 rootfs-ubuntu-gnome-7.0-resolute.zip,获取 rootfs.img 和内核驱动镜像。

二、刷机指令

1. 进入 Fastboot 模式

adb reboot bootloader

2. 清空分区(清除旧数据冲突)

fastboot erase dtbo
fastboot erase boot
fastboot erase cache
fastboot erase userdata

3. 刷入底层引导

fastboot flash boot u-boot.img

4. 刷入系统主镜像 (压缩包内解压获取)

fastboot flash userdata rootfs.img

如果报错

libc++abi: terminating due to uncaught exception of type std::bad_alloc: std::bad_alloc:

使用转换

.\img2simg rootfs.img rootfs_sparse.img

在进行

fastboot flash userdata rootfs_sparse.img

下载地址:
https://github.com/thka2016/lpunpack_and_lpmake_cmake/releases

5. 刷入内核和驱动 (压缩包内解压获取)

fastboot flash cache xiaomi-k20pro-boot.img

6. 重启设备

fastboot reboot

user用户默认密码:1234
设置root用户密码:

sudo passwd

f4576f01bb569aea2c335ec3879d4d9f.jpg

dcc43c670b77167edc3dea5a393dba31.png

]]>
<![CDATA[在“终端”中设置 Mac 定时开关机]]> https://blog.iletter.top/archives/524/ 2026-04-01T20:46:58+08:00 2026-04-01T20:46:58+08:00 DelLevin https://blog.iletter.top 设置每日定时开关机

在您的Mac上打开"终端"(Terminal)应用,然后输入以下命令:

  1. 查看当前设置

    pmset -g sched
  2. 设置每天定时开关机
    要设置每天早上8点开机,晚上12点(24:00)关机,请运行以下命令:

    sudo pmset repeat poweron MTWRFSU 08:00:00 shutdown MTWRFSU 00:00:00

这里参数的含义:
poweron 表示开机
shutdown 表示关机
MTWRFSU 代表每天(Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday)
08:00:00 表示早上8点整
00:00:00 表示午夜12点整

  1. 输入密码
    执行上述命令后,系统会要求您输入管理员密码,输入完成后按回车确认。
  2. 验证设置
    再次运行以下命令来确认设置是否成功:
pmset -g sched

如何取消定时任务
如果您以后想取消这些定时任务,可以运行:

sudo pmset repeat cancel

注意事项
M1芯片兼容性:M1芯片的Mac电脑支持pmset的定时功能,但某些旧的参数可能不适用。上面提供的命令适用于M1芯片Mac。
电源要求:为了确保定时开机功能正常工作,建议将Mac连接到电源适配器。

系统版本:在较新的macOS版本中,您也可以通过"系统设置" > "电池" > "调度"来设置定时开关机,但使用终端命令提供了更多灵活性。

]]>
<![CDATA[安卓模拟器无法连接网络问题]]> https://blog.iletter.top/archives/521/ 2026-03-08T12:11:00+08:00 2026-03-08T12:11:00+08:00 DelLevin https://blog.iletter.top 简短解释
  1. 打开你安卓SDK的存放目录,然后找到emulator文件夹并进入
  2. 打开终端调用emulator程序修改模拟器DNS配置 , 命令如下
    emulator -avd 模拟器名称 -dns-server 8.8.8.8 114.114.114.114
  3. 如果你不知道模拟器名称可以使用下面命令
    emulator -list-avds

步骤及命令

1.打开终端

键盘win+R,输入cmd

2.切换到Android SDK目录下的emulator文件夹下

cd 盘符:存放路径/sdk/emulator

3.获取模拟器名称

emulator -list-avds

4.设置模拟器DNS

emulator -avd 模拟器名称 -dns-server 8.8.8.8 114.114.114.114
]]>
<![CDATA[Win11打开文件夹显示找不到应用程序]]> https://blog.iletter.top/archives/519/ 2026-01-04T14:05:00+08:00 2026-01-04T14:05:00+08:00 DelLevin https://blog.iletter.top
  • 按【 Win + R 】组合键,打开运行,输入【regedit】命令,按【确定或回车】打开注册表编辑器;
  • 注册表编辑器窗口,依次展开到以下路径:
    HKEY_CLASSES_ROOT\Folder\shell
  • 在【Shell】下通常默认有下图几项,如果有其它第三方软件命名项,我们可以【右键删除】;
  • 左侧列表中,点击【shell】,在右侧双击名称为【默认】的项;
  • 将数值数据【清空】,最后点击【确定】;
  • 以上设置完成后,重启电脑再看是否正常。
  • ]]>
    <![CDATA[linux服务器实现webdav挂载]]> https://blog.iletter.top/archives/518/ 2025-12-30T14:35:53+08:00 2025-12-30T14:35:53+08:00 DelLevin https://blog.iletter.top 使用 davfs2 (推荐用于标准WebDAV)

    安装 davfs2

    在 Debian/Ubuntu:

    sudo apt update && sudo apt install davfs2

    在 CentOS/RHEL (可能需要EPEL源):

    sudo yum install davfs2

    创建挂载点

    sudo mkdir /home/dellevin/zhang/jellyfin/media/webdav/g3

    配置 davfs2 凭证

    编辑 /etc/davfs2/secrets 文件,添加一行:

    /home/dellevin/zhang/jellyfin/media/webdav/g3 webdav账户 webdav密码

    设置文件权限:

    sudo chmod 600 /etc/davfs2/secrets

    挂载 WebDAV

    sudo mount -t davfs http://webdav地址/path  /home/dellevin/zhang/jellyfin/media/webdav/g3

    卸载

    sudo umount /home/dellevin/zhang/jellyfin/media/webdav/g3
    ]]>
    <![CDATA[ 宝塔面板V11.4精简去除vip以及其他推广功能]]> https://blog.iletter.top/archives/516/ 2025-12-21T22:57:03+08:00 2025-12-21T22:57:03+08:00 DelLevin https://blog.iletter.top 该操作仅适用于宝塔面板 V11.4,其他版本需要自行测试。

    功能隐藏:

    关闭不必要的功能

    设置->常用设置->面板栏隐藏,隐藏如下功能

    WAF、WP Tools、多用户、邮局、节点管理

    不想用,隐藏就行了。

    去除首页的软件推荐功能。

    image.png

    一开始我本以为这个是在utils-lib.js里面带着的,后来通过减慢请求查看到是在请求里面带着的。通过搜索关键词get_pay_type发现,是通过getRecommendContent这个请求函数带过来的。所以我们需要在这里设置返还值为空即将

    getRecommendContent=()=>useAxios.post("ajax/get_pay_type")

    替换成

    getRecommendContent=()=>{return []}

    去除日志部分的 SSH 登录日志

    删掉如下部分

    {path:"ssh",name:"ssh",meta:{title:"SSH登录日志"},component:()=>__vitePreload(()=>import("./index57.js?v=1766131796"),__vite__mapDeps([]),import.meta.url)},

    去除 SSL 部分的 自动部署

    image.png

    删掉如下部分

    {path:"auto-deploy",name:"auto-deploy",meta:{title:"自动部署"},component:()=>__vitePreload(()=>import("./index89.js?v=1766131796").then(e=>e.i),__vite__mapDeps([]),import.meta.url)},

    去除 安全部分的 安全检测和违规词检测

    image.png

    删掉如下部分

    {path:"safe-detect",name:"safe-detect",meta:{title:"安全检测"},component:()=>__vitePreload(()=>import("./index46.js?v=1766131796"),__vite__mapDeps([]),import.meta.url)},{path:"keyword",name:"keyword",meta:{title:"违规词检测"},component:()=>__vitePreload(()=>import("./index47.js?v=1766131796"),__vite__mapDeps([]),import.meta.url)},

    去除 PHP网站安全 入侵防御 系统加固 扫描感知 部分

    image (1).png

    删掉如下部分

    ,{path:"php-safe",name:"php-safe",meta:{title:"PHP网站安全"},component:()=>__vitePreload(()=>import("./index48.js?v=1766131796"),__vite__mapDeps([]),import.meta.url)},{path:"intrusion",name:"intrusion",meta:{title:"入侵防御"},component:()=>__vitePreload(()=>import("./index49.js?v=1766131796"),__vite__mapDeps([]),import.meta.url)},{path:"fixed",name:"fixed",meta:{title:"系统加固"},component:()=>__vitePreload(()=>import("./index50.js?v=1766131796"),__vite__mapDeps([]),import.meta.url)},{path:"network-scan",name:"network-scan",meta:{title:"扫描感知"},component:()=>__vitePreload(()=>import("./index51.js?v=1766131796"),__vite__mapDeps([]),import.meta.url)}

    去除网站界面 的漏洞扫描 和 网站安全

    找到 index74.js

    image.png

    漏洞扫描删除如下部分

    {type:"custom",render:()=>w(P,{onClick:ee},{default:()=>{var e,t;return[S("漏洞扫描"),w("span",{class:"ml-4px py-1px px-4px text-center font-bold ".concat((null==(e=Se.value)?void 0:e.loophole_num)>0?"text-danger":"text-warning")},[null==(t=Se.value)?void 0:t.loophole_num])]}})},

    网站安全删除如下部分

    ,{type:"custom",render:()=>w(P,{onClick:te},{default:()=>{var e,t;return[S("网站安全"),w("span",{class:"ml-4px py-1px px-4px text-center font-bold ".concat((null==(e=Se.value)?void 0:e.web_scaning_times)>0?"text-danger":"text-warning")},[null==(t=Se.value)?void 0:t.web_scaning_times])]}})}

    去除 table 表格的右侧的统计和 waf

    image.png

    {onClick:e=>{le(e,"monitor-setting")},title:"统计"},{onClick:e=>{le(e,"bt_waf")},title:"WAF"},

    去除网站安全和防篡改

    找到 index235.js

    image (1).png

    删除该部分

    {label:"防篡改",name:"antiTamper",lazy:!0,render:()=>r(()=>import("./index463.js?v=1766131796"),__vite__mapDeps([]),import.meta.url)},{label:"网站安全",lazy:!0,name:"siteSecurity",render:()=>r(()=>import("./index464.js?v=1766131796"),__vite__mapDeps([]),import.meta.url)},

    Css隐藏:

    主要路径为/www/server/panel/BTPanel/static/css/style.css 一下更改需要在此文件内进行调整,如需更改其他部分会另作说明

    去除顶部的企业版tag

    image.png

    .icon-end-time-free[data-v-402b09ab]{ 后面添加 display:none;

    软件商店的推广 banner

    image.png

    .recom-view[data-v-81e888c5]{ 后面添加 display:none

    去除底部的vip推广

    image.png

    找到如下路径的/www/server/panel/BTPanel/static/css里面的style.css搜索advantage-view吧这里面的display:flex改成display:none

    去除网站里面的 waf 图标

    image (1).png

    .svgtofont-left-waf:before{content:""} 替换成 .svgtofont-left-waf:before{dispaly:none;content:""}

    ]]>
    <![CDATA[笔记本断电后自动关机python命令]]> https://blog.iletter.top/archives/503/ 2025-12-16T10:46:00+08:00 2025-12-16T10:46:00+08:00 DelLevin https://blog.iletter.top 自己的笔记本被自己改成了win server服务器,外加来电自启+小爱同学控制开关机,可以说很好了,但是笔记本却没有断电自动关机这个东西,原本想把电池扣了,换上usp的,但是有一点成本在的,果断放弃。

    后来更改电源计划,99%的时候进行关机,但是盖上盖子,断开远程的时候,睡眠状态了就,不会进行关机操作。索性写了这个python代码

    import sys
    import win32api
    import win32gui
    import win32con
    import pythoncom
    import psutil
    import threading
    import time
    import subprocess
    
    SHUTDOWN_DELAY_SECONDS = 60
    
    class PowerListenerWindow:
        def __init__(self):
            self.is_plugged_in = True # 初始假设为连接电源
            self.shutdown_timer = None
            self.last_unplugged_time = None
    
            wc = win32gui.WNDCLASS()
            wc.lpfnWndProc = self.wnd_proc
            wc.lpszClassName = 'MyPowerListenerClass'
            wc.hInstance = win32api.GetModuleHandle(None)
            class_atom = win32gui.RegisterClass(wc)
    
            # Create a hidden window
            self.hwnd = win32gui.CreateWindow(
                class_atom,
                'PowerListener',
                0, 0, 0, 0, 0,
                0, 0, wc.hInstance, None
            )
    
        def wnd_proc(self, hwnd, msg, wparam, lparam):
            if msg == win32con.WM_POWERBROADCAST:
                if wparam == win32con.PBT_APMPOWERSTATUSCHANGE:
                    # print("[WM_POWERBROADCAST] 电源状态可能已更改 (PBT_APMPOWERSTATUSCHANGE)") # 简化日志
                    self.check_and_print_status() # 调用更新后的检查函数
    
                elif wparam == win32con.PBT_ACPIRESUMEAUTOMATIC or wparam == win32con.PBT_ACPIRESUMESUSPEND:
                    # print(f"[WM_POWERBROADCAST] 系统从睡眠/休眠恢复 (wParam={wparam})") # 简化日志
                    pass # 可根据需要添加恢复逻辑
    
                elif wparam == win32con.PBT_APMSUSPEND:
                    # print("[WM_POWERBROADCAST] 系统即将进入睡眠/休眠 (PBT_APMSUSPEND)") # 简化日志
                    pass # 可根据需要添加休眠前逻辑
    
            return win32gui.DefWindowProc(hwnd, msg, wparam, lparam)
    
        def cancel_pending_shutdown(self):
            """取消任何待定的关机操作"""
            if self.shutdown_timer and self.shutdown_timer.is_alive():
                 self.shutdown_timer.cancel()
                 self.shutdown_timer = None
    
        def schedule_shutdown(self):
            """在指定延迟后执行关机"""
            print(f"警告:设备未充电,将在 {SHUTDOWN_DELAY_SECONDS} 秒后关机!")
            self.execute_shutdown()
    
        def execute_shutdown(self):
            """实际执行关机操作"""
            # 再次确认是否仍然未充电,避免在检查间隙插上了电源
            try:
                battery_check = psutil.sensors_battery()
                if battery_check and not battery_check.power_plugged:
                     print("--- 执行关机 ---")
                     # 使用 subprocess 调用 Windows 关机命令
                     # /s 关机, /t 5 延迟5秒, /c 添加消息
                     subprocess.run(["shutdown", "/s", "/t", "5", "/c", "Battery low and not charging. Shutting down in 5 seconds..."], check=True)
                     # 等待一下,让关机命令生效
                     time.sleep(10)
                     sys.exit(0) # 正常退出监听器
                else:
                     print("--- 电源状态已恢复,取消关机 ---")
            except psutil.Error as e:
                 print(f"查询电源状态失败: {e}")
                 # 查询失败,出于安全考虑,可以选择不关机或记录日志
            except subprocess.CalledProcessError as e:
                 print(f"执行关机命令失败: {e}")
            except Exception as e:
                 print(f"执行关机时发生未知错误: {e}")
    
    
        def check_and_print_status(self):
            """Helper function to query and print current status and manage shutdown timer"""
            try:
                battery = psutil.sensors_battery()
                was_plugged_in = self.is_plugged_in # 记录之前的状态
                if battery:
                    self.is_plugged_in = battery.power_plugged
                    # 简化状态打印,仅在状态变化时提示
                    # plugged_status_str = "已充电/接入电源" if self.is_plugged_in else "未在充电"
                    # print(f"当前电源状态: {plugged_status_str}, 电量: {battery.percent}%")
    
                    if not self.is_plugged_in:
                        # 检测到未充电
                        if was_plugged_in or self.shutdown_timer is None:
                            # 如果之前是充电的,或者是第一次检测到未充电且无定时器
                            print(f"提示:笔记本电脑当前未在充电! 电量: {battery.percent}%. 将在 {SHUTDOWN_DELAY_SECONDS} 秒后关机.")
                            self.cancel_pending_shutdown() # 先取消旧的(理论上不应该有)
                            # 启动新的 60 秒关机定时器
                            self.shutdown_timer = threading.Timer(SHUTDOWN_DELAY_SECONDS, self.schedule_shutdown)
                            self.shutdown_timer.start()
                        # else: 已经在倒计时中,无需重复启动
    
                    else:
                        # 检测到已充电
                        if not was_plugged_in: # 如果之前是未充电的
                             print("提示:电源已连接,取消关机计划。")
                        # 取消任何待定的关机
                        self.cancel_pending_shutdown()
    
                else:
                    # print("无法获取电池信息,可能不是笔记本电脑或传感器不可用。") # 简化日志
                    self.is_plugged_in = True # 默认为连接(安全起见)
                    self.cancel_pending_shutdown() # 取消关机
    
            except Exception as e:
                print(f"查询电源状态时出错: {e}")
                # 出错时也应取消关机以防万一
                self.cancel_pending_shutdown()
    
    
        def start_message_loop(self):
            print("Windows 电源监听器已启动...")
            print("请插拔电源测试功能。按 Ctrl+C 退出。")
            # 初始检查一次状态
            self.check_and_print_status()
            try:
                while True:
                    pythoncom.PumpWaitingMessages()
                    win32api.Sleep(5000) # 每5秒处理一次消息队列
    
            except KeyboardInterrupt:
                print("\n收到退出指令,正在关闭...")
            finally:
                self.cancel_pending_shutdown() # 确保退出时取消定时器
                win32gui.DestroyWindow(self.hwnd)
                print("监听器已关闭。")
    
    # 编译
    # pyinstaller --noconfirm --onefile --hidden-import=win32timezone powerOffShutDown.py
    if __name__ == "__main__":
        listener = PowerListenerWindow()
        listener.start_message_loop()
    
    ]]>
    <![CDATA[将bat脚本设置成windows服务]]> https://blog.iletter.top/archives/502/ 2025-12-02T13:46:29+08:00 2025-12-02T13:46:29+08:00 DelLevin https://blog.iletter.top 步骤 1: 下载 NSSM

    访问 NSSM 官方网站:http://nssm.cc/download
    下载适用于你系统架构(通常是 64-bit x64)的最新版本。
    解压下载的 ZIP 文件。你会得到一个包含 nssm.exe 的文件夹(例如 win64 文件夹里有 nssm.exe)。

    步骤 2: 将 NSSM 添加到系统 PATH

    为了在任何地方都能使用 nssm 命令,建议将其路径添加到系统的环境变量 PATH 中。

    打开“控制面板” -> “系统和安全” -> “系统” -> “高级系统设置”。点击“环境变量”。在“系统变量”或“用户变量”中找到 Path,选中它并点击“编辑”。点击“新建”,然后粘贴你解压出来的 nssm.exe 所在的完整目录路径(例如 D:\tools\nssm-2.24\win64)。

    请务必将路径修改为你实际解压的路径。点击“确定”保存所有更改。关闭并重新打开命令提示符窗口,以使 PATH 变更生效。

    步骤 3: 使用 NSSM 创建服务

    以管理员身份 打开命令提示符 (CMD) 或 PowerShell。
    输入以下命令来启动 NSSM 的图形安装界面:

    nssm install frp_client_service

    (frp_client_service 是你将要创建的服务名称,你可以根据需要修改,但不能包含空格)。

    在弹出的 NSSM 配置窗口中:

    Path: 浏览并选择你的 start.bat 文件路径:D:\appStable\frp-client\start.bat。

    Startup directory: 自动填充为 .bat 文件所在的目录,即 D:\appStable\frp-client。请确认此目录正确。这是程序运行时的工作目录。

    Arguments: 如果你的 start.bat 脚本需要额外的命令行参数,可以在这里填写。通常 .bat 文件不需要在此处添加参数。

    其他选项卡(如 Details, Log on, Dependencies, Process, Shutdown, Exit actions, I/O Priority)可以根据需要进行配置,但对于大多数情况,默认设置即可。

    Details: 可以给服务起个易读的显示名称(Display name),比如 "FRP Client",以及描述(Description)。
    Log on: 默认是使用本地系统账户,通常足够了。

    I/O Priority: 如果担心性能,可以将优先级设为 Normal。
    确认所有信息无误后,点击 Install service 按钮。

    步骤 4: 启动并测试服务

    可以通过 NSSM GUI 来管理服务:

    nssm edit frp_client_service  # 编辑服务
    nssm start frp_client_service # 启动服务
    nssm stop frp_client_service  # 停止服务
    nssm remove frp_client_service # 删除服务

    或者使用 Windows 内置的 服务管理器:

    按 Win + R 键,输入 services.msc 并回车。

    在服务列表中找到你刚刚创建的服务(名称是你在 NSSM 中指定的 Display name 或服务名 frp_client_service)。

    右键单击该服务,选择“启动”。

    检查状态是否变为“正在运行”。

    步骤 5: 设置开机自启

    在 Windows 的 服务管理器 (services.msc) 中,找到你的 frp_client_service 服务。

    右键单击该服务,选择“属性”。

    在“常规”选项卡下,将“启动类型”设置为 自动。

    点击“应用”和“确定”。

    现在,这个 FRP 客户端就会作为 Windows 服务运行,并且在系统开机时自动启动了。

    ]]>
    <![CDATA[pycharm远程开发]]> https://blog.iletter.top/archives/501/ 2025-11-06T22:18:00+08:00 2025-11-06T22:18:00+08:00 DelLevin https://blog.iletter.top 首先创建新的ssh项目

    2025-11-06T14:03:42.png

    填写相关参数

    2025-11-06T14:04:29.png

    这里需要上传linux的安装包,因为下载的话一直失败无法下载成功,我们选择上传和上传路径
    2025-11-06T14:05:26.png

    pycharm地址:https://www.jetbrains.com/zh-cn/pycharm/download/other.html

    破解文件下载地址:ja-netfilter-2025.3.0.zip

    弄完之后,会让你填写远程pycharm的验证,在这之前退出一下我们需要填写编辑一下文件

    vim pycharm64.vmoptions

    里面填写关于破解文件的相关信息

    -Xms256m
    -Xmx2048m
    -XX:ReservedCodeCacheSize=512m
    -XX:+UseG1GC
    -XX:SoftRefLRUPolicyMSPerMB=50
    -XX:CICompilerCount=2
    -XX:+HeapDumpOnOutOfMemoryError
    -XX:-OmitStackTraceInFastThrow
    -XX:+IgnoreUnrecognizedVMOptions
    -XX:CompileCommand=exclude,com/intellij/openapi/vfs/impl/FilePartNodeRoot,trieDescend
    -ea
    -Dsun.io.useCanonCaches=false
    -Dsun.java2d.metal=true
    -Djbr.catch.SIGABRT=true
    -Djdk.http.auth.tunneling.disabledSchemes=""
    -Djdk.attach.allowAttachSelf=true
    -Djdk.module.illegalAccess.silent=true
    -Dkotlinx.coroutines.debug=off
    -Dide.show.tips.on.startup.default.value=false
    -Dsun.tools.attach.tmp.only=true
    -Dawt.lock.fair=true
    -javaagent:/root/ja-netfilter/ja-netfilter.jar
    --add-opens=java.base/jdk.internal.org.objectweb.asm=ALL-UNNAMED
    --add-opens=java.base/jdk.internal.org.objectweb.asm.tree=ALL-UNNAMED
    

    之后再次打开pycharm远程,填写激活码

    6ZLWI4KV9Y-eyJsaWNlbnNlSWQiOiI2WkxXSTRLVjlZIiwibGljZW5zZWVOYW1lIjoi5rC45LmF5r+A5rS7IHd3d8K3YWppaHVvwrdjb20iLCJsaWNlbnNlZVR5cGUiOiJQRVJTT05BTCIsImFzc2lnbmVlTmFtZSI6IiIsImFzc2lnbmVlRW1haWwiOiIiLCJsaWNlbnNlUmVzdHJpY3Rpb24iOiIiLCJjaGVja0NvbmN1cnJlbnRVc2UiOmZhbHNlLCJwcm9kdWN0cyI6W3siY29kZSI6IkdPIiwicGFpZFVwVG8iOiIyMDI1LTExLTIzIiwiZXh0ZW5kZWQiOmZhbHNlfSx7ImNvZGUiOiJSUzAiLCJwYWlkVXBUbyI6IjIwMjUtMTEtMjMiLCJleHRlbmRlZCI6ZmFsc2V9LHsiY29kZSI6IkRNIiwicGFpZFVwVG8iOiIyMDI1LTExLTIzIiwiZXh0ZW5kZWQiOmZhbHNlfSx7ImNvZGUiOiJDTCIsInBhaWRVcFRvIjoiMjAyNS0xMS0yMyIsImV4dGVuZGVkIjpmYWxzZX0seyJjb2RlIjoiUlNVIiwicGFpZFVwVG8iOiIyMDI1LTExLTIzIiwiZXh0ZW5kZWQiOmZhbHNlfSx7ImNvZGUiOiJSU0MiLCJwYWlkVXBUbyI6IjIwMjUtMTEtMjMiLCJleHRlbmRlZCI6dHJ1ZX0seyJjb2RlIjoiUEMiLCJwYWlkVXBUbyI6IjIwMjUtMTEtMjMiLCJleHRlbmRlZCI6ZmFsc2V9LHsiY29kZSI6IkRTIiwicGFpZFVwVG8iOiIyMDI1LTExLTIzIiwiZXh0ZW5kZWQiOmZhbHNlfSx7ImNvZGUiOiJSRCIsInBhaWRVcFRvIjoiMjAyNS0xMS0yMyIsImV4dGVuZGVkIjpmYWxzZX0seyJjb2RlIjoiUkMiLCJwYWlkVXBUbyI6IjIwMjUtMTEtMjMiLCJleHRlbmRlZCI6ZmFsc2V9LHsiY29kZSI6IlJTRiIsInBhaWRVcFRvIjoiMjAyNS0xMS0yMyIsImV4dGVuZGVkIjp0cnVlfSx7ImNvZGUiOiJEQlIiLCJwYWlkVXBUbyI6IjIwMjUtMTEtMjMiLCJleHRlbmRlZCI6ZmFsc2V9LHsiY29kZSI6IlJNIiwicGFpZFVwVG8iOiIyMDI1LTExLTIzIiwiZXh0ZW5kZWQiOmZhbHNlfSx7ImNvZGUiOiJJSSIsInBhaWRVcFRvIjoiMjAyNS0xMS0yMyIsImV4dGVuZGVkIjpmYWxzZX0seyJjb2RlIjoiRFBOIiwicGFpZFVwVG8iOiIyMDI1LTExLTIzIiwiZXh0ZW5kZWQiOmZhbHNlfSx7ImNvZGUiOiJEQiIsInBhaWRVcFRvIjoiMjAyNS0xMS0yMyIsImV4dGVuZGVkIjpmYWxzZX0seyJjb2RlIjoiREMiLCJwYWlkVXBUbyI6IjIwMjUtMTEtMjMiLCJleHRlbmRlZCI6ZmFsc2V9LHsiY29kZSI6IlBTIiwicGFpZFVwVG8iOiIyMDI1LTExLTIzIiwiZXh0ZW5kZWQiOmZhbHNlfSx7ImNvZGUiOiJSUiIsInBhaWRVcFRvIjoiMjAyNS0xMS0yMyIsImV4dGVuZGVkIjpmYWxzZX0seyJjb2RlIjoiUlNWIiwicGFpZFVwVG8iOiIyMDI1LTExLTIzIiwiZXh0ZW5kZWQiOnRydWV9LHsiY29kZSI6IldTIiwicGFpZFVwVG8iOiIyMDI1LTExLTIzIiwiZXh0ZW5kZWQiOmZhbHNlfSx7ImNvZGUiOiJQU0kiLCJwYWlkVXBUbyI6IjIwMjUtMTEtMjMiLCJleHRlbmRlZCI6dHJ1ZX0seyJjb2RlIjoiUENXTVAiLCJwYWlkVXBUbyI6IjIwMjUtMTEtMjMiLCJleHRlbmRlZCI6dHJ1ZX0seyJjb2RlIjoiQUlMIiwicGFpZFVwVG8iOiIyMDI1LTExLTIzIiwiZXh0ZW5kZWQiOmZhbHNlfSx7ImNvZGUiOiJSUyIsInBhaWRVcFRvIjoiMjAyNS0xMS0yMyIsImV4dGVuZGVkIjp0cnVlfSx7ImNvZGUiOiJQUlIiLCJwYWlkVXBUbyI6IjIwMjUtMTEtMjMiLCJleHRlbmRlZCI6dHJ1ZX0seyJjb2RlIjoiRFAiLCJwYWlkVXBUbyI6IjIwMjUtMTEtMjMiLCJleHRlbmRlZCI6dHJ1ZX0seyJjb2RlIjoiUERCIiwicGFpZFVwVG8iOiIyMDI1LTExLTIzIiwiZXh0ZW5kZWQiOnRydWV9XSwibWV0YWRhdGEiOiIwNDIwMjUxMDI0UFBBTTAwMDAwNUEwMDAwMDBYQyIsImhhc2giOiI3NTkxODgyNy8wOjEzODU1MTE2NSIsImdyYWNlUGVyaW9kRGF5cyI6NywiYXV0b1Byb2xvbmdhdGVkIjpmYWxzZSwiaXNBdXRvUHJvbG9uZ2F0ZWQiOmZhbHNlLCJ0cmlhbCI6ZmFsc2UsImFpQWxsb3dlZCI6dHJ1ZX0=-jEJB+XsDL603fDEvkpWiZmuv+g4j7nLQ2jwzghoDP8KuxfCXLPG6LFK4C00mUzUX23i+T9XB9hAp83icdF+YuVESTTbPPxLQVCzk2uIskO8s/g4BZacTQD5IsHVDjRmv5HWtuakqNVUzbatF+yc0ut58PfrPsnKMrp1yFBQEvw3Ch1gghbm85UsTQ4zW2C05QSQDrLSlQB4M/cZ6OTI22NtPSrfJxyfdUhVEnQQqO6uQqrqa7CX8ZuC+ZKsap4tnaXmHG4hfUlZdO7PTlZfV20n9mtJxZSftqZUgeJzreporG7C2bX1mIDlkAECzkMU5gmJzlUQ6499xz2O2Upx7Wg==-MIIETDCCAjSgAwIBAgIBETANBgkqhkiG9w0BAQsFADAYMRYwFAYDVQQDDA1KZXRQcm9maWxlIENBMB4XDTI0MDkyMDEyMTEyN1oXDTI2MDkyMjEyMTEyN1owHzEdMBsGA1UEAwwUcHJvZDJ5LWZyb20tMjAyNDA5MjAwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC7SH/XcUoMwkDi8JJPzXWWHWFdOZdrP2Dqkz2W8iUi650cwz2vdPEd0tMzosLAj7ifkFEHUyiuEcL//q9d9Op7ZsV23lpPXX8tFMLFwugoQ9D8jDLT/XP9pp/YukWkKF5jpNbaCvsVQkDdYkArBkYvhH3aN4v9BkEsXahfgLLOPe4IG2FDJNf9R4to9V1vt+m2UVJB0zV4a/sVMKUZLgqKmKKKOKoLrE3OjBlZlb+Q0z2N5dsW0hDEVRFGmBUAbHN/mp44MMMvEIFKfoLIGpgic92P2O6uFh75PI7mcultL6yuR48ajErx8CjjQEGOSnoq/8hD+yVE+6GW2gJa2CPvAgMBAAGjgZkwgZYwCQYDVR0TBAIwADAdBgNVHQ4EFgQUb5NERj05GyNerQ/Mjm9XH8HXtLIwSAYDVR0jBEEwP4AUo562SGdCEjZBvW3gubSgUouX8bOhHKQaMBgxFjAUBgNVBAMMDUpldFByb2ZpbGUgQ0GCCQDSbLGDsoN54TATBgNVHSUEDDAKBggrBgEFBQcDATALBgNVHQ8EBAMCBaAwDQYJKoZIhvcNAQELBQADggIBALq6VfVUjmPI3N/w0RYoPGFYUieCfRO0zVvD1VYHDWsN3F9buVsdudhxEsUb8t7qZPkDKTOB6DB+apgt2ZdKwok8S0pwifwLfjHAhO3b+LUQaz/VmKQW8gTOS5kTVcpM0BY7UPF8cRBqxMsdUfm5ejYk93lBRPBAqntznDY+DNc9aXOldFiACyutB1/AIh7ikUYPbpEIPZirPdAahroVvfp2tr4BHgCrk9z0dVi0tk8AHE5t7Vk4OOaQRJzy3lST4Vv6Mc0+0z8lNa+Sc3SVL8CrRtnTAs7YpD4fpI5AFDtchNrgFalX+BZ9GLu4FDsshVI4neqV5Jd5zwWPnwRuKLxsCO/PB6wiBKzdapQBG+P9z74dQ0junol+tqxd7vUV/MFsR3VwVMTndyapIS+fMoe+ZR5g+y44R8C7fXyVE/geg+JXQKvRwS0C5UpnS5FcGk+61b0e4U7pwO20RlwhEFHLSaP61p2TaVGo/TQtT/fWmrtV+HegAv9P3X3Se+xIVtJzQsk8QrB/w52IB3FKiAKl/KRn1egbMIs4uoNAkqNZ9Ih2P1NpiQnONFmkiAgeynJ+0FPykKdJQbV3Mx44jkaHIif4aFReTsYX1WUBNu/QerZRjn4FVSHRaZPSR5Oi82Wz0Nj7IY9ocTpLnXFrqkb/Kt3S6B9s2Kol3Lr1ElYA

    这一步可能会提示

    This license xxxx has been suspended

    可以设置一下代理就可以了

    2025-11-06T14:15:15.png

    ]]>
    <![CDATA[1+ACE2系统优化笔记]]> https://blog.iletter.top/archives/495/ 2025-11-01T21:01:00+08:00 2025-11-01T21:01:00+08:00 DelLevin https://blog.iletter.top 记录一下系统的优化记录系统版本C13.1 (cn01)版本。机型1+ace2

    系统版本:

    系统版本.jpg

    冻结的应用:

    禁用服务.jpg

    其中,发现我的system_server里面一直高负载,时不时跳到150%以上。于是采用adb抓包形式。

    抓包命令

    .\adb logcat -v time > D:\UserData\Desktop\logcat.log

    第一次日志抓取

    11-01 18:31:44.931 W/ActivityManager( 3189): Unable to start service Intent { act=com.oplus.onet.service.INTENT_SDK_BIND_SERVICE pkg=com.oplus.onet } U=0: not found
    11-01 18:31:44.931 W/ContextImpl( 4912): Calling a method in the system process without a qualified user: android.app.ContextImpl.bindService:1973 android.content.ContextWrapper.bindService:863 com.oplus.onet.case$do.run:142 android.os.Handler.handleCallback:942 android.os.Handler.dispatchMessage:99 
    11-01 18:31:44.932 W/ActivityManager( 3189): Unable to start service Intent { act=com.oplus.onet.service.INTENT_SDK_BIND_SERVICE pkg=com.oplus.onet } U=0: not found
    11-01 18:31:44.933 W/ContextImpl( 4912): Calling a method in the system process without a qualified user: android.app.ContextImpl.bindService:1973 android.content.ContextWrapper.bindService:863 com.oplus.onet.case$do.run:142 android.os.Handler.handleCallback:942 android.os.Handler.dispatchMessage:99 
    11-01 18:31:44.934 W/ActivityManager( 3189): Unable to start service Intent { act=com.oplus.onet.service.INTENT_SDK_BIND_SERVICE pkg=com.oplus.onet } U=0: not found
    11-01 18:31:44.935 W/ContextImpl( 4912): Calling a method in the system process without a qualified user: android.app.ContextImpl.bindService:1973 android.content.ContextWrapper.bindService:863 com.oplus.onet.case$do.run:142 android.os.Handler.handleCallback:942 android.os.Handler.dispatchMessage:99 
    11-01 18:31:44.936 W/ActivityManager( 3189): Unable to start service Intent { act=com.oplus.onet.service.INTENT_SDK_BIND_SERVICE pkg=com.oplus.onet } U=0: not found
    11-01 18:31:44.937 W/ContextImpl( 4912): Calling a method in the system process without a qualified user: android.app.ContextImpl.bindService:1973 android.content.ContextWrapper.bindService:863 com.oplus.onet.case$do.run:142 android.os.Handler.handleCallback:942 android.os.Handler.dispatchMessage:99 
    11-01 18:31:44.938 W/ActivityManager( 3189): Unable to start service Intent { act=com.oplus.onet.service.INTENT_SDK_BIND_SERVICE pkg=com.oplus.onet } U=0: not found
    11-01 18:31:44.938 W/ContextImpl( 4912): Calling a method in the system process without a qualified user: android.app.ContextImpl.bindService:1973 android.content.ContextWrapper.bindService:863 com.oplus.onet.case$do.run:142 android.os.Handler.handleCallback:942 android.os.Handler.dispatchMessage:99 
    11-01 18:31:44.939 W/ActivityManager( 3189): Unable to start service Intent { act=com.oplus.onet.service.INTENT_SDK_BIND_SERVICE pkg=com.oplus.onet } U=0: not found
    11-01 18:31:44.939 W/ContextImpl( 4912): Calling a method in the system process without a qualified user: android.app.ContextImpl.bindService:1973 android.content.ContextWrapper.bindService:863 com.oplus.onet.case$do.run:142 android.os.Handler.handleCallback:942 android.os.Handler.dispatchMessage:99 

    这里疯狂唤醒com.oplus.onet 服务,同时com.oplus.virtualcomm,这个虚拟通信也疯狂调用。于是只好解冻这net服务。

    第二次抓包

    11-01 18:48:53.927 E/AdbDebuggingManager( 3189): Caught an exception opening the socket: java.io.IOException: No such file or directory
    11-01 18:48:53.956 W/ActivityManager( 3189): Unable to start service Intent { act=com.heytap.accessory.action.BASE_FRAMEWORK_MANAGER pkg=com.heytap.accessory } U=0: not found
    11-01 18:48:53.958 W/ActivityManager( 3189): Unable to start service Intent { act=com.heytap.accessory.action.BASE_FRAMEWORK_MANAGER pkg=com.heytap.accessory } U=0: not found
    11-01 18:48:53.960 W/ActivityManager( 3189): Unable to start service Intent { act=com.heytap.accessory.ScanService pkg=com.heytap.accessory (has extras) } U=0: not found
    11-01 18:48:53.960 W/ActivityManager( 3189): Unable to start service Intent { act=com.heytap.accessory.action.BASE_FRAMEWORK_MANAGER pkg=com.heytap.accessory } U=0: not found
    11-01 18:48:53.960 W/ActivityManager( 3189): Unable to start service Intent { act=com.heytap.accessory.ScanService pkg=com.heytap.accessory (has extras) } U=0: not found
    11-01 18:48:53.960 W/ActivityManager( 3189): Unable to start service Intent { act=com.heytap.accessory.ScanService pkg=com.heytap.accessory (has extras) } U=0: not found
    11-01 18:48:53.962 W/ActivityManager( 3189): Unable to start service Intent { act=com.heytap.accessory.ScanService pkg=com.heytap.accessory (has extras) } U=0: not found
    11-01 18:48:53.962 W/ActivityManager( 3189): Unable to start service Intent { act=com.heytap.accessory.action.BASE_FRAMEWORK_MANAGER pkg=com.heytap.accessory } U=0: not found
    11-01 18:48:53.963 W/ActivityManager( 3189): Unable to start service Intent { act=com.heytap.accessory.action.BASE_FRAMEWORK_MANAGER pkg=com.heytap.accessory } U=0: not found
    11-01 18:48:53.963 W/ActivityManager( 3189): Unable to start service Intent { act=com.heytap.accessory.ScanService pkg=com.heytap.accessory (has extras) } U=0: not found
    11-01 18:48:53.964 W/ActivityManager( 3189): Unable to start service Intent { act=com.heytap.accessory.ScanService pkg=com.heytap.accessory (has extras) } U=0: not found
    11-01 18:48:53.964 W/ActivityManager( 3189): Unable to start service Intent { act=com.heytap.accessory.action.BASE_FRAMEWORK_MANAGER pkg=com.heytap.accessory } U=0: not found
    11-01 18:48:53.965 W/ActivityManager( 3189): Receiver with filter android.content.IntentFilter@56b32fa already registered for pid 16357, callerPackage is com.oplus.onet
    11-01 18:48:53.965 W/ActivityManager( 3189): Unable to start service Intent { act=com.heytap.accessory.action.BASE_FRAMEWORK_MANAGER pkg=com.heytap.accessory } U=0: not found
    11-01 18:48:53.966 W/ActivityManager( 3189): Unable to start service Intent { act=com.heytap.accessory.ScanService pkg=com.heytap.accessory (has extras) } U=0: not found
    11-01 18:48:53.966 W/ActivityManager( 3189): Unable to start service Intent { act=com.heytap.accessory.ScanService pkg=com.heytap.accessory (has extras) } U=0: not found

    这里疯狂唤醒com.heytap.accessory,于是把这个解冻了。

    第三次抓包

    发现一直在唤醒com.nearme.statistics.rom这个玩意,但是频次不是很高。搜索发现这是哪个用户体验计划,索性就不管了。

    同时在阅读了https://www.coolapk.com/feed/66547164这个大佬的文章之后。也是选择性的禁用软件。删除了olc和反馈工具箱这俩应用。

    其实从18年入手的第一台小米8开始,就开始了我的root之路。到现在已经七年了。也从小米换到了一加。从一个无脑安装模块的脚本小子,到了开始解读源码写程序的程序员。自己蜕变了好多,心态也老了好多。沉下心来做事,安安静静的学习!

    加油吧!

    ]]>