这个题可以说是比较坑了(还不是我很弱...)

Linux跑一下:

要输密码

ida打开看看:

  1. int __cdecl main(int argc, const char **argv, const char **envp)
  2. {
  3. __int64 v3; // rax
  4. __int64 v4; // rax
  5. __int64 v5; // rax
  6. __int64 v6; // rax
  7. __int64 v7; // rax
  8. __int64 v8; // rax
  9. __int64 v9; // rax
  10. __int64 v10; // rax
  11. __int64 v11; // rax
  12. __int64 v12; // rax
  13. __int64 v13; // rax
  14. __int64 v14; // rax
  15. __int64 v15; // rax
  16. __int64 v16; // rax
  17. __int64 v17; // rax
  18. __int64 v18; // rax
  19. __int64 v19; // rax
  20. __int64 v20; // rax
  21. __int64 v21; // rax
  22. int result; // eax
  23. __int64 v23; // rax
  24. __int64 v24; // rax
  25. __int64 v25; // rax
  26. __int64 v26; // rax
  27. __int64 v27; // rax
  28. __int64 v28; // rax
  29. __int64 v29; // rax
  30. __int64 v30; // rax
  31. __int64 v31; // rax
  32. __int64 v32; // rax
  33. __int64 v33; // rax
  34. __int64 v34; // rax
  35. __int64 v35; // rax
  36. __int64 v36; // rax
  37. __int64 v37; // rax
  38. char v38; // [rsp+Fh] [rbp-71h]
  39. char v39; // [rsp+10h] [rbp-70h]
  40. char v40; // [rsp+20h] [rbp-60h]
  41. _BYTE *v41; // [rsp+28h] [rbp-58h]
  42. char v42; // [rsp+30h] [rbp-50h]
  43. unsigned __int64 v43; // [rsp+68h] [rbp-18h]
  44.  
  45. v43 = __readfsqword(0x28u);
  46. std::operator<<<std::char_traits<char>>(&std::cout, "Enter the valid key!\n", envp);
  47. std::operator>><char,std::char_traits<char>>(&edata, &v42);
  48. std::allocator<char>::allocator((__int64)&v38);
  49. std::string::string(&v39, &v42, &v38);
  50. md5((MD5 *)&v40, (const std::string *)&v39);
  51. v41 = (_BYTE *)std::string::c_str((std::string *)&v40);
  52. std::string::~string((std::string *)&v40);
  53. std::string::~string((std::string *)&v39);
  54. std::allocator<char>::~allocator(&v38);
  55. if ( *v41 !=
  56. || v41[] !=
  57. || v41[] !=
  58. || v41[] !=
  59. || v41[] !=
  60. || v41[] !=
  61. || v41[] !=
  62. || v41[] !=
  63. || v41[] !=
  64. || v41[] !=
  65. || v41[] !=
  66. || v41[] !=
  67. || v41[] !=
  68. || v41[] !=
  69. || v41[] !=
  70. || v41[] !=
  71. || v41[] !=
  72. || v41[] !=
  73. || v41[] !=
  74. || v41[] !=
  75. || v41[] !=
  76. || v41[] !=
  77. || v41[] !=
  78. || v41[] !=
  79. || v41[] !=
  80. || v41[] !=
  81. || v41[] !=
  82. || v41[] !=
  83. || v41[] !=
  84. || v41[] !=
  85. || v41[] !=
  86. || v41[] != )
  87. {
  88. v23 = std::operator<<<std::char_traits<char>>(&std::cout, 73LL);
  89. v24 = std::operator<<<std::char_traits<char>>(v23, 110LL);
  90. v25 = std::operator<<<std::char_traits<char>>(v24, 118LL);
  91. v26 = std::operator<<<std::char_traits<char>>(v25, 97LL);
  92. v27 = std::operator<<<std::char_traits<char>>(v26, 108LL);
  93. v28 = std::operator<<<std::char_traits<char>>(v27, 105LL);
  94. v29 = std::operator<<<std::char_traits<char>>(v28, 100LL);
  95. v30 = std::operator<<<std::char_traits<char>>(v29, 32LL);
  96. v31 = std::operator<<<std::char_traits<char>>(v30, 75LL);
  97. v32 = std::operator<<<std::char_traits<char>>(v31, 101LL);
  98. v33 = std::operator<<<std::char_traits<char>>(v32, 121LL);
  99. v34 = std::operator<<<std::char_traits<char>>(v33, 33LL);
  100. v35 = std::operator<<<std::char_traits<char>>(v34, 32LL);
  101. v36 = std::operator<<<std::char_traits<char>>(v35, 58LL);
  102. v37 = std::operator<<<std::char_traits<char>>(v36, 40LL);
  103. std::ostream::operator<<(v37, &std::endl<char,std::char_traits<char>>);
  104. result = ;
  105. }
  106. else
  107. {
  108. v3 = std::operator<<<std::char_traits<char>>(&std::cout, 84LL);
  109. v4 = std::operator<<<std::char_traits<char>>(v3, 104LL);
  110. v5 = std::operator<<<std::char_traits<char>>(v4, 101LL);
  111. v6 = std::operator<<<std::char_traits<char>>(v5, 32LL);
  112. v7 = std::operator<<<std::char_traits<char>>(v6, 107LL);
  113. v8 = std::operator<<<std::char_traits<char>>(v7, 101LL);
  114. v9 = std::operator<<<std::char_traits<char>>(v8, 121LL);
  115. v10 = std::operator<<<std::char_traits<char>>(v9, 32LL);
  116. v11 = std::operator<<<std::char_traits<char>>(v10, 105LL);
  117. v12 = std::operator<<<std::char_traits<char>>(v11, 115LL);
  118. v13 = std::operator<<<std::char_traits<char>>(v12, 32LL);
  119. v14 = std::operator<<<std::char_traits<char>>(v13, 118LL);
  120. v15 = std::operator<<<std::char_traits<char>>(v14, 97LL);
  121. v16 = std::operator<<<std::char_traits<char>>(v15, 108LL);
  122. v17 = std::operator<<<std::char_traits<char>>(v16, 105LL);
  123. v18 = std::operator<<<std::char_traits<char>>(v17, 100LL);
  124. v19 = std::operator<<<std::char_traits<char>>(v18, 32LL);
  125. v20 = std::operator<<<std::char_traits<char>>(v19, 58LL);
  126. v21 = std::operator<<<std::char_traits<char>>(v20, 41LL);
  127. std::ostream::operator<<(v21, &std::endl<char,std::char_traits<char>>);
  128. result = ;
  129. }
  130. return result;
  131. }

可以看出来是先将输入的字符串进行md5加密 然后进行比对 正确就会输出一串字符

一开始我以为flag应该是输出的字符 于是:

  1. a=[84,104,101,32,107,101,121,32,105,115,32,118,97,108,105,100,32,58,41]
  2.  
  3. s=''
  4.  
  5. for i in a:
  6. s+=chr(i)
  7.  
  8. print(s)

结果输出是:

  1. The key is valid :)

okey....应该是考虑错了

那么就是md5这里:

  1. b=[55,56,48,52,51,56,100,53,98,54,101,50,57,100,98,48,56,57,56,98,99,52,102,48,50,50,53,57,51,53,99,48]
  2.  
  3. s=''
  4.  
  5. for i in b:
  6. s+=chr(i)
  7.  
  8. print(s)

输出:

  1. 780438d5b6e29db0898bc4f0225935c0

这是md5加密后的值,把它解密:

输出是 grape

满心欢喜提交 错误......

仔细看一下这个md5的类型:

md5(md5($pass))

也就是加密了之后又进行了一遍md5加密的 所以grape是最初的字符串 780438d5b6e29db0898bc4f0225935c0是最终的密文

那么我们的key应该就是中间加密一次得到的字符串!

将 grape 加密一遍得到:

  1. b781cbb29054db12f88f08c6e161c199

提交正确!

SUCTF 2016 : dMd的更多相关文章

  1. suctf逆向部分

    自己真的菜,然后在网上找了一篇分析pyc反编译后的文件然后进行手撸opcode,过程真痛苦 http://www.wooy0ung.me/writeup/2017/10/11/0ctf-quals-2 ...

  2. Be Better:遇见更好的自己-2016年记

    其实并不能找到好的词语来形容过去的一年,感觉就如此平淡的过了!没有了毕业的稚气,看事情淡了,少了一丝浮躁,多了一分认真.2016也许就是那句话-多读书,多看报,少吃零食多睡觉,而我更愿意说--Be B ...

  3. Connect() 2016 大会的主题 ---微软大法好

    文章首发于微信公众号"dotnet跨平台",欢迎关注,可以扫页面左面的二维码. 今年 Connect 大会的主题是 Big possibilities. Bold technolo ...

  4. “.Net 社区虚拟大会”(dotnetConf) 2016 Day 3 Keynote: Scott Hanselman

    美国时间 6月7日--9日,为期三天的微软.NET社区虚拟大会正式在 Channel9 上召开,美国时间6.9 是第三天, Scott Hanselman 做Keynote.今天主题围绕的是.NET ...

  5. “.Net 社区虚拟大会”(dotnetConf) 2016 Day 2 Keynote: Miguel de Icaza

    美国时间 6月7日--9日,为期三天的微软.NET社区虚拟大会正式在 Channel9 上召开,美国时间6.8 是第二天, Miguel de Icaza 做Keynote,Miguel 在波士顿Xa ...

  6. “.Net 社区虚拟大会”(dotnetConf) 2016 Day 1 Keynote: Scott Hunter

    “.Net 社区虚拟大会”(dotnetConf) 2016 今天凌晨在Channel9 上召开,在Scott Hunter的30分钟的 Keynote上没有特别的亮点,所讲内容都是 微软“.Net社 ...

  7. 微软发布正式版SQL Server 2016

    微软于今天在SQL 官方博客上宣布 SQL Server 数据库软件的正式发布版本(GA),历时一年多,微软为该软件发布了多个公共预览版和候选版本,而今天最终版本终于上线了.在博客中,微软数据集团的企 ...

  8. Summary of Critical and Exploitable iOS Vulnerabilities in 2016

    Summary of Critical and Exploitable iOS Vulnerabilities in 2016 Author:Min (Spark) Zheng, Cererdlong ...

  9. 黑云压城城欲摧 - 2016年iOS公开可利用漏洞总结

    黑云压城城欲摧 - 2016年iOS公开可利用漏洞总结 作者:蒸米,耀刺,黑雪 @ Team OverSky 0x00 序 iOS的安全性远比大家的想象中脆弱,除了没有公开的漏洞以外,还有很多已经公开 ...

随机推荐

  1. openjduge 求简单表达式的值

    表达式求值 总时间限制:  10000ms  单个测试点时间限制:  1000ms  内存限制:  131072kB 给定一个只包含加法和乘法的算术表达式,请你编程计算表达式的值. 输入 输入仅有一行 ...

  2. Flask 系列之 部署发布

    说明 操作系统:Windows 10 Python 版本:3.7x 虚拟环境管理器:virtualenv 代码编辑器:VS Code 实验目标 通过 Windows 的 WSL,将我们的项目网站部署到 ...

  3. Java发送电子邮件

    转自 https://blog.csdn.net/xietansheng/article/details/51673073 纯代码, 详情请至原文查看 需要一个javamail的jar包 以下为实现代 ...

  4. HTML和CSS前端教程05-CSS盒模型

    目录 1. CSS盒模型 1.1 元素的尺寸 1.2. 元素内边距 padding 1.3. 元素外边距 margin 1.4. 处理溢出overflow 1.5. 元素的可见性Visibility ...

  5. 解决ViewGroup不调用onDraw()的问题

    今天在做项目的时候自定义了一个View,继承了LinearLayout,结果,里面的onDraw()方法一直无法被调用. 后来发现ViewGroup是默认不调用onDraw()方法的. 原因我们暂且不 ...

  6. Netty学习笔记(三) 自定义编码器

    编写一个网络应用程序需要实现某种编解码器,编解码器的作用就是讲原始字节数据与自定义的消息对象进行互转.网络中都是以字节码的数据形式来传输数据的,服务器编码数据后发送到客户端,客户端需要对数据进行解码, ...

  7. TinScrapy-简化的Scrapy原码-查看爬虫的执行流程

    学习了自定义的TinyScrapy框架,整理出以下定注释的代码 from twisted.web.client import getPage,defer from twisted.internet i ...

  8. iOS开发之OC与swift开发混编教程,代理的相互调用,block的实现。OC调用Swift中的代理, OC调用Swift中的Block 闭包

    本文章将从两个方向分别介绍 OC 与 swift 混编 1. 第一个方向从 swift工程 中引入 oc类 1. 1 如何在swift的类中使用oc类    1.2  如何在swift中实现oc的代理 ...

  9. 为什么不使用github的wiki而是使用mkdocs做文档管理?

    为什么不使用github的wiki而是使用mkdocs做文档管理? 目前 KSFramework 是使用mkdocs来做在线文档 而非使用github的wiki,这是为什么呢? 在windows下搭建 ...

  10. 让 Windows7 - 64bit 支持 VC++ 6.0 的解决方法(无法启动此程序,因为计算机中丢失 MSVCRTD.dll。尝试重新安装该程序以解决此问题)

    源地址:https://www.cnblogs.com/poissonnotes/p/4372136.html 无法启动此程序,因为计算机中丢失 MSVCRTD.dll.尝试重新安装该程序以解决此问题 ...