Python实现仿射密码的思路详解

作者:SFS_Ccjm 时间:2021-04-17 22:32:00 

仿射密码思路:

1、加解密公式:

Python实现仿射密码的思路详解

2、构造对应字典:

Python实现仿射密码的思路详解

3、代码实现

构造字典,建立映射关系:


# 构造字典,'A' --> 0 ...
def char_2_num(x):
 list_s = []
 list_num = []
 for i in range(26):
   c = chr(i + 65)
   list_s.append(c)
   list_num.append(i)
 c_2_n = dict(map(lambda x, y: [x, y], list_s, list_num))
 return c_2_n[f'{x}']

# 构造字典,0 ---> 'A' ...
def num_2_char(x):
 list_s = []
 list_num = []
 for i in range(26):
   c = chr(i + 65)
   list_s.append(c)
   list_num.append(i)
 n_2_c = dict(map(lambda x, y: [x, y], list_num, list_s))
 print(n_2_c[x],end='')

实现加密:


# 编码
def encode():
 s = input('输入需要编码的字符: ')
 print('编码后的结果为: ',end='')
 for j in s:
   if j.isspace():
     print(' ',end='')
   else:
     ek = a * char_2_num(j) + b
     result = ek % 26
     num_2_char(result)

求模26下a的逆,实现解密:


# 求模26下a的逆
def inv_(x):
 for inv_a in range(1,26,2):
   for j in range(27):
     if x * inv_a == 26 * j + 1:
       return inv_a

# 解码
def decode():
 s = input('输入需要解码的字符: ')
 print('解码后的结果为: ',end='')
 for j in s:
   if j.isspace():
     print(' ',end='')
   else:
     dk = inv_(a) * (char_2_num(j) - b)
     result = dk % 26
     num_2_char(result)

函数入口:


# 输入指令
answer = input(f'请输入所需的操作:编码/E or 解码/D: ')

# 输入参数a,b
a = int(input('请输入a:'))
b = int(input('请输入b: '))

try:
 if answer.upper() == 'E':
   encode()
 elif answer.upper() =='D':
   decode()
 else:
   print('输入错误!')
except KeyError:
 print('请正确输入大写字母!')

加密效果:

请输入所需的操作:编码/E or 解码/D:  E
请输入a:5
请输入b: 7
输入需要编码的字符: TODAY IS SO HOT
编码后的结果为: YZWHX VT TZ QZY

解密效果:

请输入所需的操作:编码/E or 解码/D:  D
请输入a:5
请输入b: 7
输入需要解码的字符: YZWHX VT TZ QZY
解码后的结果为: TODAY IS SO HOT

来源:https://blog.csdn.net/SFS_Ccjm/article/details/105660224

标签:python,仿射密码
0
投稿

猜你喜欢

  • C#操作SQLite数据库帮助类详解

    2024-01-22 03:52:37
  • python查看矩阵的行列号以及维数方式

    2021-03-25 20:24:58
  • java连接mysql底层封装详解

    2024-01-26 17:31:19
  • 解决Pycharm出现的部分快捷键无效问题

    2021-09-12 12:49:34
  • django-rest-framework 自定义swagger过程详解

    2023-01-01 22:05:34
  • Python中parsel两种获取数据方式小结

    2023-03-01 17:44:50
  • MySQL数据库生产环境的维护工作总结的经验

    2011-12-01 10:20:52
  • 详解如何使用beego orm在postgres中存储图片

    2024-04-25 15:14:46
  • python使用代理ip访问网站的实例

    2022-02-08 08:16:36
  • 微信小程序如何处理token过期问题

    2023-07-02 05:23:54
  • 详解MySQL双活同步复制四种解决方案

    2024-01-13 04:39:47
  • 设计工作者必须了解的常识

    2008-04-06 13:56:00
  • 模仿PHP写的ASP分页函数

    2008-04-13 06:11:00
  • 详解pytorch 0.4.0迁移指南

    2023-04-10 08:02:14
  • 浅谈Scrapy网络爬虫框架的工作原理和数据采集

    2023-08-24 22:17:21
  • Django restframework 源码分析之认证详解

    2021-08-15 12:03:40
  • vue3 axios 实现自动化api配置详解

    2024-05-28 16:01:23
  • SQL Server的链接服务器技术小结

    2024-01-17 03:41:22
  • 带你轻松接触 MySQL中损坏的MyISAM表

    2008-12-19 17:55:00
  • python 点云地面点滤波-progressive TIN densification(PTD)算法介绍

    2023-05-26 17:50:55
  • asp之家 网络编程 m.aspxhome.com