Inspired by android-CardReader
🌟🔥Only supported Android !🔥🌟
- Android (API 19+)
- Android SDK 27
- Android Build Tools v27.0.2
$ npm install react-native-nfc-hce-reader --save
$ react-native link react-native-nfc-hce-reader
- Open up
android/app/src/main/java/[...]/MainActivity.java
- Add
import studio.bb.rnlib.RNHceReaderPackage;
to the imports at the top of the file - Add
new RNHceReaderPackage()
to the list returned by thegetPackages()
method
- Append the following lines to
android/settings.gradle
:include ':react-native-hce-reader' project(':react-native-hce-reader').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-hce-reader/android')
- Insert the following lines inside the dependencies block in
android/app/build.gradle
:compile project(':react-native-hce-reader')
- Open up
android/app/src/main/AndroidManifest.xml
- Add
<uses-permission android:name="android.permission.NFC" />
-Add
<intent-filter>
<action android:name="android.nfc.action.TECH_DISCOVERED" />
</intent-filter>
<meta-data
android:name="android.nfc.action.TECH_DISCOVERED"
android:resource="@xml/nfc_tech_filter" />
- Create
nfc_tech_filter.xml
inandroid/app/src/main/res/xml/
- Add code in
aid_list.xml
<?xml version="1.0" encoding="utf-8"?><!-- This file is used as part of the filter for incoming NFC TECH_DISCOVERED intents. -->
<resources xmlns:android="http://schemas.android.com/apk/res/android">
<!-- Android's host card emulation feature only supports the IsoDep protocol. -->
<tech-list>
<tech>android.nfc.tech.IsoDep</tech>
</tech-list>
</resources>
The aid need to customize
- Edit AID in
react-native-nfc-hce/android/src/main/java/studio/bb/rnlib/RNHceReaderModule.java
public class RNHceReaderModule extends ReactContextBaseJavaModule implements NfcAdapter.ReaderCallback, LifecycleEventListener {
private static final String TAG = "ReaderModule";
private static final String AID = "F201808175";
import HCEReader from "react-native-hce-reader";
componentDidMount = () => {
let { support, enabled } = HCEReader.supportNFC();
this.setState({ support, enabled });
if (support) {
this._listenNFCStatus();
if (!enabled) return;
this._listenDataReceived();
} else {
//你的裝置不支援NFC
}
};
_listenNFCStatus = () => {
HCEReader.listenNFCStatus(enabled => {
this.setState({ enabled, warnText });
});
};
_listenDataReceived = () => {
HCEReader.listenDataReceived(data => {
this.setState({ receivedData: data });
});
};
Get NFC supported and enabled
Listen NFC enabled status
Listen Data Received