Added python-only implementation of PKCS7 padding
This commit is contained in:
parent
19a033db96
commit
b2b6708e8f
18
RNS/Cryptography/PKCS7.py
Normal file
18
RNS/Cryptography/PKCS7.py
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
class PKCS7:
|
||||||
|
BLOCKSIZE = 16
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def pad(data, bs=BLOCKSIZE):
|
||||||
|
l = len(data)
|
||||||
|
n = bs-l%bs
|
||||||
|
v = bytes([n])
|
||||||
|
return data+v*n
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def unpad(data, bs=BLOCKSIZE):
|
||||||
|
l = len(data)
|
||||||
|
n = data[-1]
|
||||||
|
if n > bs:
|
||||||
|
raise ValueError("Cannot unpad, invalid padding length of "+str(n)+" bytes")
|
||||||
|
else:
|
||||||
|
return data[:l-n]
|
Loading…
Reference in New Issue
Block a user