本文实例讲述了Python实现的凯撒密码算法。分享给大家供大家参考,具体如下:
一 介绍
凯撒密码是一种非常古老的加密方法,相传当年凯撒大地行军打仗时为了保证自己的命令不被敌军知道,就使用这种特殊的方法进行通信,以确保信息传递的安全。他的原理很简单,说到底就是字母于字母之间的替换。下面让我们看一个简单的例子:“baIDu”用凯撒密码法加密后字符串变为“edlgx”,它的原理是什么呢?把“baIDu”中的每一个字母按字母表顺序向后移3位,所得的结果就是刚才我们所看到的密文。
二 代码
# -*- Coding:utf-8 -*-import os#==================================================================## 凯撒密码(caesar)是最早的代换密码,对称密码的一种 ## 算法:将每个字母用字母表中它之后的第k个字母(称作位移值)替代 ##==================================================================#def encryption(): str_raw = raw_input("请输入明文:") k = int(raw_input("请输入位移值:")) str_change = str_raw.lower() str_List = List(str_change) str_List_encry = str_List i = 0 while i < len(str_List): if ord(str_List[i]) < 123-k: str_List_encry[i] = chr(ord(str_List[i]) + k) else: str_List_encry[i] = chr(ord(str_List[i]) + k - 26) i = i+1 print ("加密结果为:"+"".join(str_List_encry))def decryption(): str_raw = raw_input("请输入密文:") k = int(raw_input("请输入位移值:")) str_change = str_raw.lower() str_List = List(str_change) str_List_decry = str_List i = 0 while i < len(str_List): if ord(str_List[i]) >= 97+k: str_List_decry[i] = chr(ord(str_List[i]) - k) else: str_List_decry[i] = chr(ord(str_List[i]) + 26 - k) i = i+1 print ("解密结果为:"+"".join(str_List_decry))while True: print (u"1. 加密") print (u"2. 解密") choice = raw_input("请选择:") if choice == "1": encryption() elif choice == "2": decryption() else: print (u"您的输入有误!")
三 运行结果
PS:关于加密解密感兴趣的朋友还可以参考本站在线工具:
文字在线加密解密工具(包含AES、DES、RC4等):
http://tools.jb51.net/password/txt_encode
MD5在线加密工具:
http://tools.jb51.net/password/CreateMD5Password
在线散列/哈希算法加密工具:
http://tools.jb51.net/password/hash_encrypt
在线MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools.jb51.net/password/hash_md5_sha
在线sha1/sha224/sha256/sha384/sha512加密工具:
http://tools.jb51.net/password/sha_encode
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python加密解密算法与技巧总结》、《Python编码 *** 作技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串 *** 作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录 *** 作技巧汇总》
希望本文所述对大家Python程序设计有所帮助。
您可能感兴趣的文章:Python实现的维尼吉亚密码算法示例python 换位密码算法的实例详解python使用rsa加密算法模块模拟新浪微博登录python实现RSA加密(解密)算法Python基于DES算法加密解密实例python实现的DES加密算法和3DES加密算法实例Python实现的文本简单可逆加密算法示例Python md5与sha1加密算法用法分析Python实现的rsa加密算法详解Python实现的HMacMD5加密算法示例Python使用MD5加密算法对字符串进行加密 *** 作示例Python基于pycrypto实现的AES加密和解密算法示例 总结以上是内存溢出为你收集整理的Python实现的凯撒密码算法示例全部内容,希望文章能够帮你解决Python实现的凯撒密码算法示例所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)