当前位置:   article > 正文

2024ctfshow元旦水友赛 RE re_signin

ctfshow元旦水友赛

很简单的签到题,然而我把加密函数看花眼了

主要函数部分可以直接看到

41行 获取128个字符,v8算个长度,读入到回车就停止

45行 生成了一个key

46行 加密

47行 比对密文,s2已经给出

encrypt看一下

对每一个字符,加上一个v7,再异或v7>>4,

v6是用来记录上次的result

逆向搓一下脚本

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. unsigned int generate_key(unsigned int s) {
  5. s = s * 0x5bd1e995 + 0x12345678;
  6. return (s >> 16);
  7. }
  8. void decrypt(unsigned char* flag, unsigned char* crypt, unsigned int year, unsigned int key) {
  9. unsigned int result = 0;//v6=0
  10. int i;
  11. for (i = 0; i < 128; i++) {
  12. if (crypt[i] == 0) { //跳过0的填充部分
  13. continue;
  14. }
  15. result += year + key;
  16. flag[i] = crypt[i] - result;
  17. result = (result >> 4) ^ crypt[i]; //v6
  18. }
  19. }
  20. int main() {
  21. unsigned char flag[128] = { 0 }; //先填满0
  22. unsigned int key;
  23. unsigned char crypt[] = {
  24. 0x9c, 0xcc, 0x88, 0x76, 0xd7, 0x89, 0x78, 0xec, 0x7c, 0xd7, 0x89, 0x71, 0xe3, 0x6d, 0x98, 0x17,
  25. 0x94, 0x0f, 0xca, 0x9f, 0x7e, 0xd9, 0xa0, 0x8a, 0x79, 0xd1, 0x80, 0x77, 0x00, 0x00, 0x00, 0x00,
  26. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  27. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  28. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  29. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  30. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  31. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  32. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  33. }; //128
  34. key = generate_key(0x36D);
  35. decrypt(flag, crypt, 2024, key);
  36. printf("%s", flag);
  37. }

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号