Android NFC一般使用方法

2024-01-10 20:18
文章标签 android 使用 方法 一般 nfc

本文主要是介绍Android NFC一般使用方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Android NFC一般使用方法

  • Android NFC官网文档地址:[官网文档1](https://developer.android.google.cn/guide/topics/connectivity/nfc )、[官网地址2](https://developer.android.google.cn/reference/kotlin/android/nfc/package-summary?hl=en)
  • 一般使用方法:
    • 1、 AndroidManifest配置(可不配置):
    • 2、 NfcAdapter.getDefaultAdapter(this)获取nfc adapter实列,isEnabled可判断nfc是否可用;
    • 3、 Activity的onNewIntent会回调nfc读取的相应intent内容, NfcAdapter.ACTION_NDEF_DISCOVERED == intent.action判断来自什么类型的vfc内容。
    • 4、 val pendingIntent = PendingIntent.getActivity( this, PENDING_RESULT, intent, PendingIntent.FLAG_UPDATE_CURRENT)
    • 5、 支持的标签技术:
    • 可选择支持的标签技术:
    • 6、代码相关:

Android NFC官网文档地址:官网文档1、官网地址2

一般使用方法:

1、 AndroidManifest配置(可不配置):

  <action android:name="android.nfc.action.TAG_DISCOVERED" />
  • 1> (ACTION_NDEF_DISCOVERED:如果扫描到包含 NDEF 负载的标签,并且可识别其类型,则使用此 Intent 启动 Activity。这是优先级最高的 Intent,标签调度系统会尽可能尝试使用此 Intent 启动 Activity,在行不通时才会尝试使用其他 Intent。
  • 2> ACTION_TECH_DISCOVERED:如果没有登记要处理 ACTION_NDEF_DISCOVERED Intent 的 Activity,则标签调度系统会尝试使用此 Intent 来启动应用。此外,如果扫描到的标签包含无法映射到 MIME 类型或 URI 的 NDEF 数据,或者该标签不包含 NDEF 数据,但它使用了已知的标签技术,那么也会直接启动此 Intent(无需先启动 ACTION_NDEF_DISCOVERED)。
  • 3> ACTION_TAG_DISCOVERED:如果没有处理 ACTION_NDEF_DISCOVERED 或者 ACTION_TECH_DISCOVERED Intent 的 Activity,则使用此 Intent 启动 Activity。

2、 NfcAdapter.getDefaultAdapter(this)获取nfc adapter实列,isEnabled可判断nfc是否可用;

3、 Activity的onNewIntent会回调nfc读取的相应intent内容, NfcAdapter.ACTION_NDEF_DISCOVERED == intent.action判断来自什么类型的vfc内容。

4、 val pendingIntent = PendingIntent.getActivity( this, PENDING_RESULT, intent, PendingIntent.FLAG_UPDATE_CURRENT)

NfcAdapter.getDefaultAdapter(this).enableForegroundDispatch –使用前台调度,这种方式不用AndroidManifest注册intent-filter

5、 支持的标签技术:

说明
TagTechnology这是所有标签技术类都必须实现的接口。
NfcA提供对 NFC-A (ISO 14443-3A) 属性和 I/O 操作的访问权限。
NfcB提供对 NFC-B (ISO 14443-3B) 属性和 I/O 操作的访问权限。
NfcF提供对 NFC-F (JIS 6319-4) 属性和 I/O 操作的访问权限。
NfcV提供对 NFC-V (ISO 15693) 属性和 I/O 操作的访问权限。
IsoDep提供对 ISO-DEP (ISO 14443-4) 属性和 I/O 操作的访问权限。
Ndef提供对 NDEF 格式的 NFC 标签上的 NDEF 数据和操作的访问权限。
NdefFormatable为可设置为 NDEF 格式的标签提供格式化操作。

可选择支持的标签技术:

说明
MifareClassic提供对 MIFARE Classic 属性和 I/O 操作的访问权限(如果此 Android 设备支持 MIFARE)。
MifareUltralight提供对 MIFARE Ultralight 属性和 I/O 操作的访问权限(如果此 Android 设备支持 MIFARE)。

6、代码相关:

  • 1>当前是否支持NFC功能:
    AndroidManifest(permission):
    <uses-permission android:name="android.permission.NFC" /><uses-permission android:name="android.permission.NFC_PREFERRED_PAYMENT_INFO" />
    // Initialize the NFC adapterprivate fun initNfc() {// Gets the default NFC adapter for the systemmNfcAdapter = NfcAdapter.getDefaultAdapter(this)textBtn?.apply {text = if (mNfcAdapter == null) {"The current phone does not support NFC"} else if (!mNfcAdapter?.isEnabled!!) {"Please enable NFC in System Settings first"} else {"Mobile phones currently support NFC"}}}
  • 2>注册当前页面接收的NFC类型(IsoDepNfcANfcB…):
      override fun onResume() {super.onResume()Log.d("$TAG==", "onResume")mNfcAdapter?.let {if (!it.isEnabled) {return}val intent =Intent(this, MainActivity::class.java).addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP)val pendingIntent = PendingIntent.getActivity(this,PENDING_RESULT,intent,PendingIntent.FLAG_UPDATE_CURRENT)//It can define more than one here, but pay attention to the collocation, or there will be no callbacksval techLists = arrayOf(arrayOf(IsoDep::class.java.name
//                    ,
//                    NfcA::class.java.name,
//                    NfcB::class.java.name,
//                    NfcF::class.java.name,
//                    Ndef::class.java.name,
//                    NdefFormatable::class.java.name))try {val filters = arrayOf(IntentFilter(NfcAdapter.ACTION_TECH_DISCOVERED, "*/*"))it.enableForegroundDispatch(this, pendingIntent, filters, techLists)} catch (e: Exception) {e.printStackTrace()}}}
  • 3>接收当前页面感应到的NFC信息,通过intent接收传递的信息,action来区分:
  override fun onNewIntent(intent: Intent) {Log.d("$TAG== onNewIntent==","$TAG ${intent.action} " +"    ${intent.extras} " +" ${intent.flags} ")super.onNewIntent(intent)Toast.makeText(this, "$TAG ${intent.action} $intent", Toast.LENGTH_LONG).show()Log.d("$TAG== onNewIntent==","NfcAdapter.ACTION_NDEF_DISCOVERED => ${NfcAdapter.ACTION_NDEF_DISCOVERED}")if (NfcAdapter.ACTION_NDEF_DISCOVERED == intent.action) {intent.getParcelableArrayExtra(NfcAdapter.EXTRA_NDEF_MESSAGES)?.also { rawMessages ->val messages: List<NdefMessage> = rawMessages.map { it as NdefMessage }// Process the messages array.Log.d("==nfc message==", messages.toString())}} else if (NfcAdapter.ACTION_TECH_DISCOVERED == intent.action) {val extraTag = intent.getParcelableExtra<Tag>(NfcAdapter.EXTRA_TAG)Log.d("$TAG==", "${intent.getParcelableExtra<Tag>(NfcAdapter.EXTRA_TAG)}"+ ",ACTION_NDEF_DISCOVERED==${intent.getParcelableArrayExtra(NfcAdapter.ACTION_NDEF_DISCOVERED)}"+ ",EXTRA_NDEF_MESSAGES==${intent.getParcelableArrayExtra(NfcAdapter.EXTRA_NDEF_MESSAGES)}")extraTag?.let {Log.d("$TAG==", "id:${extraTag.id},techList:${extraTag.techList}")}}}
  • 4>发送NFC信息example:
  //nfcv processprivate fun processTagNfcV(tag: Tag?) {val nfcV = NfcA.get(tag)Log.d("$TAG==NfcA ", "${nfcV}")if (nfcV != null) {// Create a connectionnfcV.connect()val data = ByteArray(20)// Send a messageval response: ByteArray = nfcV.transceive(data)Log.d("$TAG==response ", "${response.let {NdefRecord(TNF_ABSOLUTE_URI,"https://developer.android.com/index.html".toByteArray(Charset.forName("US-ASCII")),it,it)}}")// close junctionnfcV.close()}}
  • 4.1>读写NFC信息(官网示例):
   class MifareUltralightTagTester {//write fun writeTag(tag: Tag, tagText: String) {MifareUltralight.get(tag)?.use { ultralight ->ultralight.connect()Charset.forName("US-ASCII").also { usAscii ->ultralight.writePage(4, "abcd".toByteArray(usAscii))ultralight.writePage(5, "efgh".toByteArray(usAscii))ultralight.writePage(6, "ijkl".toByteArray(usAscii))ultralight.writePage(7, "mnop".toByteArray(usAscii))}}fun readTag(tag: Tag): String? {return MifareUltralight.get(tag)?.use { mifare ->mifare.connect()val payload = mifare.readPages(4)String(payload, Charset.forName("US-ASCII"))}}}}
  • 5>当前页面停止接收:
    override fun onPause() {super.onPause()//forbidden nfcmNfcAdapter?.isEnabled.takeIf { it != true }?: mNfcAdapter?.disableForegroundDispatch(this)Log.d("$TAG", "onPause")}


end

这篇关于Android NFC一般使用方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/591949

相关文章

springboot+redis实现订单过期(超时取消)功能的方法详解

《springboot+redis实现订单过期(超时取消)功能的方法详解》在SpringBoot中使用Redis实现订单过期(超时取消)功能,有多种成熟方案,本文为大家整理了几个详细方法,文中的示例代... 目录一、Redis键过期回调方案(推荐)1. 配置Redis监听器2. 监听键过期事件3. Redi

C#中checked关键字的使用小结

《C#中checked关键字的使用小结》本文主要介绍了C#中checked关键字的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录✅ 为什么需要checked? 问题:整数溢出是“静默China编程”的(默认)checked的三种用

C#中预处理器指令的使用小结

《C#中预处理器指令的使用小结》本文主要介绍了C#中预处理器指令的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 第 1 名:#if/#else/#elif/#endif✅用途:条件编译(绝对最常用!) 典型场景: 示例

基于SpringBoot实现分布式锁的三种方法

《基于SpringBoot实现分布式锁的三种方法》这篇文章主要为大家详细介绍了基于SpringBoot实现分布式锁的三种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、基于Redis原生命令实现分布式锁1. 基础版Redis分布式锁2. 可重入锁实现二、使用Redisso

自定义注解SpringBoot防重复提交AOP方法详解

《自定义注解SpringBoot防重复提交AOP方法详解》该文章描述了一个防止重复提交的流程,通过HttpServletRequest对象获取请求信息,生成唯一标识,使用Redis分布式锁判断请求是否... 目录防重复提交流程引入依赖properties配置自定义注解切面Redis工具类controller

Mysql中RelayLog中继日志的使用

《Mysql中RelayLog中继日志的使用》MySQLRelayLog中继日志是主从复制架构中的核心组件,负责将从主库获取的Binlog事件暂存并应用到从库,本文就来详细的介绍一下RelayLog中... 目录一、什么是 Relay Log(中继日志)二、Relay Log 的工作流程三、Relay Lo

使用Redis实现会话管理的示例代码

《使用Redis实现会话管理的示例代码》文章介绍了如何使用Redis实现会话管理,包括会话的创建、读取、更新和删除操作,通过设置会话超时时间并重置,可以确保会话在用户持续活动期间不会过期,此外,展示了... 目录1. 会话管理的基本概念2. 使用Redis实现会话管理2.1 引入依赖2.2 会话管理基本操作

Springboot请求和响应相关注解及使用场景分析

《Springboot请求和响应相关注解及使用场景分析》本文介绍了SpringBoot中用于处理HTTP请求和构建HTTP响应的常用注解,包括@RequestMapping、@RequestParam... 目录1. 请求处理注解@RequestMapping@GetMapping, @PostMappin

Java调用DeepSeek API的8个高频坑与解决方法

《Java调用DeepSeekAPI的8个高频坑与解决方法》现在大模型开发特别火,DeepSeek因为中文理解好、反应快、还便宜,不少Java开发者都用它,本文整理了最常踩的8个坑,希望对... 目录引言一、坑 1:Token 过期未处理,鉴权异常引发服务中断问题本质典型错误代码解决方案:实现 Token

Nginx 访问控制的多种方法

《Nginx访问控制的多种方法》本文系统介绍了Nginx实现Web访问控制的多种方法,包括IP黑白名单、路径/方法/参数控制、HTTP基本认证、防盗链机制、客户端证书校验、限速限流、地理位置控制等基... 目录一、IP 白名单与黑名单1. 允许/拒绝指定IP2. 全局黑名单二、基于路径、方法、参数的访问控制