当前位置: 首页 > article >正文

密码学---easy_hash

题目出处:首页 - Bugku CTF

✨打开题目有两个文件

✨打开flag.py后开始分析所给的代码

import hashlib  
# 导入 hashlib 模块,用于计算哈希值
from multiprocessing import Pool  
# 从 multiprocessing 模块导入 Pool 类,用于多进程处理


def compute_md5(char):  
    # 定义一个函数 compute_md5,接受一个字符作为参数
    md5_flag = hashlib.md5(char.encode())  
    # 将字符编码为字节并计算其 MD5 哈希值
    return md5_flag.hexdigest()  
    # 返回 MD5 哈希值的十六进制表示(hexdigest)


if __name__ == '__main__':
    with open('flag', 'r') as flag_file:  
        # 以只读模式打开名为 'flag' 的文件
        content = flag_file.read()  
        # 读取文件内容
        chars = list(content)  
        # 将文件内容转换为字符列表

        with Pool() as pool:  
            # 创建一个进程池
            md5_results = pool.map(compute_md5, chars)  
            # 并行计算每个字符的 MD5 哈希值

        with open('output', 'w') as output_file:  
            # 以写入模式打开名为 'output' 的文件
            for result in md5_results:  
                # 遍历每个计算出的 MD5 结果
                output_file.write(result + '\n')  
                # 将结果写入输出文件,每个结果一行

✨到这我的想法肯定是将代码运行,将给的output文件里面的每一行序列进行计算md5的值,最后得到flag,但是遇到的问题是没有flag文件,代码现在是无法运行的。

✨然后,我自己创建一个叫flag的文件,代码运行没有报错,现在要做的就是看怎样获取flag文件里面的内容。(做到后面才知道,这个脚本只是告诉你加密的过程)

✨新发现,output里面给的序列,我将每一行分别进行md5解密

8fa14cdd754f91cc6554c9e71929cce7    f
2db95e8e1a9267b7a1188556b2013b33    l
0cc175b9c0f1b6a831c399e269772661    a
b2f5ff47436671b6e533d8dc3614845d    g
f95b70fdc3088560732a5ac135644506    {
61e9c06ea9a85a5088a499df6458d276    W
e1671797c52e15f763380b45e841ec32    e
c4ca4238a0b923820dcc509a6f75849b    1
4a8a08f09d37b73795649038408b5f33    c
cfcd208495d565ef66e7dff9f98764da    0
6f8f57715090da2632453988d9a1501b    m
e1671797c52e15f763380b45e841ec32    e
b14a7b8059d9c055954c92674ce60032    _
e358efa489f58062f10dd7316b65649e    t
cfcd208495d565ef66e7dff9f98764da    0
b14a7b8059d9c055954c92674ce60032    _
e358efa489f58062f10dd7316b65649e    t
2510c39011c5be704182423e3a695e91    h
e1671797c52e15f763380b45e841ec32    e
b14a7b8059d9c055954c92674ce60032    _
f1290186a5d0b1ceab27f4e77c0c5d68    w
cfcd208495d565ef66e7dff9f98764da    0
4b43b0aee35624cd95b910189b3dc231    r
c4ca4238a0b923820dcc509a6f75849b    1
8277e0910d750195b448797616e091ad    d
b14a7b8059d9c055954c92674ce60032    _
cfcd208495d565ef66e7dff9f98764da    0
8fa14cdd754f91cc6554c9e71929cce7    f
b14a7b8059d9c055954c92674ce60032    _
6f8f57715090da2632453988d9a1501b    m
8277e0910d750195b448797616e091ad    d
e4da3b7fbbce2345d7772b0674a318d5    5
cbb184dd8e05c9709e5dcaedaa0495cf    }

✨发现了flag{We1c0me_t0_the_w0r1d_0f_md5},注意:就是1和0


http://www.kler.cn/a/309221.html

相关文章:

  • Android 10 默认授权安装app运行时权限(去掉运行时所有权限授权弹窗)
  • Llama架构及代码详解
  • Linux 系统管理和监控命令---- auditctl命令
  • DevOps工程技术价值流:加速业务价值流的落地实践与深度赋能
  • vue2+ element ui 集成pdfjs-dist
  • 在Java中使用ModelMapper简化Shapefile属性转JavaBean实战
  • 论文阅读: SigLit | SigLip |Sigmoid Loss for Language Image Pre-Training
  • 【Kubernetes】常见面试题汇总(二十一)
  • 51单片机 - DS18B20实验1-读取温度
  • 硬件工程师笔试面试——变压器
  • 二.Oracle每周运维操作
  • 在Android中如何进行多渠道打包
  • Linux基础---07文件传输及解决yum安装失效的方法
  • 【Linux】探索文件I/O奥秘,解锁软硬链接与生成动静态库知识
  • 编译成功!QT/6.7.2/Creator编译Windows64 MySQL驱动(MinGW版)
  • 剧本杀小程序开发,探索互联网剧本杀游戏体验
  • 【C++】虚函数
  • 多速率信号处理-CIC滤波器
  • Go第三方框架--gin框架(三)
  • SpringBoot 消息队列RabbitMQ死信交换机
  • 2025年最新大数据毕业设计选题-基于Spark分析相关
  • NC反弹shell
  • 微服务中间件之Nacos
  • Android 系统开发人员的权限说明文档
  • 解锁全球机遇:澳大利亚服务器租用市场的独特魅力
  • [C#学习笔记]Newtonsoft.Json