CTF之密码学(当铺解密)

一、当铺密码的基本原理

  • 加密过程

    • 当铺密码通过将汉字的笔画数转化为数字来进行加密。具体来说,一个汉字的笔画数(出头笔画也算作一笔)就是它对应的数字。
    • 例如,汉字"由"有3笔(包括出头的笔画),在加密时就可以表示为数字"3"。
  • 解密过程

    • 解密时,需要将数字重新映射回对应的汉字。这通常需要一个预定义的汉字笔画映射表,该表列出了每个汉字及其对应的笔画数。
    • 通过查找这个表,可以将数字解密为对应的汉字。

二、解密步骤

  1. 准备汉字笔画映射表

    • 创建一个包含常用汉字及其笔画数的映射表。这个表应该足够全面,以涵盖可能用于加密的所有汉字。
    • 需要注意的是,由于汉字的笔画数可能因书写习惯和字体差异而有所不同,因此在实际应用中需要选择一个标准的笔画数定义。
  2. 接收加密信息

    • 接收由数字组成的加密信息。这些数字代表了对应汉字的笔画数。
  3. 解密数字为汉字

    • 遍历加密信息中的每个数字。
    • 在汉字笔画映射表中查找与该数字对应的汉字。
    • 将找到的汉字添加到解密结果中。
  4. 验证解密结果

    • 根据上下文或预期内容验证解密结果是否正确。
    • 如果解密结果不符合预期,可能需要检查加密信息是否正确、汉字笔画映射表是否完整或准确等问题。

三、示例

假设我们有一个简单的汉字笔画映射表如下:

汉字 笔画数
5
3(包括出头的笔画)
4
2
... ...

如果我们收到的加密信息是"5 3 4 2",那么解密过程如下:

  1. 在映射表中查找笔画数为5的汉字,找到"田"。
  2. 在映射表中查找笔画数为3的汉字,找到"由"。
  3. 在映射表中查找笔画数为4的汉字,找到"中"。
  4. 在映射表中查找笔画数为2的汉字,找到"人"。

因此,解密结果是"田中由人"。

python解码程序

python 复制代码
s = '田由中人工大王夫井羊'
txt = input()
# txt = txt.split()
answer = ""
fu = ""
for i in range(len(txt)):
    if txt[i] == " ":
        answer += chr(int(fu))
        fu = ""
    elif txt[i] in s:
        fu += str(s.index(txt[i]))
answer += chr(int(fu))
print(answer)
相关推荐
RestCloud36 分钟前
在制造业数字化转型浪潮中,数据已成为核心生产要素。然而,系统割裂、数据滞后、开发运维成本高等问题,却像顽固的 “数据枷锁”,阻碍着企业发展。ETLCloud与
数据库·postgresql
!chen1 小时前
【Spring Boot】自定义starter
java·数据库·spring boot
十碗饭吃不饱1 小时前
sql报错:java.sql.SQLSyntaxErrorException: Unknown column ‘as0‘ in ‘where clause‘
java·数据库·sql
我是Superman丶2 小时前
【优化】Mysql指定索引查询或忽略某个索引
数据库·mysql
程序定小飞2 小时前
基于springboot的在线商城系统设计与开发
java·数据库·vue.js·spring boot·后端
呆呆小金人2 小时前
SQL入门: HAVING用法全解析
大数据·数据库·数据仓库·sql·数据库开发·etl·etl工程师
LL_break2 小时前
Mysql数据库
java·数据库·mysql
野犬寒鸦2 小时前
从零起步学习Redis || 第十一章:主从切换时的哨兵机制如何实现及项目实战
java·服务器·数据库·redis·后端·缓存
倔强的石头_3 小时前
面向大数据架构的演进:为何 Apache IoTDB 是与生态无缝融合的理想之选?
数据库
Elastic 中国社区官方博客4 小时前
如何减少 Elasticsearch 集群中的分片数量
大数据·数据库·elasticsearch·搜索引擎·全文检索