-
Notifications
You must be signed in to change notification settings - Fork 228
/
readmifareultra.py
executable file
·141 lines (121 loc) · 3.1 KB
/
readmifareultra.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
#!/usr/bin/python
# readmifareultra.py - read all sectors from a Ultralight tag
#
# Keith Howell <kch@kch.net>
# built on the code by:
# Adam Laurie <adam@algroup.co.uk>
# http://rfidiot.org/
#
# This code is copyright (c) Adam Laurie, 2006, All rights reserved.
# For non-commercial use only, the following terms apply - for all other
# uses, please contact the author:
#
# This code is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This code is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
import rfidiot
import sys
import os
try:
card= rfidiot.card
except:
print "Couldn't open reader!"
os._exit(True)
help= rfidiot.help
if help:
print sys.argv[0] + ' - read mifare ultralight tags'
print 'Usage: ' + sys.argv[0]
print
os._exit(True)
card.info('readmifareultra v0.1b')
card.waitfortag('Waiting for Mifare Ultralight...')
blocks=16
print '\n ID: ' + card.uid
print 'Type: ' + card.tagtype
card.select()
# pull header block information from the tag
if card.readblock(0):
sn0=card.data[0:2]
sn1=card.data[2:4]
sn2=card.data[4:6]
bcc0=card.data[6:8]
else:
print 'read error: %s' % card.errorcode
if card.readblock(1):
sn3=card.data[0:2]
sn4=card.data[2:4]
sn5=card.data[4:6]
sn6=card.data[6:8]
else:
print 'read error: %s' % card.errorcode
if card.readblock(2):
bcc1=card.data[0:2]
internal=card.data[2:4]
lock0=card.data[4:6]
lock1=card.data[6:8]
else:
print 'read error: %s' % card.errorcode
if card.readblock(3):
otp0=card.data[0:2]
otp1=card.data[2:4]
otp2=card.data[4:6]
otp3=card.data[6:8]
else:
print 'read error: %s' % card.errorcode
# convert lock bytes to binary for later use
lbits0=card.ToBinaryString(card.ToBinary(lock0))
lbits1=card.ToBinaryString(card.ToBinary(lock1))
lbits=lbits1 + lbits0
y=0
plock=''
for x in range(15,-1,-1):
plock = lbits[y:y+1] + plock
y += 1
# show status of the OTP area on the tag
print 'OTP area is',
if int(plock[3:4]) == 1:
print 'locked and',
else:
print 'unlocked and',
if int(plock[0:1]) == 1:
print 'cannot be changed'
else:
print 'can be changed'
print 'If locked, blocks 4 through 9',
if int(plock[1:2]) == 1:
print 'cannot be unlocked'
else:
print 'can be unlocked'
print 'If locked, blocks 0a through 0f',
if int(plock[2:3]) == 1:
print 'cannot be unlocked'
else:
print 'can be unlocked'
print '\nTag Data:'
# DATA0 byte starts on page/block 4
for x in range(blocks):
print ' Block %02x:' % x,
if card.readblock(x):
print card.data[:8],
print card.ReadablePrint(card.ToBinary(card.data[:8])),
if x > 2:
if int(plock[x:x+1]) == 1:
print ' locked'
else:
print ' unlocked'
else:
print ' -'
else:
print 'read error: %s' % card.errorcode
print
if x > 0:
os._exit(False)
else:
os._exit(True)