当前位置: 首页 > article >正文

保姆级教程:在AOSP源码里给SIM卡加个“小功能”,从UiccProfile到IccRecords的客制化实战

深度定制AOSP Telephony框架从UiccProfile到IccRecords的SIM卡功能扩展实战在Android系统开发领域Telephony框架的定制化需求日益增多尤其是针对SIM卡功能的深度改造。本文将带您深入AOSP源码探索如何在UiccProfile、IccRecords等核心类中安全地植入自定义逻辑实现诸如运营商名称修改、特定SIM文件读取等高级功能。1. AOSP Telephony框架核心组件解析1.1 UICC族类架构与职责划分UICCUniversal Integrated Circuit Card作为SIM卡的技术实现载体在AOSP中通过一系列紧密协作的类完成功能抽象UiccController整个UICC系统的控制中枢负责监听SIM卡状态变化并协调各子模块工作。其核心机制包括// 典型初始化流程示例 UiccController.make(context, phone); mUiccController.registerForIccChanged(handler, EVENT_ICC_CHANGED, null);UiccProfile运营商配置的核心载体包含以下关键属性属性类型说明mCarrierPrivilegeRulesUiccCarrierPrivilegeRules运营商权限规则mUiccCardApplicationsUiccCardApplication[]SIM卡应用集合mCatServiceCatServiceSIM卡工具箱服务IccRecordsSIM卡文件系统的抽象表示主要处理EF_IMSI (国际移动用户标识)EF_ADN (电话号码簿)EF_SMS (短消息存储)EF_SPN (服务提供商名称)提示修改任何SIM卡相关功能前务必通过getIccRecords()获取当前卡片记录实例。1.2 消息处理机制剖析Telephony框架采用Handler机制实现异步通信关键消息类型包括EVENT_APP_READY卡应用就绪EVENT_RECORDS_LOADED记录加载完成EVENT_REFRESHSIM卡刷新典型消息处理流程Override public void handleMessage(Message msg) { switch (msg.what) { case EVENT_RECORDS_LOADED: updateSpnDisplay(); break; case EVENT_REFRESH: handleRefresh((AsyncResult) msg.obj); break; } }2. SIM卡功能定制实战指南2.1 运营商名称动态修改方案通过重写UiccProfile的handleCarrierNameOverride方法可实现运营商名称的动态控制// 自定义运营商名称逻辑 private void handleCustomCarrierName() { String overrideName SystemProperties.get(persist.custom.carrier_name); if (!TextUtils.isEmpty(overrideName)) { mCarrierName overrideName; sendBroadcast(new Intent(TelephonyIntents.ACTION_CARRIER_NAME_CHANGED)); } }实现要点通过系统属性持久化自定义名称在SIM卡状态变化时触发更新发送广播通知系统更新显示2.2 扩展SIM卡文件读取能力在IccRecords子类中添加自定义文件读取逻辑public byte[] readCustomFile(int fileId) throws IccException { IccFileHandler fh getIccFileHandler(); if (fh ! null) { return fh.loadEFTransparent(fileId, null); } throw new IccException(No File Handler available); }配套需在IccFileHandler中注册新文件类型// 文件类型注册表示例 public static final int EF_CUSTOM_FILE 0x6F50;3. 安全修改架构的最佳实践3.1 代码注入位置选择原则推荐修改点及其风险等级修改位置风险等级适用场景UiccProfile.update()中运营商配置更新IccRecords.handleMessage()高记录处理流程UiccCarrierPrivilegeRules低权限规则管理注意避免直接修改UiccController的核心流程优先考虑通过回调接口扩展功能。3.2 兼容性保障措施为确保修改不影响原有功能建议采用AOP编程模式通过动态代理拦截关键方法public class UiccProfileProxy extends UiccProfile { Override public void update(IccCardStatus status) { // 前置处理 super.update(status); // 后置处理 } }配置开关控制通过资源文件管理功能开关bool nameconfig_custom_sim_feature_enabledtrue/bool多SIM卡适配方案for (UiccProfile profile : mUiccProfiles) { if (profile ! null) { // 应用修改到每个卡槽 } }4. 调试与验证方法论4.1 关键日志标记点在代码中植入以下调试信息// 在UiccProfile构造器中 Log.d(TAG, Profile created for slot mPhoneId); // 在记录加载完成时 EventLog.writeEvent(EVENT_SIM_RECORDS_LOADED, mImsi, mSpn, mRecordsLoaded);4.2 自动化测试方案构建自定义Instrumentation测试用例Test public void testCustomCarrierName() { // 准备测试环境 setTestMode(true); // 执行测试逻辑 setCarrierNameOverride(TEST_CARRIER); // 验证结果 assertEquals(TEST_CARRIER, getDisplayedCarrierName()); }测试覆盖要点SIM卡热插拔场景多卡切换场景运营商配置更新场景5. 高级定制技巧与陷阱规避5.1 性能优化策略针对频繁操作的优化方案缓存机制对静态SIM信息进行内存缓存private String mCachedImsi; public String getImsi() { if (mCachedImsi null) { mCachedImsi fetchImsiFromCard(); } return mCachedImsi; }延迟加载非关键数据按需加载private void lazyLoadSmsRecords() { if (!mSmsRecordsLoaded) { loadSmsRecords(); } }5.2 常见问题解决方案问题1修改后SIM卡状态异常检查是否正确处理了EVENT_REFRESH消息验证IccCardStatus的转换逻辑问题2自定义文件读取失败确认EF文件ID符合规范检查文件访问权限if (!mUiccCard.hasCarrierPrivileges()) { throw new SecurityException(Missing carrier privileges); }问题3多卡兼容性问题采用卡槽隔离的存储策略SharedPreferences prefs context.getSharedPreferences( sim_prefs_ mPhoneId, Context.MODE_PRIVATE);在实际项目中我们发现最稳定的修改方式是在UiccProfile初始化完成后通过回调接口注入自定义逻辑这比直接修改核心类更能适应不同厂商的代码分支。对于需要读取特殊SIM文件的需求务必先在UiccCarrierPrivilegeRules中声明相应权限避免出现安全异常。

相关文章:

保姆级教程:在AOSP源码里给SIM卡加个“小功能”,从UiccProfile到IccRecords的客制化实战

深度定制AOSP Telephony框架:从UiccProfile到IccRecords的SIM卡功能扩展实战 在Android系统开发领域,Telephony框架的定制化需求日益增多,尤其是针对SIM卡功能的深度改造。本文将带您深入AOSP源码,探索如何在UiccProfile、IccReco…...

别再死记公式了!用Python+Matplotlib动画可视化理解向量点积、叉积的几何意义

用Python动画解锁向量运算的几何奥秘:点积与叉积的视觉化探索 线性代数中那些抽象的向量运算公式,是否总让你在纸上反复推导却难以建立直观理解?当教科书上冰冷的数学符号无法唤起你的几何直觉时,或许该让代码和动画来架起这座桥梁…...

终极罗技PUBG鼠标宏教程:5分钟掌握智能压枪技巧

终极罗技PUBG鼠标宏教程:5分钟掌握智能压枪技巧 【免费下载链接】logitech-pubg PUBG no recoil script for Logitech gaming mouse / 绝地求生 罗技 鼠标宏 项目地址: https://gitcode.com/gh_mirrors/lo/logitech-pubg 绝地求生(PUBG&#xff0…...

联楷国际超级大掌柜:商业AI大模型如何重塑中小企业智能管理未来?

在人工智能浪潮席卷全球的当下,商业领域的AI应用已从概念炒作转向深度落地。对于广大中小企业而言,如何选择一家非娱乐化AI公司,真正将AI技术转化为降本增效的利器,成为数字化转型的关键命题。作为科大讯飞生态伙伴,联…...

告别绿点焦虑!用ADB命令一键隐藏Android 12/13的相机麦克风状态栏图标(无需Root)

深度隐藏Android隐私指示器的ADB高阶玩法 每次打开相机或语音助手时,状态栏角落那个闪烁的绿点总在提醒你:系统正在监视着你的隐私权限。对于注重界面简洁的极客用户来说,这个设计良好的隐私保护功能反而成了视觉干扰。更令人困扰的是&#…...

实战踩坑记录:在Windows 11上用Android Studio模拟器跑通Android Maxim的全过程

Windows 11环境下的Android Maxim实战:从环境搭建到自动化测试全解析 在移动应用开发领域,自动化测试已成为保证产品质量的关键环节。对于Windows平台上的Android开发者而言,如何在本地环境中高效运行自动化测试工具,是提升开发效…...

从Depix的爆火到冷静:聊聊‘马赛克还原’背后的算法原理与伦理边界

从Depix的爆火到冷静:解码马赛克还原技术的双面性 当Depix项目在GitHub上突然走红时,整个技术社区为之震动。这个看似简单的工具,能够将某些特定类型的马赛克还原为原始文字,引发了关于数字隐私安全的广泛讨论。但在这股热潮背后&…...

为什么高频PLL里偏爱用TSPC分频器?聊聊动态触发器的那些事儿

为什么高频PLL设计者钟爱TSPC分频器?动态触发器的技术内幕 在5G通信和毫米波雷达的电路设计中,工程师们常常面临一个关键抉择:当锁相环(PLL)需要工作在10GHz以上频率时,传统分频器架构突然变得力不从心。此…...

本地部署应用服务器 Wildfly 并实现外部访问

wildfly 是一款高性能、可扩展的易于管理的开源应用服务器。它支持独立模式和域模式,适应不同规模需求,支持大规模并发连接,使用社交网络、在线游戏等场景。本文将详细介绍如何在本地安装 Wildfly 以及结合路由侠内网穿透实现外网访问 Wildfl…...

从零到一:在Ubuntu上为SpaceMouse配置开源驱动并集成Python/Robosuite

1. 为什么需要为SpaceMouse配置开源驱动? 如果你手头有一台3Dconnexion的SpaceMouse,想在Ubuntu系统上使用它来控制机器人仿真环境,可能会遇到一个尴尬的问题:官方早在2014年就停止了对Linux驱动的支持。这意味着你无法直接使用Sp…...

MAX30102心率血氧数据不准?可能是你的算法和滤波没做对(STM32实战分析)

MAX30102心率血氧测量优化实战:从数据波动到精准结果的进阶指南 引言:当传感器数据开始"说谎" 那是一个加班的深夜,我的MAX30102模块第37次显示我的心率为0——而我的咖啡杯知道这显然不真实。这种令人抓狂的场景,正是许…...

告别复制粘贴!实战派教你用Allegro2Altium.bat脚本搞定AD文件转换(附环境变量避坑指南)

告别复制粘贴!实战派教你用Allegro2Altium.bat脚本搞定AD文件转换(附环境变量避坑指南) 在PCB设计领域,文件格式转换一直是工程师们绕不开的痛点。特别是当项目需要从Cadence Allegro迁移到Altium Designer时,网上的教…...

ESP8266连接公共MQTT服务器,用户名密码怎么填才不报错?

ESP8266连接公共MQTT服务器的认证避坑指南 当你在深夜调试ESP8266连接MQTT服务器时,突然弹出一条"Connection failed: Bad username or password"的错误提示——这种挫败感每个物联网开发者都经历过。本文将带你深入理解公共MQTT服务器的认证机制&#xf…...

告别内存焦虑!ESP32+LVGL加载PNG图片的实战优化与内存管理技巧

ESP32LVGL深度优化:PNG图片加载与内存管理的实战艺术 在物联网设备的图形界面开发中,ESP32搭配LVGL已成为许多开发者的首选方案。但当涉及到PNG图片加载时,内存限制往往成为最棘手的瓶颈。我曾在一个智能家居面板项目中被这个问题困扰数周——…...

从一次线上故障复盘:深度解析AutoSar WDGM如何守护你的ECU核心任务链

从一次线上故障复盘:深度解析AutoSar WDGM如何守护你的ECU核心任务链 在汽车电子控制单元(ECU)开发中,功能安全始终是悬在工程师头顶的达摩克利斯之剑。去年我们团队遭遇了一次典型的线上故障:某个关键SWC任务链因执行…...

终极Windows激活方案:KMS_VL_ALL_AIO智能激活脚本完全解析

终极Windows激活方案:KMS_VL_ALL_AIO智能激活脚本完全解析 【免费下载链接】KMS_VL_ALL_AIO Smart Activation Script 项目地址: https://gitcode.com/gh_mirrors/km/KMS_VL_ALL_AIO 还在为Windows系统激活而烦恼吗?每次重装系统后面对"需要…...

别光看API了!聊聊SpringBoot集成Activiti后,那二十多张表到底都是干嘛的?

别光看API了!聊聊SpringBoot集成Activiti后,那二十多张表到底都是干嘛的? 当你第一次在SpringBoot项目中集成Activiti工作流引擎,启动应用后看到数据库里突然多出的二十多张表,是否感到一头雾水?这些以act_…...

STM32F103C8T6标准库工程模板搭建避坑指南:从文件结构到编译报错的完整解决方案

STM32F103C8T6标准库工程模板搭建避坑指南:从文件结构到编译报错的完整解决方案 当你第一次接触STM32开发时,搭建一个标准的工程模板往往是遇到的第一个挑战。很多教程会告诉你"怎么做",但很少解释"为什么这么做"。本文…...

Desktop Postflop:德州扑克策略计算引擎的技术分析与实践指南

Desktop Postflop:德州扑克策略计算引擎的技术分析与实践指南 【免费下载链接】desktop-postflop [Development suspended] Advanced open-source Texas Holdem GTO solver with optimized performance 项目地址: https://gitcode.com/gh_mirrors/de/desktop-post…...

当混乱的地址数据遇见智能解析:一个Java开发者的救赎之旅

当混乱的地址数据遇见智能解析:一个Java开发者的救赎之旅 【免费下载链接】address-parse Java 版智能解析收货地址 项目地址: https://gitcode.com/gh_mirrors/addr/address-parse 你是否也曾被这样的地址数据折磨过? "广东省深圳市盐田区…...

如何用roop-unleashed在5分钟内制作专业级AI换脸视频:免费开源工具完整指南

如何用roop-unleashed在5分钟内制作专业级AI换脸视频:免费开源工具完整指南 【免费下载链接】roop-unleashed Evolved Fork of roop with Web Server and lots of additions 项目地址: https://gitcode.com/gh_mirrors/ro/roop-unleashed 你是否曾梦想过制作…...

M1/M2 Mac 开发者必看:用Homebrew搞定MySQL 5.7,从安装到连接Navicat的完整避坑记录

M1/M2 Mac开发者实战:用Homebrew征服MySQL 5.7的全链路指南 当那台崭新的M系列MacBook Pro第一次在你手中亮起屏幕时,你可能已经迫不及待想要搭建开发环境了。但当你按照传统教程安装MySQL 5.7时,那些在Intel芯片上畅通无阻的步骤突然变得荆棘…...

终极指南:深入解析Godot PCK文件解包器的完整工作流程

终极指南:深入解析Godot PCK文件解包器的完整工作流程 【免费下载链接】godot-unpacker godot .pck unpacker 项目地址: https://gitcode.com/gh_mirrors/go/godot-unpacker godot-unpacker是一款专业的Godot游戏资源解包工具,专门用于提取Godot引…...

ESXi 8.0存储进阶:手把手教你创建RDM磁盘直通给群晖DSM,告别缓存盘限制

ESXi 8.0存储进阶:突破群晖DSM限制的RDM磁盘直通实战指南 在虚拟化环境中,存储性能往往是决定整体系统响应速度的关键因素。对于使用ESXi搭建All-in-One家庭服务器的技术爱好者来说,如何充分发挥NVMe SSD的性能优势,同时规避群晖D…...

华为交换机VRRP配置避坑指南:优先级、Track联动与虚拟IP设置的那些细节

华为交换机VRRP实战精要:优先级策略、Track联动机制与虚拟IP配置全解析 在现网架构中,VRRP协议如同网络流量的"隐形守护者",默默确保着业务连续性。当核心交换机突发故障时,毫秒级的切换能力往往决定着业务系统的生死存…...

PHP面向对象方式调用的庖丁解牛

它的本质是:当代码执行 $obj->method() 时,PHP 并非像 C 那样直接跳转到固定的内存地址,而是经历了一场复杂的 运行时查找 (Runtime Lookup) 。它需要解析对象类型、检索类定义、定位方法指针、处理访问控制,并最终在当前的执行…...

别再为找数据集发愁了!这份超全的电气AI数据集清单(含下载链接)帮你搞定目标检测与负荷预测

电气AI实战指南:从数据集获取到模型落地的全流程解析 在电气工程与人工智能的交叉领域,数据是驱动创新的核心燃料。无论是输电线路缺陷识别还是新能源发电预测,优质数据集往往决定了项目的成败。但现实情况是,许多研究者花费大量时…...

CefFlashBrowser:拯救Flash数字遗产的终极方案,让经典游戏重获新生

CefFlashBrowser:拯救Flash数字遗产的终极方案,让经典游戏重获新生 【免费下载链接】CefFlashBrowser Flash浏览器 / Flash Browser 项目地址: https://gitcode.com/gh_mirrors/ce/CefFlashBrowser 还记得那些年我们在4399、7k7k等网站上畅玩的Fl…...

手把手教你用Python复现AES/ECB解密过程(附完整代码与避坑点)

手把手教你用Python复现AES/ECB解密过程(附完整代码与避坑点) 在数据安全领域,AES(高级加密标准)算法因其高安全性和高效性成为最广泛使用的对称加密方案之一。其中ECB(电子密码本)模式作为AES的…...

别再死记硬背了!用Unity粒子系统做个会动的火焰,5分钟搞定基础属性

用Unity粒子系统打造动态火焰:从参数恐惧到创意掌控 火焰在游戏场景中从来不只是简单的视觉效果——它是营地篝火的温暖,是战场爆炸的震撼,更是魔法施放时的灵魂。当我第一次打开Unity的粒子系统面板时,那密密麻麻的参数列表确实让…...