npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@monaca/monaca-plugin-nfc-reader

v1.0.1

Published

Monaca NFC Reader Plugin

Downloads

12

Readme

@monaca/monaca-plugin-nfc-reader

Monaca NFCリーダープラグイン

for English

説明

このプラグインではNFCタグの情報を読み取ることができます。

  • タグIDの読み取り NFCタグに割り当てられた固有のIDを読み取ることができます。
  • ブロックデータ読み取り(FeliCa[^1]のみ) FeliCaのブロックデータを読み取ることができます。

対象プラットフォーム

ビルド環境

  • Cordova 11.0.0 以降
  • cordova iOSプラットフォーム 6.2.0 以降
  • Swift 4 以降 (5 以降推奨)

androidは未対応

動作環境

  • iOS 13 以降
  • iPhone 7 以降

対応するNFCタグの種類

  • NFC Type A (Mifare[^2])
  • NFC Type F (FeliCa)

API の解説

readId

monaca.NfcReader.readId(successCallback, failCallback, args)

NFCタグのIDを読み込みます。 Type A: UID / Type F: IDm NFC Type Bには対応していません。

successCallback

successCallback(result)

result: 以下のデータが返されます。

{
  "type": "typeA",  // NFCタグの種類 (typeA / typeF)
  "id": "xxxxxxxxxx",  // NFCタグのID
  "cancelled": false // 読み取りがキャンセルされたかどうか
}
  • idは16進数文字列です。
  • idの桁数はNFCタグの種類によって変わります。
  • FeliCaではアプリケーションに指定されたシステムコード(後述)に対応するIDが返ります。
    • プラグインのデフォルトではシステムコード=0003のカードに設定されています。
    • システムコードを変更したい場合は、後述のシステムコードの指定を参照してください。

failCallback

failCallback(error)

error: エラーメッセージ(文字列)

エラーの内容はエラーメッセージ参照

args

{
  "message" : "NFCタグをスマートフォンに近づけてください"
}

| parameter | type | optional | default value | description | |---|---|---|---|---| | message | string | YES | "Bring the NFC tag closer to your Smartphone" | 検出中のUIに表示されるメッセージ文字列 |

  monaca.NfcReader.readId((result) => {
    if (result.cancelled) {
      // cancelled
    } else {
      // success
      const detected_id = result.id;
      const detected_type = result.type;
    }
  }, (error) => {
    // error
    const error_message = error;
  }, {
      "message" : "NFCタグをスマートフォンに近づけてください"
  });

readBlockData

monaca.NfcReader.readBlockData(successCallback, failCallback, args)

FeliCaのブロックデータを読み込みます。

successCallback

successCallback(result)

result: 以下のデータが返されます。

{
  "type": "typeF",  // NFCタグの種類 (typeF)
  "id": "xxxxxxxxxx",  // NFCタグのID
  "cancelled": false, // 読み取りがキャンセルされたかどうか
  "data": [n][16]   // blockData[n][16]  1ブロック=16byte x n(n: 0 .. count-1)
}
  • 指定したサービスコード・システムコード(後述)に対応するIDおよびブロックデータが返ります。

failCallback

failCallback(error)

error: エラーメッセージ(文字列)

エラーの内容はエラーメッセージ参照

args

{
  "service_code" : [ 0x09, 0x0f ],  // サービスコード
  "start" : 0,  // 読み取り開始インデックス
  "count" : 12, // 読み取りブロック数 (count <= 12)
  "message" : "NFCタグをスマートフォンに近づけてください"
}

| parameter | type | optional | default value | description | |---|---|---|---|---| | service_code | array(byte[2]) | NO | - | サービスコード | | start | int | NO | - | 読み取り開始インデックス (0 <= start < 20) | | count | int | NO | - | 読み取りブロック数 (count <= 12) | | message | string | YES | "Bring the NFC tag closer to your Smartphone" | 検出中のUIに表示されるメッセージ文字列 |

  • 指定したサービスコード(後述)に対応するデータが返ります。
    • サービスコードは1つのみ対応しています。複数のサービスコードを指定することはできません。
    • システムコードを指定したい場合は、後述のシステムコードの指定を参照してください。
  • FeliCaのブロックデータは最大20個です。
  • 一度に読み取れるブロックデータ数は12個までです。
    • count <= 12
    • start + count <= 20

  monaca.NfcReader.readBlockData((result) => {
    if (result.cancelled) {
      // cancelled
    } else {
      // success
      const detected_id = result.id;
      const detected_type = result.type;
      const blockData = result.data;

      // convert block data to traffic IC history
      const history = blockData.map(block => {
        return monaca.NfcReader.convertToHistory(block);
      });
    }
  }, (error) => {
    // error
    const error_message = error;
  }, {
    "service_code" : [ 0x09, 0x0f ],
    "start" : 0,  // start index
    "count" : 12, // count
    "message" : "NFCタグをスマートフォンに近づけてください"
  });

エラーメッセージ

| message | description | |---|---| | "Invalid Arguments" | 引数指定のエラー | | "NFC Not Available" | NFCが使用できない | | "NFC Connection Error" | NFC接続時のエラー| | "Feature Not Supported" | 対応していない機能の呼び出し(typeA + readBlockData etc.) | | "Unsupported NFC Tag is detected" | 未対応のNFCタグの検出 | | "Request Service Error" | サービスコードの指定エラー | | "Read Block Data Error" | ブロックデータ読み込みエラー | | "Read Block Data Error: Invalid Status Code" | ブロックデータ読み込み ステータスコード異常 | | "NFC Session timed out" | NFC読み取りタイムアウト | | "Unhandled NFC error" | その他のNFCエラー |

iOS 特有の動作

プラグインの使用にはアプリケーションのconfig.xmlに以下の設定を追加する必要があります。

  • Swiftバージョンの指定(必須)
  • システムコードの指定(任意)

Swiftバージョンの指定

このプラグインはSwiftで書かれています。 アプリケーションの config.xml にてSwiftのバージョンを指定する必要があります。 config.xmlに以下の記述を追加してください。

<platform name="ios">
  <preference name="SwiftVersion" value="5"/>
</platform>

システムコードの指定

プラグインにデフォルトで指定されているFeliCaシステムコードは0003です。 このコードを変更もしくは追加したい場合は以下のいずれかの方法で設定してください。

Monaca クラウドIDEで設定

  1. MonacaクラウドIDEから 設定 → Cordova プラグインの管理を選択します。
  2. NFCリーダープラグインの設定ボタンをクリックします。
  3. インストールパラメータ の欄に以下のように値を設定してください。 0003fe00に変更する場合: SYSTEM_CODES=fe00

variableオプションで設定

Cordova CLIからプラグインを使用する場合は、プラグイン追加時にvariableオプションで値を指定してください。

# '0003'を'fe00'に変更する場合
cordova plugin add @monaca/monaca-plugin-nfc-reader --variable SYSTEM_CODES=fe00

補足

FeliCaの読み込みについて

システムコード

FeliCaにおいて事業者や使用目的ごとに割り当てられたコードをシステムコードと呼びます。 FeliCaカードを採用しているサービスごとに異なるシステムコードが割り当てられています。

また、FeliCaカードでは1枚のカードの中に複数のシステム領域を持つことができます。 この場合、1枚のカード内には複数のシステムコードが存在します。ID(IDm)はシステム領域ごとに割り当てられています。 対象のIDを取得するにはシステムコードの指定が必要となります。 このプラグインの現在のバージョンではシステムコードは1つのみ対応しています。

iOSアプリケーションでは対応するシステムコードを*.plistファイルに指定しておく必要があります。 この設定方法については前述のシステムコードの指定を参照してください。

サービスコード

FeliCaのシステム領域の中にはサービスと呼ばれる領域が存在します。複数のサービス領域が存在し、その中にブロックデータが格納されています。 どのサービス領域のブロックデータを取得するか特定するためにサービスコードが用いられます。

ブロックデータの取得にはシステムコードとサービスコードの両方が必要です。

プラグインの対応状況

  • このプラグインの現在のバージョンではシステムコードは1つのみ指定可能です。
  • readId(), readBlockData()ともに、システムコードで指定された1つのシステム領域からの読み込みに対応しています。
  • readBlockData()では1つのサービスコードで指定されたサービス領域からのブロックデータの読み込みに対応しています。

応用

ブロックデータの活用方法の1つとして、交通系ICカードの利用履歴の読み取りが挙げられます。 このプラグインでは参考としてブロックデータから利用履歴への変換メソッドを提供しています。

/**
 * Convert blockData to traffic history
 * @param {int[16]} blockData
 * @return {object} traffic history object
 */
monaca.NfcReader.convertToHistory(blockData)

traffic history object:

{
  "year": 2022, // 年
  "month": 11,  // 月
  "day": 1,   // 日
  "boarding_station_code": [xxx, xxx], // 乗車駅(2byte)
  "exit_station_code": [xxx, xxx],  // 降車駅(2byte)
  "balance": 1000   // 残高
}

使用例

    monaca.NfcReader.readBlockData((result) => {
        if (result.cancelled) {

        } else {
            const history = result.data.map(block => {
                return monaca.NfcReader.convertToHistory(block);
            });
        }
    }, (error) => {

    }, {
      // (略)
    });

注意

交通系ICのデータ形式は公表されていません。 convertToHistoryの処理は独自の調査結果により実装されています。 このメソッドに関してはあくまでも参考程度として、以下の方針のもと提供させて頂きます。

  • 全ての交通系ICカードに対応しているものではありません。
  • 一般的な交通系ICカードの列車の乗降履歴のみに対応しています。
  • それ以外の乗り物や買い物の履歴などはデータ形式が異なるケースがあり対応していません。
  • このメソッドに関しての一切の動作保証は致しかねます。
  • 今後のバージョンでの提供や互換性に関しても未定となります。

注意事項

FeliCaおよび関連の技術方式について

  • FeliCaはソニー株式会社の登録商標です。
  • このドキュメント内に記載されたFeliCaおよびそれに関する技術用語はソニー株式会社様により公開されている技術資料を基に構成されています。
  • システムコード、サービスコード等の数値については対応するカード・サービスの事業者様より提供を受けた上でご利用ください。

License

see LICENSE

[^1]: FeliCa はソニー株式会社の登録商標です。 FeliCa はソニー株式会社が開発した非接触ICカードの技術方式です。 [^2]: Mifare はNXPセミコンダクターズN.V.の登録商標です。