python密码学对称和非对称密码教程

目录
  • 对称密码术
    • 缺点
  • 数据加密标准(DES)
    • 安装
    • 输出
  • 非对称加密
    • 缺点
    • 输出

在本章中,我们将详细讨论对称和非对称密码术.

对称密码术

在此类型中,加密和解密进程使用相同的密钥.它也被称为秘密密钥加密.对称加密的主要特征如下:

  • 它更简单,更快.
  • 双方以安全的方式交换密钥.

缺点

对称密码术的主要缺点是如果密钥泄漏给入侵者,则可以轻松更改消息,这被视为风险因素.

数据加密标准(DES)

最流行的对称密钥算法是数据加密标准(DES),Python包含一个包含DES算法背后的逻辑的包.

安装

在Python中安装DES包 pyDES 的命令是 :

pip install pyDES

DES算法的简单程序实现如下<

import pyDes
data = "DES Algorithm Implementation"
k = pyDes.des("DESCRYPT", pyDes.CBC, "\0\0\0\0\0\0\0\0", pad=None, padmode=pyDes.PAD_PKCS5)
d = k.encrypt(data)
print "Encrypted: %r" % d
print "Decrypted: %r" % k.decrypt(d)
assert k.decrypt(d) == data

它调用变量 padmode ,它根据DES算法实现提取所有包,并以指定的方式进行加密和解密.

输出

您可以看到以下输出作为上面和下面给出的代码的结果;

非对称加密

它也被称为公钥加密.它以对称加密的相反方式工作.这意味着它需要两个密钥:一个用于加密,另一个用于解密.公钥用于加密,私钥用于解密.

缺点

  • 由于其密钥长度,它的加密速度较低.
  • 密钥管理至关重要.

以下Python中的程序代码说明了使用RSA算法进行非对称加密的工作及其实现 :

from Crypto import Random
from Crypto.PublicKey import RSA
import base64
def generate_keys():
   # key length must be a multiple of 256 and >= 1024
   modulus_length = 256*4
   privatekey = RSA.generate(modulus_length, Random.new().read)
   publickey = privatekey.publickey()
   return privatekey, publickey
def encrypt_message(a_message , publickey):
   encrypted_msg = publickey.encrypt(a_message, 32)[0]
   encoded_encrypted_msg = base64.b64encode(encrypted_msg)
   return encoded_encrypted_msg
def decrypt_message(encoded_encrypted_msg, privatekey):
   decoded_encrypted_msg = base64.b64decode(encoded_encrypted_msg)
   decoded_decrypted_msg = privatekey.decrypt(decoded_encrypted_msg)
   return decoded_decrypted_msg
a_message = "This is the illustration of RSA algorithm of asymmetric cryptography"
privatekey , publickey = generate_keys()
encrypted_msg = encrypt_message(a_message , publickey)
decrypted_msg = decrypt_message(encrypted_msg, privatekey)
print "%s - (%d)" % (privatekey.exportKey() , len(privatekey.exportKey()))
print "%s - (%d)" % (publickey.exportKey() , len(publickey.exportKey()))
print " Original content: %s - (%d)" % (a_message, len(a_message))
print "Encrypted message: %s - (%d)" % (encrypted_msg, len(encrypted_msg))
print "Decrypted message: %s - (%d)" % (decrypted_msg, len(decrypted_msg))

输出

你可以找到执行上面给出的代码时减去输出;

以上就是python密码学对称和非对称密码教程的详细内容,更多关于python对称非对称密码学的资料请关注我们其它相关文章!

(0)

相关推荐

  • python密码学Vignere密码教程

    目录 Vignere密码 数学方程 Vignere Tableau 实现 代码 输出 Vignere密码 Vignere Cipher包含用于加密和解密的Caesar Cipher算法. Vignere Cipher与Caesar Cipher算法类似,只有一个主要区别:Caesar Cipher包含一个字符移位的算法,而Vignere Cipher包含多个字母移位的键. 数学方程 Vignere密码使用多组替换,因此它也被称为 polyalphabetic cipher . Vignere C

  • Python密码学仿射密码及攻击单字母密码教程

    目录 仿射密码 代码 输出 单字母密码 输出 仿射密码 Affine Cipher是Multiplicative Cipher和Caesar Cipher算法的组合. 仿射密码的基本实现如下图所示 : 我们将通过创建包含两个加密和解密基本函数的相应类来实现仿射密码. 代码 您可以使用以下代码实现仿射密码 :  class仿射(对象):  DIE = 128   KEY =(7,3,55)  def __init __(self): #传递  def encryptChar(self,char):

  • python密码学各种加密模块教程

    目录 加密模块 代码 输出 说明 在本章中,您将详细了解Python中各种加密模块. 加密模块 它包含所有配方和基元,并在Python中提供高级编码接口.您可以使用以下命令安装加密模块 : pip install cryptography 代码 您可以使用以下代码实现加密模块 : from cryptography.fernet import Fernet key = Fernet.generate_key() cipher_suite = Fernet(key) cipher_text = c

  • Python密码学XOR算法编码流程及乘法密码教程

    目录 XOR算法 代码 输出 说明 乘法密码 Python中乘法密码的基本调制函数如下: 在本章中,让我们了解XOR过程及其在Python中的编码以及乘法密码的教程 XOR算法 XOR算法的加密和解密转换ASCII字节格式的纯文本,并使用XOR过程将其转换为指定的字节.它为用户提供以下优势 : 快速计算 没有区别标记左侧和右侧 易于理解和分析 代码 您可以使用以下代码执行XOR过程 : def xor_crypt_string(data, key = 'awesomepassword', enc

  • python密码学简单替代密码解密及测试教程

    目录 简单替代密码 示例 输出 简单替换密码测试 输出 简单替换密码解密 代码 简单替代密码 简单替换密码是最常用的密码,包括为每个密文文本字符替换每个纯文本字符的算法.在这个过程中,与凯撒密码算法相比,字母表是混乱的. 示例 简单替换密码的密钥通常由26个字母组成.一个示例键是 : plain alphabet : abcdefghijklmnopqrstuvwxyz cipher alphabet: phqgiumeaylnofdxjkrcvstzwb 使用上述密钥的示例加密是 : plai

  • python密码学一次性密码的实现

    目录 一次性密码密码 为什么它是坚不可摧的? 加密 解密 一次性密码密码的实现 安装 代码 输出 一次性密码密码 一次性密码密码是一种Vignere密码,包括以下功能; 这是一个牢不可破的密码. 密钥与加密邮件的长度完全相同. 密钥由随机符号组成. 顾名思义,密钥仅使用一次,并且从不再用于任何其他消息加密. 由于这个原因,加密邮件很容易受到密码分析者的攻击.用于一次性密码密码的密钥称为 pad ,因为它打印在纸垫上. 为什么它是坚不可摧的? 由于以下功能,密钥是牢不可破的; 密钥只要是给定的消息

  • python密码学对称和非对称密码教程

    目录 对称密码术 缺点 数据加密标准(DES) 安装 输出 非对称加密 缺点 输出 在本章中,我们将详细讨论对称和非对称密码术. 对称密码术 在此类型中,加密和解密进程使用相同的密钥.它也被称为秘密密钥加密.对称加密的主要特征如下: 它更简单,更快. 双方以安全的方式交换密钥. 缺点 对称密码术的主要缺点是如果密钥泄漏给入侵者,则可以轻松更改消息,这被视为风险因素. 数据加密标准(DES) 最流行的对称密钥算法是数据加密标准(DES),Python包含一个包含DES算法背后的逻辑的包. 安装 在

  • python密码学文件解密实现教程

    目录 代码 输出 在本章中,我们将讨论使用Python解密加密文件.请注意,对于解密过程,我们将遵循相同的过程,但不是指定输出路径,而是关注输入路径或加密的必要文件. 代码 以下是使用Python解密加密文件的示例代码; #!/usr/bin/python # ---------------- READ ME --------------------------------------------- # This Script is Created Only For Practise And E

  • python密码学实现文件加密教程

    目录 代码 输出 说明 在Python中,可以在传输到通信通道之前加密和解密文件.为此,您必须使用插件 PyCrypto .您可以使用下面给出的命令安装此插件. pip install pycrypto 代码 用密码保护器加密文件的程序代码在下面提到 : # =================Other Configuration================ # Usages : usage = "usage: %prog [options] " # Version Version

  • python密码学RSA密码解密教程

    目录 授权 身份验证 RSA密码解密 本章是前一章的延续,我们使用RSA算法逐步实现加密,并详细讨论它. 用于解密密文的函数是as跟随 : def decrypt(ciphertext, priv_key):    cipher = PKCS1_OAEP.new(priv_key)    return cipher.decrypt(ciphertext) 对于公钥加密或非对称密钥加密,重要的是要保持两个重要的功能,即身份验证和授权. 授权 授权是确认发件人是唯一发送邮件的人的过程.以下代码解释了

  • python密码学RSA密码加密教程

    目录 加密算法模块 哈希值初始化 函数algorithm 加密程序的完整代码 在本章中,我们将重点介绍RSA密码加密的不同实现及其所涉及的功能.您可以引用或包含此python文件以实现RSA密码算法实现. 加密算法模块 加密算法包含的模块如下 from Crypto.PublicKey import RSA from Crypto.Cipher import PKCS1_OAEP from Crypto.Signature import PKCS1_v1_5 from Crypto.Hash i

  • Python密码学概述双倍强度加密教程

    目录 使用python进行密码学 加密术语 纯文本 密文 加密 解密 现代密码学的特征 双倍强度加密级别 第一层加密 第二层加密 第三层加密 混合密码术 Python语言的特性 解释 面向对象 Python语言的关键点 Python字符串 Python列表 Python元组 Python Dictionary 加密软件包 使用python进行密码学 密码学是两个用户之间通过编码消息进行通信的艺术.密码学科学的出现基本动机是为从一方转移到另一方的机密信息提供安全保障. 密码学被定义为隐藏信息以引入

  • Python密码学ROT13算法教程

    目录 ROT13算法的解释 示例 程序代码 缺点 ROT13算法的分析 到目前为止,您已经了解了反向密码和Caesar密码算法.现在,让我们讨论一下ROT13算法及其实现. ROT13算法的解释 ROT13密码是指缩写形式旋转方式13个地方.这是Caesar Cipher的一个特例,其中shift始终为13.每个字母移动13个位置以加密或解密消息. 示例 下图以图形方式解释了ROT13算法过程 : 程序代码 ROT13算法的程序实现如下 from string import maketrans

  • Python密码学Caesar Cipher凯撒密码算法教程

    目录 凯撒密码算法 输出 说明 凯撒密码算法的黑客攻击 在最后一章中,我们处理了反向密码.本章详细讨论了凯撒密码. 凯撒密码算法 凯撒密码的算法具有以下特征; Caesar Cipher Technique是一种简单易用的加密技术方法. 这是一种简单的替换密码类型. 每个纯文本字母都被一个字母替换,字母的位数固定不变./p> 下图描绘了Caesar密码算法实现的工作原理 : Caesar密码算法的程序实现如下 : def encrypt(text,s): result = ""

  • python密码学换位密码及换位解密转置加密教程

    目录 换位密码 示例 代码 解释 输出 Pyperclip 代码 输出 解释 解密转置密码的步骤. 代码 说明 输出 换位密码 Transposition Cipher是一种加密算法,其中明文中的字母顺序被重新排列以形成密文.在此过程中,不包括实际的纯文本字母. 示例 转置密码的一个简单示例是柱状转置密码其中纯文本中的每个字符都是水平写入的,具有指定的字母宽度.密码是垂直写入的,它创建了一个完全不同的密文. 考虑纯文本 hello world ,让我们应用简单的柱状转置技术,如图所示在 纯文本字

随机推荐