Как проект я экспериментировал с кодированием, декодированием и хэшированием; Я получаю эту общую ошибку каждый раз, когда я тестирую эту программу.
Ошибка UnicodeDecodeError: 'utf-8' codec can't decode byte 0xf2 in position 0: invalid continuation byte
в строке var_hash = str(newhash.digest(), encoding = 'utf-8')
В программе я использую файл, который импортирует пользователей ' детали.
Ожидаемый формат хешированных паролей должен быть следующим: 4ac2e277734c1e9e21616d7cb9bfa777b8a765af4f48e19ebac12c4173149618
Я пробовал другие методы кодирования / декодирования, такие как latin-1 и utf-16, которые дают неверные результаты
Код:
import hashlib
salt = ['1AsnOZtM41','M6IQQD4fRb','XgJbmMhlg9']
login = open('login.csv','r+')
## Login format = [USERNAME,PASSWORD,SALTNUMBER]
def membership(): ## Membership Function
linevarc = ''
newusr = input('Enter your username: ')
newpass = input('Enter your password: ')
newhash = hashlib.sha256() ## Sets hash algorithm to sha256
newrand = random.randint(0,2) ## Picks random salt
for line in login:
newlog = line.split(',')
if newusr.upper() == newlog[0]:
print('This username is already taken, Please re-enter all details')
login.seek(0)
membership()
login.seek(0)
for line in login:
save = line.split(',')
if newusr.upper() != newlog[0]:
linevarc = linevarc + save[0] + ',' + save[1] + ',' + save[2] + '\n'
print(str(linevarc))
#login.write(str(newdetails))
login.seek(0)
for line in login:
if newusr.upper() != newlog[0]:
passalter = str(newpass + salt[int(newrand)])
newhash.update(passalter.encode('utf-8'))
var_hash = str(newhash.digest().decode(), errors = 'ignore') ## errors occur here
linevarc = linevarc + newusr.upper() + ',' + var_hash + ',' + str(newrand)
print(str(linevarc))