利用以下python代码编写栏栅加密和解密
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了利用以下python代码编写栏栅加密和解密相关的知识,希望对你有一定的参考价值。
#! /usr/bin/env python
#coding=utf-8
def Encrypt(n,col,M):
row=len(M)/n
if len(M)%n>0:
row+=1
arr=[[""for x in range(0,n)] for y in range(0,row)]
x=0
for i in range(0,row):
for j in range(0,n):
if x<len(M):
arr[i][j]=M[x]
print M[x],
x+=1
print "\r\n"
for i in range(0,row):
for j in (0,n):
m=int(col[j])-1
print arr[i][m],
print "\r\n"
print u"1.进行栅栏加密\r\n 2.进行栅栏解密\r\n请选择:".encode("gb2312"),
sel=raw_input()
if int(sel)==1:
print u"请输入分组数目".encode("gb2312"),
n=int(raw_input())
print u"请输入列排编号".encode("gb2312"),
col=raw_input()
print u"请输明文".encode("gb2312"),
M=raw_input()
while len(M)<n*3:
print u"明文必须是分组数目的3倍".encode("gb2312")
M=raw_input()
Encrypt(n,col,M)
else :
print u"请输入分组数目".encode("gb2312"),
n=int(raw_input())
print u"请输入列排编号".encode("gb2312"),
col=raw_input()
print u"请输密文".encode("gb2312"),
C=raw_input()
while len(C)<n*3:
print u"密文必须是分组数目的3倍".encode("gb2312")
C=raw_input()
Decrypt(n,col,C)
a. 加密
1.进行栅栏加密
2.进行栅栏解密
请选择: 1
请输入分组数目 2
请输入列排编号 21
请输明文 abcdefgh
b a
d c
f e
h g
b. 解密
1.进行栅栏加密
2.进行栅栏解密
请选择: 2
请输入分组数目 2
请输入列排编号 21
请输密文 b a d c f e h g
abcdefgh
修改后的代码:
def Encrypt(n,col,M):
row=len(M)/n
if len(M)%n>0:
row+=1
arr=[[""for x in range(0,n)] for y in range(0,row)]
x=0
for i in range(0,row):
for j in range(0,n):
if x<len(M):
arr[i][j]=M[x]
#print M[x],
x+=1
#print "\r\n"
for i in range(0,row):
for j in range(0,n):
m=int(col[j])-1
print arr[i][m],
print "\r\n"
def Decrypt(n, col, C):
C="".join(C.split())
row=len(C)/n
if len(C)%n>0:
row+=1
arr=[[""for x in range(0,n)] for y in range(0,row)]
x=0
for i in range(0,row):
for j in range(0,n):
if x<len(C):
arr[i][j]=C[x]
#print C[x],
x+=1
#print "\r\n"
M=""
for i in range(0,row):
for j in range(0,n):
m=int(col[j])-1
#print arr[i][m],
M+=arr[i][m]
#print "\r\n"
print M
print u"1.进行栅栏加密\r\n2.进行栅栏解密\r\n请选择:".encode("gb2312"),
sel=raw_input()
if int(sel)==1:
print u"请输入分组数目".encode("gb2312"),
n=int(raw_input())
print u"请输入列排编号".encode("gb2312"),
col=raw_input()
print u"请输明文".encode("gb2312"),
M=raw_input()
while len(M)<n*3:
print u"明文必须是分组数目的3倍".encode("gb2312")
M=raw_input()
Encrypt(n,col,M)
else :
print u"请输入分组数目".encode("gb2312"),
n=int(raw_input())
print u"请输入列排编号".encode("gb2312"),
col=raw_input()
print u"请输密文".encode("gb2312"),
C=raw_input()
while len(C)<n*3:
print u"密文必须是分组数目的3倍".encode("gb2312")
C=raw_input()
Decrypt(n,col,C)追问
分组数目是奇数不行的 而且输出的是奇数行的也不能输出
追答怎么会?
测试参数 分组3 列321 数据abcdefghi 9/3=3行
分组: 3 是奇数,
行数: 3 是奇数
运行结果:
1.进行栅栏加密
2.进行栅栏解密
请选择: 1
请输入分组数目 3
请输入列排编号 321
请输明文 abcdefghi
c b a
f e d
i h g
Traceback (most recent call last):
File "D:\网络安全\python\dad.py", line 65, in
Encrypt(n,col,M)
File "D:\网络安全\python\dad.py", line 20, in Encrypt
m=int(col[j])-1
ValueError: invalid literal for int() with base 10: ''
经常出现这个错误
列排编号输错了? 列编号是范围在[1,分组数]的数字的一个排列 对应列的重排.分组数是三组时可取的值是123,321,132等。
本回答被提问者采纳 参考技术B #! /usr/bin/env python#coding=utf-8
def Encrypt(n,col,M):
row=len(M)/n
if len(M)%n>0:
row+=1
arr=[[""for x in range(0,n)] for y in range(0,row)]
x=0
for i in range(0,row):
for j in range(0,n):
if x<len(M):
arr[i][j]=M[x]
print M[x],
x+=1
print "\r\n"
for i in range(0,row):
for j in (0,n):
m=int(col[j])-1
print arr[i][m],
print "\r\n"
print u"1.进行栅栏加密\r\n 2.进行栅栏解密\r\n请选择:".encode("gb2312"), 参考技术C 答案不对的,我试过了,因为你排序改变很乱时就不行的,修改后的答案,无论排序怎样都可以的。。
#! /usr/bin/env python
#coding=utf-8
def Encrypt(n,col,M):
row =len(M)/n
if len(M) % n > 0:
row +=1
arr=[["" for x in range(0,n)] for y in range(0,row)]
x=0
print u"原明文:".encode("gb2312"),
print "\r"
for i in range(0,row):
for j in range(0,n):
if x < len(M):
arr[i][j] = M[x]
print M[x],
x += 1
print "\r"
print "\r"
print u"加密文:".encode("gb2312"),
print "\r"
for i in range(0,row):
for j in range(0,n):
m=int(col[j])-1
print arr[i][m],
print "\r"
def Decrypt(n,col,C):
row=len(C)/n
if len(C)%n>0:
row+=1
arr=[[""for x in range(0,n)] for y in range(0,row)]
x=0
print u"加密文:".encode("gb2312"),
print "\r"
for i in range(0,row):
for j in range(0,n):
if x<len(C):
a=int(col[j])-1
arr[i][a]=C[x]
print C[x],
x+=1
print "\r"
print "\r"
print u"原明文:".encode("gb2312"),
print "\r"
for i in range(0,row):
for j in range(0,n):
print arr[i][j],
print "\r"
print u"1、进行栅栏加密\r\n 2、进行栅栏解密\r\n请选择".encode("gb2312"),
sel = raw_input()
if int(sel)==1:
print u"请输入分组数目".encode("gb2312"),
n=int(raw_input())
print u"请输入列排序编号".encode("gb2312"),
col=raw_input()
print u"请输入明文".encode("gb2312"),
M=raw_input()
while len(M)<n*3:
print u"明文必须是分组数目的3倍,请重新输入明文:".encode("gb2312"),
M=raw_input()
Encrypt(n,col,M)
else :
print u"请输入分组数目".encode("gb2312"),
n=int(raw_input())
print u"请输入列排序编号".encode("gb2312"),
col=raw_input()
print u"请输入密文".encode("gb2312"),
C=raw_input()
while len(C)<n*3:
print u"密文必须是分组数目的3倍,请重新输入密文:".encode("gb2312"),
C=raw_input()
Decrypt(n,col,C)追问
这位大哥 能解释下解密么?还是没搞懂~
追答在解密的时候,如果你解密的步骤和加密的一样,岂不是继续加密了吗??所以解密的时候必须逆着加密的步骤解密, a=int(col[j])-1 先把列排序编号赋给a, arr[i][a]=C[x] 把密文分别赋给数组 arr[i][a],这样数组对应的值(即密文)就是加密时明文对应的数组。 for i in range(0,row):
for j in range(0,n): print arr[i][j], 然后(1.2.3……)顺序输出来。
实用脚本!利用 Python 对 PDF 进行加密解密操作,代码拿走就用!
大家好,我是启航。更多干货知识可以关注我的同名公众号(程序员启航)
本文将分享如何利用 Python 对 PDF 进行加密和解密操作,主要利用到之前多次介绍过的PyPDF2
模块。
PDF 加密
我们先拿自己随意的一个PDF 文件试一下:
from PyPDF2 import PdfFileWriter, PdfFileReader
path = r'C:\\xxx' # 这里填写目标 PDF 所在的路径
pdf_reader = PdfFileReader(path + r'\\test.pdf')
pdf_writer = PdfFileWriter()
for page in range(pdf_reader.getNumPages()):
pdf_writer.addPage(pdf_reader.getPage(page))
pdf_writer.encrypt('a123') # 设置密码为 a123
with open(path + r'\\test.pdf', 'wb') as out:
pdf_writer.write(out)
上面代码的运行逻辑是:实例化一个 PDF 写入器和读取器,读取器读取完目标 PDF 文件后,一页一页交给写入器,然后对写入器设置密码并输出。看一下运行结果:
可见这个 PDF 文件成功设置上了密码,如果有多个PDF需要加密,可以写一个简单的循环利用上述脚本批量处理,此处不再展开说明。
PDF 已知密码解密
如果知道密码的情况下,想直接取消 PDF 的加密,可以用 .decrypt
,解密的过程需要读取器和写入器共同配合。但区别于加密 .encrypt
,.decrypt 是针对读取器进行解密的,而不是写入器
from PyPDF2 import PdfFileWriter, PdfFileReader
path = r'C:\\xxx'
pdf_reader = PdfFileReader(path + r'\\test.pdf')
pdf_reader.decrypt('a123') #
pdf_writer = PdfFileWriter()
for page in range(pdf_reader.getNumPages()):
pdf_writer.addPage(pdf_reader.getPage(page))
with open(path + r'\\test.pdf', 'wb') as out:
pdf_writer.write(out)
上面代码的运行逻辑是:首先用读取器读取加密文件,然后直接在读取器上使用 .decrypt
进行解密,逐页传到刚实例化的写入器后统一输出,就完成了解密
PDF 暴力解密
暴力破解,其实就是通过手上已经有的密码库,或者完全通过数字、字母、符号的穷举,将可能的密码都放进去,逐个尝试直到成功。
「目前暴力破解只适用于已知密码位数少,由简单的数字、字母构成」
假设今天要破解的密码就是 a123
,已知密码 4 位且由数字和小写字母组成。破解又分为两种情况:
1. 手上有密码本
第一种情况,知道大概密码,可以整理成一个 password.txt
,保证可能的密码一定在其中:
首先读取 .txt
文件获取其中所有密码(示例文件只有 9 个密码):
passw = []
path = r'C:\\Scientific Research\\Python'
file = open(path + r'\\password.txt')
for line in file.readlines():
passw.append(line.strip())
print(passw)
file.close()
然后就可以用密码本的密码做暴力破解:
from PyPDF2 import PdfFileReader
passw = []
path = r'C:\\xxx'
file = open(path + r'\\password.txt')
for line in file.readlines():
passw.append(line.strip())
file.close()
path = r'C:\\xxx'
pdf_reader = PdfFileReader(path + r'\\test).pdf')
for i in passw:
if pdf_reader.decrypt(i):
print(f'破解成功,密码为{i}')
else:
print(f'破解不成功,密码{i}错误')
2. 手术无密码本,完全穷举
首先介绍 itertools
,可以构建含需要组合的生成器供后续迭代:
import itertools
mylist = ("".join(x) for x in itertools.product("0123456789abcdef", repeat=4))
print(next(mylist))
利用这个方法就可以用 while
循环尝试暴力破解(为了减少时间,生成器用"abc123"生成组合):
import itertools
from PyPDF2 import PdfFileReader
mylist = ("".join(x) for x in itertools.product("123abc", repeat=4))
path = r'C:\\xxx'
pdf_reader = PdfFileReader(path + r'\\test.pdf')
while True:
i = next(mylist)
if pdf_reader.decrypt(i):
print(f'破解成功,密码为{i}')
break
else:
print(f'破解不成功,密码{i}错误')
可以看到最后也成功破解了,但需要注意:但即使是这么简单的组合也耗费了一点时间,如果复杂的密码破解难度和破解时间就指数级增长了,暴力的穷举法就不一定适用,可以根据需求具体调整规则,缩小范围再进行尝试。
文章到这里就结束了,感谢你的观看
说实在的,每次在后台看到一些读者的回应都觉得很欣慰,我想把我收藏的一些编程干货贡献给大家,回馈每一个读者,希望能帮到你们。
干货主要有:
① 2000多本Python电子书(主流和经典的书籍应该都有了)
② Python标准库资料(最全中文版)
③ 项目源码(四五十个有趣且经典的练手项目及源码)
④ Python基础入门、爬虫、web开发、大数据分析方面的视频(适合小白学习)
⑤ Python所有知识点汇总(可以弄清楚Python的所有方向和技术)
*如果你用得到的话可以直接拿走,在我的QQ技术交流群里,可以自助拿走,群号是421592457。*
以上是关于利用以下python代码编写栏栅加密和解密的主要内容,如果未能解决你的问题,请参考以下文章