NFC - NdefRecord构造错误

时间:2015-03-03 11:11:43

标签: android nfc ndef

我尝试使用NdefRecord / NdefMessage撰写NFC标签。

byte prefix = 0x04; // https://
byte[] uriBytes = "whatever.anywhere.com".getBytes();
byte[] recordBytes = new byte[uriBytes.length + 1];
recordBytes[0] = prefix;
System.arraycopy(uriBytes, 0, recordBytes, 1, uriBytes.length);

NdefRecord record = new NdefRecord(
    NdefRecord.TNF_WELL_KNOWN,
    NdefRecord.RTD_URI,
    null,
    recordBytes);

这就是我创建NdefRecord的方法,由于兼容性问题我无法使用createUri()(自API14起我可以使用createUri()并且我需要API11兼容...)

它适用于Lollipop(在5.0.2上测试)和KitKat上的事件(在4.4.3上测试)。

我的一位用户在创建NdefRecord时遇到了崩溃:

NdefRecord record = new NdefRecord(
    NdefRecord.TNF_WELL_KNOWN,
    NdefRecord.RTD_URI,
    null,
    recordBytes);

他在ICS 4.0.2上,我无法真正调试此问题,因为我没有这样的手机可用,我无法使用AVD来模拟这个问题。

有人看到我做错了吗?或者还有其他/更好的方法吗?

修改 以下是与此错误相关联的堆栈跟踪

java.lang.RuntimeException: Unable to start activity ComponentInfo{com.your.application/com.your.application.NFCWriter}: java.lang.IllegalArgumentException: Illegal null argument
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1967)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1992)
        at android.app.ActivityThread.access$600(ActivityThread.java:127)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1158)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:137)
        at android.app.ActivityThread.main(ActivityThread.java:4448)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:511)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:823)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:590)
        at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.IllegalArgumentException: Illegal null argument
        at android.nfc.NdefRecord.<init>(NdefRecord.java:242)
        at android.nfc.NdefRecord.<init>(NdefRecord.java:233)
        at com.your.application.NFCWriter.onCreate(Unknown Source)
        at android.app.Activity.performCreate(Activity.java:4465)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1931)
        ... 11 more

1 个答案:

答案 0 :(得分:2)

我想我找到了答案。

即使API文档说null使用typeidpayload也没问题,但事实并非如此。 - &GT; API Reference

自Android 4.1.1以来,情况确实如此,对于那些感兴趣的人来说是源代码:

NdefRecord Constructor (4.1.1_r1) null替换为EMPTY_BYTE_ARRAY(尽管仍为new byte[0]

在使用null作为参数的NdefRecord Constructor (4.0.4_r2.1)中抛出IllegalArgumentException

因此,如果您想要向后兼容并构建NdefRecord,请勿提供null作为论据,请使用new byte[0] INSTEAD

byte prefix = 0x04; // https://
byte[] uriBytes = "whatever.anywhere.com".getBytes();
byte[] recordBytes = new byte[uriBytes.length + 1];
recordBytes[0] = prefix;
System.arraycopy(uriBytes, 0, recordBytes, 1, uriBytes.length);

NdefRecord record = new NdefRecord(
    NdefRecord.TNF_WELL_KNOWN,
    NdefRecord.RTD_URI,
    new byte[0],
    recordBytes);

就是这样。

感谢@ michael-roland获取UncaughtExceptionHandler的潜在客户,它有所帮助。