python可逆加密算法_Python实现的文本简单可逆加密算法示例

本文实例讲述了Python实现的文本简单可逆加密算法。分享给大家供大家参考,具体如下:

其实很简单,就是把一段文本每个字符都通过某种方式改变(比如加1)

这样就实现了文本的加密操作,解密就是其逆运算

# -*-coding:utf-8 -*-

import sys

reload(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/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:http://tools.jb51.net/password/hash_md5_sha

希望本文所述对大家Python程序设计有所帮助。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值