日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
十行Python代碼,使用OTP實(shí)現(xiàn)對文件的加密解密

不知道你是否相信,只需 10 行代碼,就可以使用 Python 100% 安全地加密文件。這背后的原理就是 OTP。

10年積累的網(wǎng)站建設(shè)、成都做網(wǎng)站經(jīng)驗(yàn),可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有奉節(jié)免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。

原理

OTP 就是 One-time password,翻譯過來就是一次性密碼。它的原理非常簡單,加密的過程就是明文和密鑰(key)進(jìn)行異或,得到密文,而解密的過程就是密文和密鑰(key)異或,得到明文。舉例如下:

加密:

解密:

理論上,基于以下假設(shè),這個(gè)加密被認(rèn)為是牢不可破的:

  • 密鑰是真正隨機(jī)的
  • 密鑰長度與信息長度相同
  • 密鑰永遠(yuǎn)不會(huì)全部或部分重復(fù)使用
  • 密鑰 key 很安全,不會(huì)公開

應(yīng)用:加密文件

如果自己有一個(gè)私密的文件,那么完全可以使用 OTP 來加密,密鑰保存在自己手里,很安全。話不多說,直接上代碼:

加密文件:

import os
def encryption(file):
toBeEncryptedFile = open(file, 'rb').read()
size = len(toBeEncryptedFile)
otpKey = os.urandom(size)
with open(file.split('.')[0] + '.key', 'wb') as key:
key.write(otpKey)
encryptedFile = bytes (a ^ b for (a, b) in zip(toBeEncryptedFile, otpKey))
with open(file, 'wb') as encrypted:
encrypted.write(encryptedFile)

這段代碼一共 10 行,密鑰 optKey 隨機(jī)生成并保存在文件中,然后用這個(gè)密鑰加密文件,當(dāng)需要加密文件時(shí),這樣調(diào)用 encryption 函數(shù):

if __name__ == "__main__":
encryption("/Users/aaron/Downloads/1/銀行卡.JPG")

成功執(zhí)行代碼后,我們無法再預(yù)覽或打開我們的圖像,因?yàn)樗F(xiàn)在是加密的。此外,我們的文件夾中有一個(gè)新的密鑰文件“銀行卡.key”。

現(xiàn)在,我們來解密它。

解密文件只需要 6 行代碼:

def decryption(file, otpKey):
encryptedFile = open(file, 'rb').read()
otpKey = open(otpKey, 'rb').read()
decryptedFile = bytes (a ^ b for (a, b) in zip(encryptedFile, otpKey))
with open(file, 'wb') as decrypted:
decrypted.write(decryptedFile)

這樣調(diào)用:

if __name__ == "__main__":
# encryption("/Users/aaron/Downloads/1/銀行卡.JPG")
decryption("/Users/aaron/Downloads/1/銀行卡.JPG", "/Users/aaron/Downloads/1/銀行卡.key")

這樣就完成了解密:

完整代碼

import os


def encryption(file):
toBeEncryptedFile = open(file, "rb").read()
size = len(toBeEncryptedFile)
otpKey = os.urandom(size)
with open(file.split(".")[0] + ".key", "wb") as key:
key.write(otpKey)
encryptedFile = bytes(a ^ b for (a, b) in zip(toBeEncryptedFile, otpKey))
with open(file, "wb") as encrypted:
encrypted.write(encryptedFile)


def decryption(file, otpKey):
encryptedFile = open(file, "rb").read()
otpKey = open(otpKey, "rb").read()
decryptedFile = bytes(a ^ b for (a, b) in zip(encryptedFile, otpKey))
with open(file, "wb") as decrypted:
decrypted.write(decryptedFile)


if __name__ == "__main__":
# encryption("/Users/aaron/Downloads/1/銀行卡.JPG")
decryption("/Users/aaron/Downloads/1/銀行卡.JPG", "/Users/aaron/Download

本文題目:十行Python代碼,使用OTP實(shí)現(xiàn)對文件的加密解密
URL地址:http://www.5511xx.com/article/cdhopei.html