时间:2021-05-22
本文实例讲述了Python实现的文本简单可逆加密算法。分享给大家供大家参考,具体如下:
其实很简单,就是把一段文本每个字符都通过某种方式改变(比如加1)
这样就实现了文本的加密操作,解密就是其逆运算
# -*-coding:utf-8 -*-import sysreload(sys)sys.setdefaultencoding('utf8')#加密def jiami(): filename=raw_input('please input file:\n') while True: try: password=int(raw_input('input number pass word:\n')) break except: print 'please input number:\n' fileword=open(filename,'r') num=filename.rfind('.') newfilename=filename[:num]+'[加密]'.encode('gbk')+filename[num:] content=fileword.read(1) newfileword=open(newfilename,'a+') while len(content)>0: contentInt=ord(content) newContent=contentInt+password c=chr(newContent) newfileword.write(c) content=fileword.read(1) newfileword.close() fileword.close()#解密def jiemi(): filename=raw_input('please input file:\n') while True: try: password=int(raw_input('input number pass word:\n')) break except: print 'please input number:\n' fileword=open(filename,'r') num=filename.rfind('.') num2=filename.rfind('[') newfilename=filename[:num2]+'[解密]'.encode('gbk')+filename[num:] content=fileword.read(1) newfileword=open(newfilename,'a+') while len(content)>0: contentInt=ord(content) newContent=contentInt-password c=chr(newContent) newfileword.write(c) content=fileword.read(1) newfileword.close() fileword.close()while True: index=int(raw_input('---请输入命令,1为加密 2为解密 3为退出---\n'.encode('gbk'))) if index==1: jiami() elif index==2: jiemi() elif index==3: exit(0)else: pass注意:
①如果出现中文编码问题可以通过.encode,.decode编码解码
②可以通过Python的切片操作处理文件名,很方便,例如: newfilename=filename[:num]+'[加密]'.encode('gbk')+filename[num:]
③最重要的!!本加密方法只是简单的给文本字符做一个+password处理,其方法非常不合理,因为加的数如果过大会造成chr字节不够(比如你输一个1000)
所以本代码只适用于新手练习,而不能作为真正的处理算法
PS:关于加密解密感兴趣的朋友还可以参考本站在线工具:
MD5在线加密工具:
http://tools.jb51.net/password/CreateMD5Password
迅雷、快车、旋风URL加密/解密工具:
http://tools.jb51.net/password/urlrethunder
在线散列/哈希算法加密工具:
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 Socket编程技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》
希望本文所述对大家Python程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例为大家分享了python实现AES加密和解密的具体代码,供大家参考,具体内容如下参考:python实现AES加密和解密AES加密算法是一种对称加密算法,
本文实例讲述了python实现的DES加密算法和3DES加密算法。分享给大家供大家参考。具体实现方法如下:###########################
一、加密算法和hash算法的区别加密算法是一种可逆的算法,基本过程就是对原来为明文的文件或数据按某种算法进行处理,使其成为不可读的一段代码为“密文”,但在用相应
很多加密包都提供复杂的加密算法,比如MD5,这些算法有的是不可逆的。有时候我们需要可逆算法,将敏感数据加密后放在数据库或配置文件中,在需要时再再还原。这里介绍一
本文实例为大家分享了python实现字符串加密成纯数字的具体代码,供大家参考,具体内容如下说明:该加密算法仅仅是做一个简单的加密,安全性就不谈了,哈哈.算法流程