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

NFC安卓开发实战指南

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

安卓开发教程步骤详解

nfc徽章复制教程安卓篇
加载中
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)
ASP.NET服务器环境配置教程,从零开始搭建高效运行环境
上一篇 2026年2月11日 02:26
服务器负载均衡有什么用?作用原理与提升性能方法详解
下一篇 2026年2月11日 02:28

相关推荐

  • 人脸识别系统规定有哪些?人脸识别系统规定

    关于人脸识别系统的规定在数字化身份认证日益普及的今天,人脸识别技术已从单纯的安防监控延伸至金融支付、智慧社区及企业考勤等核心场景,随着《个人信息保护法》与《信息安全技术 个人信息安全规范》等法规的落地,合规性已成为人脸识别系统部署的首要门槛,对于服务器基础设施而言,如何在满足严苛法律合规要求的同时,提供毫秒级的……

    2026年6月4日
    5300
  • android手机应用开发怎么入门?android应用开发学习路径与实战技巧

    Android手机应用开发:高效构建高质量应用的实战路径核心结论:成功的 Android手机应用开发 不仅依赖技术栈的熟练掌握,更需系统化思维贯穿需求分析、架构设计、开发迭代与长期运维四大阶段,以用户价值为中心、以架构稳定性为基石、以自动化流程为保障,是打造高留存、高口碑应用的关键路径,需求与架构阶段:避免80……

    程序开发 2026年4月17日
    4500
  • 魔幻农庄游戏开发需要多少钱?,魔幻农庄游戏开发成本预算

    构建沉浸式虚拟田园的核心框架与实战核心结论: 成功开发一款吸引玩家的魔幻农庄游戏,关键在于打造循环自洽的核心玩法(种植/养殖、合成、探索、交易),采用稳定可扩展的技术架构(Unity+稳定后端+合理数据库),并融入适度的魔幻元素与强社交驱动,最终通过精细化运营与数据分析持续优化体验, 核心玩法设计:构建成瘾性循……

    程序开发 2026年2月16日
    18800
  • 美国GreencloudVPS怎么样?大带宽10美元方案性能实测

    美国GreencloudVPS在低价大带宽领域一直具备较高的市场关注度,其主打的10美元/月方案以提供大带宽资源为核心卖点,本次测评将针对该方案的网络吞吐、计算性能、磁盘IO以及路由节点进行深度实测,并结合2026年最新活动优惠进行详细解析,为站点部署和流量业务提供客观的参考依据, 测评方案核心配置与基准信息本……

    2026年4月30日
    5800
  • iOS开发主要做什么?岗位职责与应用开发详解

    iOS开发指的是使用苹果公司提供的工具、编程语言和框架,为运行在iPhone、iPad、Apple Watch、Apple TV等设备上的操作系统(iOS, iPadOS, watchOS, tvOS)创建应用程序(App)的过程,它涵盖了从构思设计、编写代码、测试调试到最终在App Store上架发布的完整生……

    2026年2月11日
    10700
  • 公安局推广人脸识别门禁是真的吗?人脸识别门禁系统安装流程

    公安局推广人脸识别门禁随着“智慧公安”建设的深入,人脸识别门禁系统已从单一的社区安防工具,升级为城市级治安防控体系的关键节点,对于公安机关而言,门禁系统不再仅仅是“开门”的工具,而是数据采集中枢、身份核验终端以及应急指挥的前哨,在这一背景下,承载人脸识别算法与海量生物特征数据的后端服务器,其性能、稳定性及安全性……

    2026年6月29日
    1400
  • 公有云和私有云主机层有什么区别?如何选择适合企业的云主机

    深度测评与选型指南在数字化转型的深水区,云计算架构的选择不再仅仅是成本考量,更是关乎业务连续性、数据合规性以及系统扩展性的核心战略决策,对于企业IT决策者而言,理解公有云与私有云在主机层(IaaS)的本质差异,是构建稳健技术底座的第一步,本文基于2026年的最新技术环境,对两类云主机的性能、安全性、成本结构及适……

    2026年6月29日
    1700
  • 公有云webhook是什么?如何配置公有云webhook接收事件通知

    公有云Webhook服务深度测评:稳定性、延迟与成本效益全方位解析在微服务架构与DevOps流程日益普及的今天,Webhook已不再仅仅是一个技术术语,而是连接不同系统、触发自动化工作流的核心纽带,无论是CI/CD流水线中的代码提交通知,还是监控告警系统的实时推送,Webhook的稳定性直接决定了业务响应的速度……

    2026年6月25日
    1900
  • 个人视频存储哪里好?个人视频云存储哪个平台安全

    个人视频的存储创作日益普及的今天,个人视频创作者面临着前所未有的存储挑战,4K甚至8K分辨率的视频素材、庞大的工程文件以及长期的备份需求,使得传统的NAS(网络附加存储)或简单的云盘方案往往显得力不从心,对于追求高效工作流且注重数据安全的创作者而言,选择一款高性能、高稳定性的服务器存储方案,不仅是技术需求,更是……

    2026年6月30日
    900
  • 共赢大数据如何挖掘价值?大数据分析挖掘案例

    在数字化转型的深水区,数据已成为驱动业务增长的核心资产,对于企业而言,构建高效、稳定且具备高扩展性的数据处理基础设施,不仅是技术架构的基石,更是决定数据分析深度与挖掘效率的关键变量,【共赢大数据大数据分析与挖掘】 平台凭借其在底层算力调度与上层算法引擎上的双重优势,为开发者、数据科学家及企业IT部门提供了一套从……

    2026年6月17日
    2400

发表回复

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