NFC功能如何实现?安卓开发教程步骤详解

长按可调倍速

【极客学院】 Android NFC应用开发

NFC安卓开发实战指南

NFC技术核心原理
近场通信(NFC)允许安卓设备在10厘米内与其他NFC设备或标签安全交换数据,其工作模式包括:

安卓开发教程步骤详解

  • 读/写模式: 设备主动读取或写入NFC标签数据
  • 点对点模式: 两台设备直接交换信息(如Android Beam)
  • 卡模拟模式: 设备模拟实体智能卡(如门禁、支付卡)

开发环境与基础配置

  1. 权限声明 (AndroidManifest.xml)

    <uses-permission android:name="android.permission.NFC" />
    <uses-feature android:name="android.hardware.nfc" android:required="true" />
  2. NFC功能检测

    NfcAdapter nfcAdapter = NfcAdapter.getDefaultAdapter(this);
    if (nfcAdapter == null) {
     Toast.makeText(this, "设备不支持NFC", Toast.LENGTH_SHORT).show();
     finish();
    } else if (!nfcAdapter.isEnabled()) {
     // 引导用户开启NFC
     startActivity(new Intent(Settings.ACTION_NFC_SETTINGS));
    }
  3. 前台调度系统配置 (Activity中)

    @Override
    protected void onResume() {
     super.onResume();
     PendingIntent pendingIntent = PendingIntent.getActivity(
         this, 0, new Intent(this, getClass()).addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP), 
         PendingIntent.FLAG_MUTABLE
     );
     nfcAdapter.enableForegroundDispatch(this, pendingIntent, null, null);
    }

@Override
protected void onPause() {
super.onPause();
nfcAdapter.disableForegroundDispatch(this);
}


---
### 二、NDEF数据解析实战
处理最常见的NFC数据格式(NDEF):
```java
@Override
protected void onNewIntent(Intent intent) {
    super.onNewIntent(intent);
    if (NfcAdapter.ACTION_NDEF_DISCOVERED.equals(intent.getAction())) {
        Parcelable[] rawMessages = intent.getParcelableArrayExtra(NfcAdapter.EXTRA_NDEF_MESSAGES);
        if (rawMessages != null) {
            NdefMessage[] messages = new NdefMessage[rawMessages.length];
            for (int i = 0; i < rawMessages.length; i++) {
                messages[i] = (NdefMessage) rawMessages[i];
                for (NdefRecord record : messages[i].getRecords()) {
                    // 解析文本记录
                    if (record.getTnf() == NdefRecord.TNF_WELL_KNOWN && 
                        Arrays.equals(record.getType(), NdefRecord.RTD_TEXT)) {
                        byte[] payload = record.getPayload();
                        String textEncoding = ((payload[0] & 128) == 0) ? "UTF-8" : "UTF-16";
                        int languageCodeLength = payload[0] & 0063;
                        String text = new String(payload, languageCodeLength + 1, 
                                payload.length - languageCodeLength - 1, textEncoding);
                        Log.d("NFC", "文本内容: " + text);
                    }
                    // 解析URI记录
                    else if (record.getTnf() == NdefRecord.TNF_WELL_KNOWN && 
                            Arrays.equals(record.getType(), NdefRecord.RTD_URI)) {
                        Uri uri = record.toUri();
                        Log.d("NFC", "URI: " + uri.toString());
                    }
                }
            }
        }
    }
}

高级应用场景实现

门禁卡模拟(需系统权限)

安卓开发教程步骤详解

// 获取卡片ID(UID)
Tag tag = intent.getParcelableExtra(NfcAdapter.EXTRA_TAG);
byte[] uid = tag.getId();
String hexUid = bytesToHex(uid); // 转换为十六进制字符串
// 模拟逻辑(需ROOT或系统签名)
if (hexUid.equals("A1B2C3D4")) { 
    unlockDoor(); // 执行开锁操作
}

HCE主机卡模拟开发

public class MyHostApduService extends HostApduService {
    @Override
    public byte[] processCommandApdu(byte[] commandApdu, Bundle extras) {
        if (Arrays.equals(COMMAND_SELECT, commandApdu)) {
            return SELECT_OK_SW; // 0x9000
        } else if (Arrays.equals(COMMAND_VERIFY, commandApdu)) {
            return verifyPin(commandApdu); // 自定义验证逻辑
        }
        return UNKNOWN_CMD_SW; // 0x0000
    }
    @Override
    public void onDeactivated(int reason) { }
}
// AndroidManifest.xml注册服务
<service android:name=".MyHostApduService"
         android:exported="true"
         android:permission="android.permission.BIND_NFC_SERVICE">
    <intent-filter>
        <action android:name="android.nfc.cardemulation.action.HOST_APDU_SERVICE"/>
    </intent-filter>
    <meta-data android:name="android.nfc.cardemulation.host_apdu_service"
               android:resource="@xml/apduservice"/>
</service>

避坑指南与性能优化

  1. 厂商兼容性问题

    • 华为/小米等设备可能限制后台NFC扫描
    • 解决方案:申请android.permission.USE_CREDENTIALS权限(需系统签名)
  2. NDEF写入稳定性

    // 写入前检查标签是否可写
    Ndef ndef = Ndef.get(tag);
    if (ndef != null) {
        ndef.connect();
        if (!ndef.isWritable()) {
            throw new IOException("标签不可写");
        }
        // 执行写入操作...
    }
  3. 低功耗设计

    • 检测到标签后立即释放资源
    • 避免在onNewIntent()中执行耗时操作

安全加固方案

  1. 防中继攻击

    安卓开发教程步骤详解

    // 验证NFC通信距离(示例逻辑)
    if (calculateDistance(tag) > 0.1) { // 单位:米
        abortTransaction();
    }
  2. 数据加密传输

    // 使用AES加密NDEF负载
    Cipher cipher = Cipher.getInstance("AES/GCM/NoPadding");
    cipher.init(Cipher.ENCRYPT_MODE, secretKey);
    byte[] encryptedPayload = cipher.doFinal(payload);

技术思考:随着UWB技术的普及,NFC+UWB组合定位将成为高精度近场交互新标准,开发者需提前关注Android UWB API,构建空间感知能力。

实战挑战:你在尝试NFC门禁模拟时是否遇到过厂商加密?或对HCE支付开发有具体疑问?欢迎在评论区分享你的技术瓶颈或成功案例,我们将抽取典型问题深度剖析解决方案!

首发原创文章,作者:世雄 - 原生数据库架构专家,如若转载,请注明出处:https://idctop.com/article/22657.html

(0)
上一篇 2026年2月11日 02:26
下一篇 2026年2月11日 02:28

相关推荐

  • 软件开发评估表怎么写,软件开发报价多少钱

    构建一份科学、严谨的评估体系是软件项目成功的基石,在项目启动前与开发过程中,通过标准化的量化指标对技术可行性、商业价值、团队能力及潜在风险进行全方位扫描,能够有效规避30%以上的隐性成本浪费,这不仅是一份文档,更是连接商业愿景与技术实现的桥梁,确保项目在可控的轨道上运行,技术架构与可行性评估技术选型直接决定了系……

    2026年2月23日
    6600
  • 大连开发区修手机哪里好?大连开发区修手机哪家便宜又靠谱

    在大连开发区寻找手机维修服务,首选具备官方授权资质或拥有资深硬件工程师驻店的正规维修中心,这是确保手机维修质量、数据安全以及合理价格的核心结论,面对手机故障,用户最担忧的往往不是故障本身,而是维修过程中的“偷梁换柱”、价格欺诈或数据泄露,通过选择正规渠道,不仅能获得原厂品质的配件,更能享受完善的售后质保,彻底规……

    2026年3月25日
    2800
  • 开发区到大连返程车怎么走?哪里有车去市区?

    构建针对特定区域通勤场景的车辆管理系统,核心在于解决高并发下的数据一致性与实时调度问题,最佳实践方案是采用前后端分离架构,结合Redis缓存技术处理瞬时流量,并利用消息队列实现业务解耦,确保在早晚高峰期系统的高可用性, 本教程将详细拆解如何从零开发一套高效、稳定的返程车调度系统,系统架构设计原则在开发初期,确立……

    2026年2月18日
    12800
  • c 开发文档怎么写?c语言开发文档编写规范指南

    C语言开发文档是确保软件项目可维护性、团队协作效率以及代码质量的核心基石,其价值远超代码本身,一份高质量的c 开发文档不仅是代码的说明书,更是项目逻辑的载体与团队知识的沉淀,在长期的软件工程实践中,核心结论始终清晰:缺乏文档支撑的代码不仅是技术债务,更是项目失控的开始;而优秀的文档体系必须遵循“代码即文档”的理……

    2026年4月2日
    1400
  • 开发者账号被锁怎么办,如何快速解锁开发者账号?

    成功恢复开发者账号的核心在于精准定位违规触点、构建基于证据的整改方案,并执行标准化的申诉流程,而非盲目重复提交申诉材料,开发者账号的封禁或锁定通常由算法自动触发或人工审核裁定,直接关系到应用的线上分发与业务连续性,解决这一问题不能依赖运气,必须建立一套系统化的排查与修复机制,以下将从原因诊断、申诉策略及预防体系……

    2026年2月25日
    6100
  • 小米usb调试怎么开,开发者选项在哪里设置?

    在Android开发与系统维护的流程中,建立稳定且高效的设备连接是所有工作的基石,对于小米设备用户而言,掌握小米开发者usb调试的正确开启与配置方法,不仅能够解决数据传输与日志抓取的基础需求,更是进行深层系统调试、应用性能分析及自动化测试的前提,通过科学配置调试选项,开发者可以规避连接中断、授权失败等常见问题……

    2026年2月21日
    14200
  • gis地图开发怎么做,gis地图开发教程

    GIS地图开发的核心价值在于将复杂的地理空间数据转化为可视化的决策依据,通过空间分析能力赋能业务场景,实现从“数据展示”到“智能决策”的跨越,高效的GIS系统不仅要求地图渲染的流畅性,更强调空间数据处理的精确性与业务逻辑的深度融合,GIS地图开发的技术架构与核心要素构建一个高性能的GIS应用,必须建立在成熟的技……

    2026年3月27日
    2200
  • mac pro开发java怎么样,mac开发java卡不卡

    Mac Pro 进行 Java 开发是目前业界公认的高效生产力方案,其核心优势在于 Unix 内核的原生环境支持、卓越的硬件性能稳定性以及软硬结合的生态闭环,对于专业开发者而言,Mac Pro 不仅是一台电脑,更是一个能够显著降低环境配置成本、提升编码效率的终端设备,尤其在高并发、微服务架构及容器化部署场景下表……

    2026年3月15日
    5000
  • 360浏览器开发者模式怎么打开?开发者工具调试教程

    掌握浏览器开发工具是现代互联网从业者必须具备的核心能力,它直接决定了网页开发的效率、问题排查的精准度以及最终产品的用户体验,对于使用360浏览器的技术人员而言,深入理解其内核机制与调试技巧,能够显著提升开发质量与兼容性表现,360浏览器开发者工具不仅仅是一个代码检查器,更是连接开发者意图与用户实际体验的桥梁,其……

    2026年3月19日
    5100
  • iOS游戏开发赚钱吗?iOS游戏开发教程从入门到精通

    游戏开发者iOSiOS游戏开发是融合创意与技术的过程,核心在于掌握原生工具链、理解平台特性并实施高效优化,成功的作品需平衡性能、用户体验与商业潜力,专业工具与语言选择核心工具链Xcode: 苹果官方IDE (版本14+),集成Swift编译器、Interface Builder、性能分析工具(Instrumen……

    2026年2月8日
    5930

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注