NFC Tag Memory Calculator

29754
Image : Saranya Loisamut / 123rf

Use our memory calculator to find which NFC chips you can use for your application. We've included here the most popular NXP chips - the NTAG210 (which includes the NTAG210micro), the NTAG212, NTAG213 and NTAG216.

NTAG210
NTAG212
NTAG213
NTAG216
Memory Used : 8 Bytes

Memory Calculations

Each NFC chip's memory is divided into two sections - user memory and system memory. So, while an NTAG210 has 80 bytes of memory, only 48 bytes of memory is actually available to be encoded. To keep things simple, consider a byte as a character such as a letter or number.

NDEF Overhead

From that 48 bytes of user memory, there's also some additional data that gets included with your data. This is so that NFC readers can understand what type of data you are storing, for example a web address or text. This equates to 8 bytes of data in the base of a web address. Which leaves you being able to store 40 characters only. The good news is that in the case of a web address, the 'http://', 'https://', 'http://www.', or 'https://www.' part of your web link is included in that 8 bytes, so you don't lose any memory space describing your connection type.

The 8 Bytes

The 8 bytes consists of two parts. The entire user data is called an NDEF message. The NDEF message can contain one or more NDEF records, such as a web link. In most encoding situations, there will be just the one NDEF record. Three bytes are used to define the NDEF message, it's length and the end of the whole message. The other five bytes define the NDEF record including it's type (such as a URI), the URI identifier (such as 'http://') and the length of the type and payload (your data).

Other details

It's also possible to store a web address with a 'blank' URI identifier instead of, say, 'http://'. This would mean that you would need to include the entire web link in your data. It would make no difference to an NFC Forum compatible reading device (all mobile phones for example), but would take up more memory space as the 'http://' would require 7 bytes. The length of the data wrapper (the 8 bytes) would not change. In other words, it's not really worth doing.

Why you shouldn't use the NTAG216

NFC tags should be used as an identifier which means that they are a link to data rather than a data store themselves. Unless you think your tags may be scanned in locations without internet access, then it's generally a bad thing to store data on the tag itself. Which means that using an NTAG216 is not a good thing.

Secondly, there have been reports of user problems writing to and, in some cases, reading from larger memory NFC tags. Unless you know your hardware or phones and know the environment in which you will use the tag, NFC.Today strongly advise testing carefully before rolling out an NTAG216 project.

Thirdly, they are expensive and difficult to get hold of. Which means that if your project is reliant on a constant source of NFC tags, you'll need to consider holding enough stock to cover any delays in tag suppliers getting chips and making up the tags.

What to do if your data is too long

This can sometimes be the case if you are encoding a longer link, perhaps a Google Analytics link or similar. Generally, an NTAG213 chip will handle most longer URL's but on larger deployments is often good to use the cheaper NTAG210u chip. In these cases, you need to use a URL shortener such as Bit.ly to reduce the length of your link or a tag management platform such as Ixkio NFC Tag Management.