python实现可逆简单的加密算法
作者:丢你刘某 发布时间:2023-08-02 04:00:31
最近想把word密码文件的服务器密码信息归档到mysql数据库,心想着如果直接在里面写明文密码会不会不安全,如果用sha这些不可逆的算法又没法还原回来,所以自己就想着用Python写一个小代码,先把明文密码加密之后再存mysql表中。下面贴出我的Python代码:
首先是加密encript.py
# coding:utf-8
def encrpt(s):
length = len(s)
j = ""
for i in s:
if ord(i) <= 49:
i = chr(ord(i) + length)
j = j + i
elif ord(i) > 81 and ord(i) <= 126:
i = chr(ord(i) - length)
j = j + i
else:
j = j + chr(32) + i
return j
s = raw_input("请输入6到16位的密码:")
enscript_s = ""
if len(s) < 6 or len(s)>16:
print ("密码长度不符合")
if len(s) == 0:
print ("密码不能为空")
for i in s:
if ord(i) < 33 and ord(i) > 126:
print ("非法字符")
if len(s) >= 6 and len(s) <= 16:
enscript_s = encrpt(s)
print enscript_s
注意,我这里限定了加密6到16位密码,下面说说我的思路:
首先,输入6到16位密码,然后判断这些密码符不符合规定的字符,当然我认为这里我的判定还不够完善,ord函数获取每一个字符对应的十进制ASCII码。大家可以翻看ASCII码表,ASCII码十进制33到126,包含了大小写字母,数字和特殊标点等内容,我认为密码字符就是应该在这些范围内的,然后我执行了encrpt(s)函数,这里的详细说下这个函数,加密的原理就是密码中的字符这里假定ASCII码小于等于49的将该字符和字符长度相加作为新的字符密码的ASCII码,然后调用chr函数将这个新的ASCII码转换成字符格式,大家可以对照着ASCII码表设。而下面的ASCII码大于81,少于126的范围是跟上面的49相关的,因为最大是16位长度,如果49+16那么这个值就是65,而33(上面说明了输入的密码应该包含大小写字母,数字和特殊标点等内容,这个范围是从ASCII为33,也就是感叹号的开始)+6=39,也就是小于等于49的字符转换的范围是39~65;另一方面,对于ASCII码范围在81~126的,我们将其减去密码长度作为新的字符密码,那么同理81-16=65,126-6=120,也就是新的字符密码的ASCII码范围刚好在66~120之间,这个就保证和加密后的字符一定不会和上面条件为49的加密的字符的ASCII码重复;另外,这里对于49~80这里的字符段我所做的处理是直接按照原来的字符,并且在字符的左手边插入了一个空格字符,就是 j = j + chr(32) + i这句话实现的,这个空格字符作为我们没有处理的字符的标记,后面解密会用到。
下面是解密代码,decript.py
# coding:utf-8
def decrpt(s):
length1 = len(s)
length2 = len(s.replace(" ", ""))
j = ""
for i in range(length1):
if s[i] is None:
continue
if ord(s[i-1]) == 32:
j = j + s[i]
continue
elif ord(s[i]) >= 33 and ord(s[i]) <= 65:
j = j + chr(ord(s[i]) - length2)
continue
elif ord(s[i]) > 65 and ord(s[i]) <= 126:
j = j + chr(ord(s[i]) + length2)
continue
return j
s = raw_input("请输入6到16位的密码:")
descript_s = ""
if len(s) < 6 or len(s)>32:
print ("密码长度不符合")
if len(s) == 0:
print ("密码不能为空")
for i in s:
if ord(i) < 1 and ord(i) > 127:
print ("非法字符")
if len(s) >= 6 and len(s) <= 32:
descript_s = decrpt(s)
print descript_s
可以看到len(s) >= 6 and len(s) <= 32,我这里限定了字符的长度可以到32位,是因为刚才加密可能会产生空格标记字符,这样长度就会超过限定的16位密码字符了,然后我们关注decrpt这个函数,里面我获取了两个长度length1和length2,length1是密文(包括加密时插入的空格字符标记),length2是原来明文的实际长度(只要将加密时的空格字符标记去掉就可以算出来),然后下面的解密条件也是和加密的条件一一对应的,重点说下
if ord(s[i-1]) == 32:
j = j + s[i]
continue
这个,这里我们刚才加密插入的空格字符标记就有用了,刚才加密的时候如果是没有处理的明文密码是会在字符左边插入空格字符的(ASCII码32),然后在读到这个没有处理的字符时,我们检查前一个字符是否是空格字符,如果是证明这个字符没有经过加密,所以也不用解密了。这里为什么要插入这个空格字符呢,这里假定我们有一个明文字符对应的ASCII码是70(字符F),那么根据刚才加密的条件,ASCII码在49到80之间是不会加密的,还是按照原来的字符,但是我们解密的时候,条件规定了ASCIII码在33与74之间是要减去密码长度的,这样就没法得出正确的字符了,这里可能有疑问,为什么加密的时候设定条件中ASCII码49-80之间是断开的,解密的时候怎么33~74和74~126连续起来了,这里是因为加密时候ASCII码是49~80这一段的确没有处理,但是一旦加上字符的长度,解密范围就会变大,例如加一个最大长度的字符49+16=65,解密的时候就要在65的范围内,所以范围就增大了。
最后附上测试图:
加密
解密
测试后我们就可以把" Gpan8lY7;-"这个加密后的字符串粘贴到mysql表中,注意,粘贴的时候别漏了G字母左边是有个空格标记的,表示G这个字符没有被加密。
来源:https://blog.csdn.net/qq_26614295/article/details/86540634


猜你喜欢
- 使用Nodejs的开发者愈来越多,基于Nodejs的后台开发也多了起来,像短信验证码、短信群发、国际短信这些需求,完全可以采用第三方接口来实
- mssql 的正式名字是 SQL Server MS公司出的。图形操作界面好一些,性能还可以。在在mssql和oracle上不能互换.支持O
- MySQL 赋予用户权限命令的简单格式可概括为:grant 权限 on 数据库对象 to 用户 [identified by &
- 运行环境由于这是一个Python语言的软件包,因此需要你的机器上首先安装好Python语言的环境。关于这一点,请自行在网络上搜索获取方法。关
- asp之家注:学习asp网页编程的朋友一定用过ACCESS数据库,access的简单方便,大大降低了asp初学者学习asp的门槛,对于学习a
- 本文记录下自己使用Python实现一个简易的ORM模型使用到的知识1、元类2、描述器元类对于元类,我的理解其实也便较浅,大概是这个意思所有的
- 在第一部分中,我们主要讲解了一下如何用列表元素来实现柱状图效果。其中需要特别注意的就是相对定位和绝对定位的的使用。在本节中,将来讨论一下使用
- python 字符串下标与切片的实例代码,如下:# !/usr/bin/env pythonname = "ksunone&quo
- 调用opencv库,将yuv图像转为jpg图像。代码如下:# define _CRT_SECURE_NO_WARNINGS#include
- 在MongoDB中的ObjectID,可以理解为是一个不会重复的ID,这里有个链接https://www.aspxhome.com/arti
- 序列是Python中最基本的数据结构。序列中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推。Pyt
- 一般我们能过VS2005的SQL explorer来添加一个本地的MDF文件。也许你可能会出现下面这个问题:Exception Detail
- 将套接字流重定向到标准输入或输出流#!/usr/bin/env python3"""测试socket-stre
- Windows版本下的python并没有内置串口通讯的pyserial的库,所以需要自己下载。参照了网上的教程,有许多用的pip的安装方式,
- 子线程里是不能更新UI界面的,在移动端方面。Android的UI访问是没有加锁的,多个线程可以同时访问更新操作同一个UI控件。也就是说访问U
- 1)对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。2)应尽量避免在 where 子
- 事件背景最近业务研发反映了一个需求:能不能让现有基于 gin 的 webservice 框架能够自己输出 response 的信息,尤其是
- 1、打开指定的网页地址我们使用selenium进行自动化测试时,打开浏览器之后,第一步就是让浏览器访问我们指定的地址,可使用get方法实现f
- 1.auto close tagHTML自动补全标签2.beautiful UI32个主题集合,具体使用看个人喜好。3.better com
- Windows Server 2003系统是现在很流行的服务器操作系统,许多网站都用它来做。但是如何保证服务器的相对安全,这个只要进行一些简