python 加密解密方法_第1页
python 加密解密方法_第2页
python 加密解密方法_第3页
python 加密解密方法_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

python加密解密方法加密与解密是信息安全领域中非常重要的概念,它们能够保护数据的机密性和完整性。Python作为一门功能强大的编程语言,提供了许多用于加密和解密的库和算法。在本文中,我们将介绍一些常见的加密和解密方法的使用,包括对称加密、非对称加密和哈希算法。

1.对称加密:

对称加密是指加密和解密使用相同的密钥。在Python中,常用的对称加密算法有AES和DES。在使用这些算法之前,我们需要先安装相应的库,如pycryptodome或cryptography。

使用AES算法加密和解密示例:

```python

fromCryptodome.CipherimportAES

fromCryptodome.Randomimportget_random_bytes

defencrypt(plaintext,key):

cipher=AES.new(key,AES.MODE_EAX)

nonce=cipher.nonce

ciphertext,tag=cipher.encrypt_and_digest(plaintext)

returnnonce+ciphertext+tag

defdecrypt(ciphertext,key):

nonce=ciphertext[:16]

tag=ciphertext[-16:]

ciphertext=ciphertext[16:-16]

cipher=AES.new(key,AES.MODE_EAX,nonce)

plaintext=cipher.decrypt_and_verify(ciphertext,tag)

returnplaintext

key=get_random_bytes(16)#生成16个随机字节作为密钥

plaintext=b"Hello,World!"

ciphertext=encrypt(plaintext,key)

decrypted=decrypt(ciphertext,key)

print("加密后的文本:",ciphertext)

print("解密后的文本:",decrypted.decode())

```

2.非对称加密:

非对称加密是指加密和解密使用不同的密钥。在Python中,常用的非对称加密算法有RSA和ECC。同样地,我们需要先安装相应的库,如cryptography。

使用RSA算法加密和解密示例:

```python

fromcryptography.hazmat.primitives.asymmetricimportrsa

fromcryptography.hazmat.primitivesimportserialization,hashes

fromcryptography.hazmat.primitives.asymmetricimportpadding

private_key=rsa.generate_private_key(public_exponent=65537,key_size=2048)

public_key=private_key.public_key()

plaintext=b"Hello,World!"

ciphertext=public_key.encrypt(plaintext,padding.OAEP(

mgf=padding.MGF1(algorithm=hashes.SHA256()),

algorithm=hashes.SHA256(),

label=None

))

decrypted=private_key.decrypt(ciphertext,padding.OAEP(

mgf=padding.MGF1(algorithm=hashes.SHA256()),

algorithm=hashes.SHA256(),

label=None

))

print("加密后的文本:",ciphertext)

print("解密后的文本:",decrypted.decode())

```

3.哈希算法:

哈希算法用于生成唯一的、固定长度的字符串,通常用于校验数据的完整性。在Python中,常用的哈希算法有MD5和SHA256,它们都包含在hashlib库中。

使用SHA256算法计算哈希值示例:

```python

importhashlib

plaintext=b"Hello,World!"

hash_object=hashlib.sha256(plaintext)

hash_value=hash_object.hexdigest()

print("SHA256哈希值:

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论