MIFARE Ultralight EV1的CRC计算方式
时间: 2024-03-19 18:07:15 浏览: 172
MIFARE Ultralight EV1标签的CRC计算采用的是CCITT标准的循环冗余校验算法,多项式为x^16 + x^12 + x^5 + 1。其计算过程如下:
1. 初始化CRC寄存器为0xFFFF;
2. 依次将需要计算CRC的每个字节与CRC寄存器进行异或;
3. 对异或后的结果进行8次循环左移,每次循环如果最高位为1,则将其与0x1021异或;
4. 重复步骤2和3,直到所有字节都被计算完毕;
5. 将CRC寄存器中的值取反,得到最终的CRC校验码。
需要注意的是,MIFARE Ultralight EV1标签中存储的数据都是按照LSB(Least Significant Bit)的方式存储,因此在计算CRC时需要按照LSB的方式进行处理。
相关问题
MIFARE Ultralight EV1使用身份验证的例子
假设有一个MIFARE Ultralight EV1标签,其中存储了一些敏感数据,需要使用身份验证来保护其安全。以下是一个使用身份验证的例子:
1. 初始化标签:将标签初始化为初始状态,例如将所有数据区域都清空,并将密码设为默认密码。
2. 设置密码:使用读写器向标签发送写入密码指令,并指定密码数据。标签收到密码数据后,将其存储在内部寄存器中,然后设置保护位,表示该数据区域已经被密码保护。
3. 读取数据:使用读写器向标签发送读取数据指令,并指定需要读取的数据区域。标签收到读取指令后,会检查该数据区域是否被密码保护。如果被保护,则要求读写器提供密码。
4. 提供密码:如果标签要求提供密码,则读写器需要向标签发送身份验证指令,并指定密码数据。标签收到密码数据后,会将其与内部寄存器中存储的密码进行比较。如果比较结果一致,则允许读写器读取数据。否则,拒绝读写器的请求。
5. 取消密码保护:如果需要取消密码保护,可以使用读写器向标签发送写入密码指令,并指定空密码数据。标签收到空密码数据后,将内部寄存器中的密码数据擦除,并取消保护位。
需要注意的是,对于MIFARE Ultralight EV1标签,每个数据区域都可以单独设置密码保护。因此,在使用身份验证时,需要指定需要保护的数据区域。
MIFARE Ultralight EV1标签上设置和取消设置密码
MIFARE Ultralight EV1标签可以设置密码保护,以保护其中存储的数据不被未经授权的访问者读取或篡改。下面是设置和取消设置密码的步骤:
设置密码:
1. 使用读写器向标签发送写入密码指令;
2. 标签响应后,使用读写器向标签发送密码数据;
3. 标签收到密码数据后,将其存储在内部寄存器中;
4. 使用读写器向标签发送写入保护位指令,并指定需要保护的数据区域;
5. 标签响应后,将保护位设置为1,表示该数据区域已经被密码保护。
取消密码:
1. 使用读写器向标签发送写入密码指令;
2. 标签响应后,使用读写器向标签发送空密码数据;
3. 标签收到空密码数据后,将内部寄存器中的密码数据擦除;
4. 使用读写器向标签发送写入保护位指令,并指定需要取消保护的数据区域;
5. 标签响应后,将保护位设置为0,表示该数据区域已经取消密码保护。
阅读全文