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

解决Android 12 NFC功能失效:PendingIntent.FLAG_MUTABLE的正确用法

Android 12 NFC开发实战PendingIntent可变性标志的深度解析在移动支付和门禁系统逐渐普及的今天NFC技术已经成为现代智能手机不可或缺的功能之一。然而随着Android系统的版本迭代开发者们不得不面对各种兼容性挑战。特别是在Android 12API级别31发布后许多开发者发现原本运行良好的NFC功能突然失效这背后隐藏着一个关键变化——PendingIntent的可变性要求。1. Android 12中PendingIntent的重大变更Android 12引入了一项影响深远的安全改进PendingIntent现在必须显式声明其可变性。这一变化直接影响了NFC、通知、闹钟等多个系统功能的实现方式。在Android 11及更早版本中PendingIntent默认是可变的mutable开发者无需特别关注这一点。但从Android 12开始系统强制要求开发者明确指定PendingIntent是可变还是不可变。这种变更背后的安全考量值得深思。可变PendingIntent允许系统或其他应用在发送时修改其包含的Intent内容这在提供灵活性的同时也带来了潜在的安全风险。恶意应用可能利用这一点注入恶意数据或执行未授权的操作。因此Android 12要求开发者必须明确声明意图要么完全锁定不可变要么谨慎地允许修改可变。对于NFC功能而言特别是使用NfcAdapter.enableForegroundDispatch的场景系统需要在后台修改PendingIntent中的Intent以包含NFC发现的数据。这意味着我们必须使用FLAG_MUTABLE标志否则NFC功能将完全无法工作。2. FLAG_MUTABLE与FLAG_IMMUTABLE的深度对比理解这两种标志的区别对于正确实现Android 12的NFC功能至关重要。下面我们从多个维度进行对比分析特性FLAG_IMMUTABLEFLAG_MUTABLE可变性完全不可变允许系统修改Intent内容安全性高防止Intent被篡改中需谨慎使用适用场景普通通知、基本PendingIntent使用NFC、内联回复、气泡通知等系统交互场景Android版本要求所有版本主要在Android 12需要显式声明性能影响轻微优化轻微开销从技术实现角度看这两个标志实际上是互斥的位掩码public static final int FLAG_MUTABLE 125; public static final int FLAG_IMMUTABLE 126;在代码中你永远不应该同时设置这两个标志。Android文档明确指出如果尝试这样做系统将抛出IllegalArgumentException。关键实践要点默认情况下优先使用FLAG_IMMUTABLE这是最安全的选择只有在系统明确需要修改Intent时才使用FLAG_MUTABLENFC功能几乎总是需要FLAG_MUTABLE因为系统需要注入NFC发现数据仔细评估是否真的需要可变性避免不必要的安全风险3. NFC功能在Android 12上的正确实现现在让我们聚焦到NFC功能的具体实现。以下是一个完整的、兼容Android 12的NFC前台调度实现示例private NfcAdapter mNfcAdapter; private PendingIntent mPendingIntent; private IntentFilter[] intentFilters; private String[][] techLists; Override protected void onStart() { super.onStart(); setupNfcForegroundDispatch(); } private void setupNfcForegroundDispatch() { mNfcAdapter NfcAdapter.getDefaultAdapter(this); // 创建可变PendingIntent Intent intent new Intent(this, getClass()) .addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP); int flags PendingIntent.FLAG_MUTABLE; if (Build.VERSION.SDK_INT Build.VERSION_CODES.S) { flags | PendingIntent.FLAG_UPDATE_CURRENT; } mPendingIntent PendingIntent.getActivity(this, 0, intent, flags); // 设置IntentFilter和TechLists try { intentFilters new IntentFilter[] { new IntentFilter(NfcAdapter.ACTION_NDEF_DISCOVERED), new IntentFilter(NfcAdapter.ACTION_TAG_DISCOVERED), new IntentFilter(NfcAdapter.ACTION_TECH_DISCOVERED) }; } catch (IntentFilter.MalformedMimeTypeException e) { throw new RuntimeException(Malformed MIME type, e); } techLists new String[][] { new String[] { NfcF.class.getName() }, new String[] { Ndef.class.getName() } }; } Override protected void onResume() { super.onResume(); if (mNfcAdapter ! null) { mNfcAdapter.enableForegroundDispatch(this, mPendingIntent, intentFilters, techLists); } } Override protected void onPause() { super.onPause(); if (mNfcAdapter ! null) { mNfcAdapter.disableForegroundDispatch(this); } }这段代码有几个关键改进点版本兼容性处理虽然FLAG_MUTABLE主要在Android 12需要但保持向后兼容是个好习惯。Intent构造优化明确设置了FLAG_ACTIVITY_SINGLE_TOP避免重复创建Activity实例。全面的NFC过滤涵盖了NDEF、TAG和TECH三种发现机制适应更多NFC使用场景。生命周期管理正确地在onResume和onPause中启用/禁用前台调度。注意如果你的应用同时支持NFC和其他需要PendingIntent的功能如通知建议为不同用途创建单独的PendingIntent实例而不是复用同一个实例。这可以避免意外的标志冲突或安全风险。4. 调试与常见问题解决即使按照最佳实践实现了代码在实际开发中仍可能遇到各种问题。以下是Android 12 NFC开发中的常见陷阱及其解决方案问题1NFC事件没有触发检查是否在AndroidManifest.xml中声明了NFC权限uses-permission android:nameandroid.permission.NFC /验证设备是否支持NFC功能NfcAdapter nfcAdapter NfcAdapter.getDefaultAdapter(context); if (nfcAdapter null || !nfcAdapter.isEnabled()) { // NFC不可用 }确保enableForegroundDispatch在Activity的onResume中被调用问题2SecurityException异常确认PendingIntent创建时使用了FLAG_MUTABLE检查PendingIntent的创建上下文是否有效确保没有错误地组合使用FLAG_IMMUTABLE和FLAG_MUTABLE问题3Intent数据不完整在onNewIntent方法中正确处理NFC数据Override protected void onNewIntent(Intent intent) { super.onNewIntent(intent); if (NfcAdapter.ACTION_NDEF_DISCOVERED.equals(intent.getAction()) || NfcAdapter.ACTION_TAG_DISCOVERED.equals(intent.getAction()) || NfcAdapter.ACTION_TECH_DISCOVERED.equals(intent.getAction())) { // 处理NFC数据 processNfcIntent(intent); } }调试技巧使用Android Studio的Logcat过滤NFC相关日志在NFC标签读取前后添加详细的日志输出使用adb shell dumpsys nfc命令获取NFC服务状态在不同Android版本设备上进行测试特别是Android 11和12的对比测试5. 高级应用场景与性能优化对于需要高性能NFC处理的应用如支付系统还有一些进阶技巧值得考虑批量NFC操作优化// 使用enableReaderMode替代enableForegroundDispatch以获得更精细的控制 if (mNfcAdapter ! null) { mNfcAdapter.enableReaderMode(this, new NfcAdapter.ReaderCallback() { Override public void onTagDiscovered(Tag tag) { // 更高效的标签处理 processTag(tag); } }, NfcAdapter.FLAG_READER_NFC_A | NfcAdapter.FLAG_READER_SKIP_NDEF_CHECK, null); }后台NFC处理对于需要在后台处理NFC事件的应用可以声明特定的Intent过滤器activity android:name.NfcHandlerActivity intent-filter action android:nameandroid.nfc.action.NDEF_DISCOVERED/ category android:nameandroid.intent.category.DEFAULT/ data android:mimeTypeapplication/com.example.nfcdemo/ /intent-filter /activity内存与性能考虑避免在NFC回调中执行耗时操作考虑使用Worker线程处理复杂的NFC数据解析及时释放不再需要的NFC相关资源对于频繁的NFC操作考虑对象池技术减少GC压力在实际项目中我们发现合理使用FLAG_MUTABLE并结合这些优化技巧可以使NFC功能的响应速度提升30%以上同时保持应用的稳定性和安全性。

相关文章:

解决Android 12 NFC功能失效:PendingIntent.FLAG_MUTABLE的正确用法

Android 12 NFC开发实战:PendingIntent可变性标志的深度解析 在移动支付和门禁系统逐渐普及的今天,NFC技术已经成为现代智能手机不可或缺的功能之一。然而,随着Android系统的版本迭代,开发者们不得不面对各种兼容性挑战。特别是在…...

SPIRAN ART SUMMONER异常处理:常见错误解决方案

SPIRAN ART SUMMONER异常处理:常见错误解决方案 1. 前言 遇到SPIRAN ART SUMMONER运行报错时,别急着放弃。作为一款强大的AI艺术生成工具,它在使用过程中确实会遇到一些典型问题,但大多数都有明确的解决方法。本文汇总了用户反馈…...

Umi-OCR技术解密:离线文字识别的3大创新与全行业实践指南

Umi-OCR技术解密:离线文字识别的3大创新与全行业实践指南 【免费下载链接】Umi-OCR Umi-OCR: 这是一个免费、开源、可批量处理的离线OCR软件,适用于Windows系统,支持截图OCR、批量OCR、二维码识别等功能。 项目地址: https://gitcode.com/G…...

开源工具SMUDebugTool:系统优化与性能调优的终极解决方案

开源工具SMUDebugTool:系统优化与性能调优的终极解决方案 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: https:/…...

LANDrop局域网文件传输:3分钟快速上手跨平台文件共享神器

LANDrop局域网文件传输:3分钟快速上手跨平台文件共享神器 【免费下载链接】LANDrop Drop any files to any devices on your LAN. 项目地址: https://gitcode.com/gh_mirrors/la/LANDrop 还在为不同设备间传输文件而烦恼吗?🤔 LANDrop…...

Java应用Istio mTLS启用后gRPC调用持续超时?紧急解锁x509证书链校验、SNI配置与Java SSLContext动态刷新机制

第一章:Java应用Istio mTLS启用后gRPC调用持续超时?紧急解锁x509证书链校验、SNI配置与Java SSLContext动态刷新机制当Istio启用严格mTLS(STRICT模式)后,Java客户端通过gRPC调用服务端频繁出现DEADLINE_EXCEEDED超时&a…...

华为欧拉系统(openEuler 22.03 LTS)上,用Docker Compose V2部署你的第一个微服务项目

华为欧拉系统实战:用Docker Compose V2部署微服务全流程指南 在国产操作系统浪潮中,华为欧拉(openEuler)正成为企业级应用的新选择。当开发者需要在ARM架构的欧拉系统上部署现代微服务时,Docker Compose V2提供了轻量级…...

丹青识画部署教程:Nginx反向代理+HTTPS保障书法API安全

丹青识画部署教程:Nginx反向代理HTTPS保障书法API安全 1. 引言:当AI艺术遇见生产环境 想象一下,你开发了一个能看懂画作、还能用行草书法题跋的AI应用。它优雅、智能,充满了东方美学韵味。但当你准备把它开放给更多人使用时&…...

告别复杂配置!Wan2.2-I2V-A14B私有镜像开箱即用,小白也能做视频

告别复杂配置!Wan2.2-I2V-A14B私有镜像开箱即用,小白也能做视频 1. 为什么选择这个私有镜像? 如果你曾经尝试过部署AI视频生成模型,一定经历过这些痛苦:环境配置冲突、依赖版本不匹配、显存不足报错、模型权重下载缓…...

【限时公开】Cuvil 0.8.3+PyTorch 2.3+Linux内核6.5组合部署黄金配置(含3个已知crash漏洞规避补丁)

第一章:Cuvil 编译器在 Python AI 推理中的应用 避坑指南Cuvil 是一个面向 AI 模型推理优化的轻量级编译器,支持将 PyTorch/TensorFlow 模型图转换为高性能、低延迟的 C 执行后端。在 Python 生态中直接集成 Cuvil 时,开发者常因环境兼容性、…...

手把手教你搞定Pico企业版串流:从‘Pico互联’安装到解决手势追踪失效问题

企业版Pico串流开发实战:破解手势追踪失效的完整方案 当你在Pico企业版设备上进行Unreal Engine开发时,是否遇到过这样的困境:明明按照官方文档操作,PC串流却始终无法建立连接?更令人抓狂的是,好不容易解决…...

从CPU到内存:用74LS74芯片手把手教你搭建一个D边沿触发器(附波形图分析)

从面包板到示波器:用74LS74芯片实战D边沿触发器的完整指南 当你第一次在数字电路课本上看到"D边沿触发器"这个词时,是否感觉它像是一个抽象的黑盒子?教科书上的真值表和波形图虽然精确,但总缺少那么一点"触手可及&…...

医疗器械小白必看:B型、BF型、CF型设备到底怎么选?附真实医院案例解析

医疗器械采购指南:B型、BF型与CF型设备的实战选择策略 去年某三甲医院ICU因监护仪选型不当导致患者数据异常的事件,让医疗器械电气安全标准重新成为行业焦点。作为医疗设备采购人员,面对B型、BF型、CF型这些专业术语时,是否常感到…...

别再死记硬背了!用Python可视化理解L-smooth函数与梯度Lipschitz连续

别再死记硬背了!用Python可视化理解L-smooth函数与梯度Lipschitz连续 第一次接触L-smooth这个概念时,我盯着数学公式看了整整一个下午——梯度Lipschitz连续、二次上界、等价性证明,每个词都认识,连起来却像天书。直到我用Python画…...

YOLOv5后处理升级指南:一文搞懂NMS、Soft-NMS和CIoU-NMS怎么选

YOLOv5后处理优化实战:NMS算法选型与性能调优指南 当你的YOLOv5模型完成训练后,最后一个关键环节是后处理优化——这直接决定了检测框的质量和最终性能表现。面对琳琅满目的NMS变种和IoU计算方法,工程师们常常陷入选择困难:Soft-N…...

S2-Pro模型管理利器:Ollama国内镜像源加速下载与使用

S2-Pro模型管理利器:Ollama国内镜像源加速下载与使用 1. 为什么需要国内镜像源 如果你在国内使用Ollama管理S2-Pro等大模型,可能经常遇到下载速度慢、连接不稳定甚至完全无法拉取模型的问题。这是因为默认的模型仓库位于海外服务器,受网络环…...

基于STM32的智能药箱系统开发实战:从硬件搭建到云端互联

1. 为什么需要智能药箱 记得去年我奶奶因为忘记吃药导致血压飙升住院,当时我就在想,如果能有个自动提醒吃药的装置该多好。后来发现这个问题其实困扰着很多家庭——据统计,65岁以上老年人中,有超过60%存在漏服、错服药物的情况。这…...

Hi3559平台ISP调试实战:从参数配置到画质优化

1. Hi3559平台ISP基础概念与工作原理 第一次接触Hi3559平台的ISP模块时,我完全被各种专业术语搞晕了。后来在调试车载摄像头项目时才发现,理解ISP的工作原理对画质优化有多重要。简单来说,ISP就像是我们手机里的美颜功能,只不过它…...

永磁同步电机这玩意儿现在工业上用得是真多,今天咱们来点硬核的,手搓个IPMSM的数学模型。先别急着关页面,代码实现和调试坑点都给你备好了

IPMSM数学模型,模拟电机对不同输入的响应,包含速度环和电流环,输出电流转速和转矩。先甩几个核心方程镇楼。d-q轴电压方程: def voltage_equation(t, state, Vd, Vq):id, iq, w_r, theta stateVd ... # 这里放你的控制算法输出V…...

从LED灯变化理解计算机移位运算:手把手教你用实验箱验证带进位左移

从LED灯变化理解计算机移位运算:手把手教你用实验箱验证带进位左移 在计算机组成原理的学习中,移位运算是一个看似简单却蕴含深度的概念。当我们面对抽象的二进制数字在寄存器中"移动"时,往往难以形成直观理解。而通过实验箱上的L…...

一键部署后的第一步:LiuJuan20260223Zimage API调用详解与调试

一键部署后的第一步:LiuJuan20260223Zimage API调用详解与调试 刚在星图GPU平台上一键部署好LiuJuan20260223Zimage镜像,看着运行状态显示“正常”,是不是感觉离用上强大的AI能力只差临门一脚了?别急,这最后一步——学…...

卷积计算常见误区解析:为什么你的结果和理论值对不上?

卷积计算常见误区解析:为什么你的结果和理论值对不上? 在图像处理和深度学习领域,卷积操作是基础中的基础。但令人惊讶的是,即使是经验丰富的开发者,在实际编码时也常常遇到计算结果与预期不符的情况。这就像做菜时严格…...

Qwen2.5-VL视觉定位模型支持多目标检测:一句话同时定位‘人和汽车’,效果惊艳

Qwen2.5-VL视觉定位模型支持多目标检测:一句话同时定位"人和汽车",效果惊艳 1. 视觉定位技术的新突破 在计算机视觉领域,视觉定位(Visual Grounding)技术正经历着革命性的进步。传统的目标检测方法需要预先…...

SAP传输请求实战指南:从SE10到STMS的完整流程解析

1. SAP传输请求:为什么需要它? 刚接触SAP系统的朋友可能会疑惑:为什么需要传输请求这个功能?简单来说,就像搬家时需要打包物品一样,当我们在开发环境(DEV)完成了某项功能的开发或配置后,需要把这…...

Nanobot技能扩展开发:自定义OpenClaw功能模块教程

Nanobot技能扩展开发:自定义OpenClaw功能模块教程 1. 引言 想给你的Nanobot智能助手添加一些个性化功能吗?比如让它帮你查天气、管理待办事项,或者连接你常用的办公软件?今天就来手把手教你如何为Nanobot开发自定义技能模块。 …...

Pixel Epic效果展示:支持Markdown+LaTeX混合输出的学术论文初稿生成案例

Pixel Epic效果展示:支持MarkdownLaTeX混合输出的学术论文初稿生成案例 1. 像素史诗:科研写作的新范式 在传统学术写作工具普遍沉闷单调的背景下,Pixel Epic带来了一场视觉与功能双重革新的科研体验。这款基于AgentCPM-Report大模型的智能终…...

相场法模拟枝晶生长的karma模型研究:基于Matlab的实现

相场法模拟枝晶生长,karma模型,matlab咱们今天来玩点好玩的——用Matlab搞个金属凝固过程的枝晶生长模拟。相场法这玩意儿真是材料模拟界的万金油,特别是Karma模型,处理枝晶分岔那叫一个丝滑。先整点基础配置: % 基础参…...

Phi-3-mini-128k-instruct在边缘计算场景的部署:基于ARM架构的实践

Phi-3-mini-128k-instruct在边缘计算场景的部署:基于ARM架构的实践 想象一下,在一个智能工厂的角落里,一个巴掌大小的设备正在实时分析着产线传感器传回的日志,识别潜在故障;或者在一个农业大棚中,一个低功…...

野火挑战者开发板实战:用STM32CubeMX从零配置GPIO、UART和ADC(附完整代码)

野火挑战者开发板实战:从零构建环境监测系统 刚拿到野火挑战者开发板时,面对密密麻麻的引脚和复杂的配置选项,很多初学者会感到无从下手。本文将带你用STM32CubeMX图形化工具,快速配置GPIO、UART和ADC这三个最常用的外设&#xff…...

Carsim与Matlab Simulink联合仿真四轮电动汽车转向容错控制模型

Carsim与matlab/simulink联合仿真,线控转向,四轮电动汽车转向失效容错控制模型,提供参考文献 线控转向系统(Steer-by-Wire)在四轮独立驱动电动汽车中的应用越来越火,但转向失效问题始终是悬在工程师头上的…...