当前位置:   article > 正文

伏羲六十四卦+36D_ctfshow hlcgoyfsjqknyifnpd:bcdefghijklmnopqrstuvwx

ctfshow hlcgoyfsjqknyifnpd:bcdefghijklmnopqrstuvwxyza

伏羲六十四卦

  解压之后有两个文件,一个是加密脚本,一个是txt文件,txt文件给了我们一串密文,就是六十四卦中的汉字,那就是与六十四卦有关,查找六十四卦相关信息,发现有一篇文章是讲六十四卦与二进制的关系,上网查询之后,找到了这样一张图片

 那现在就很清楚了,需要把给出的密文转换为二进制数字,

  1. s='升随临损巽睽颐萃小过讼艮颐小过震蛊屯未济中孚艮困恒晋升损蛊萃蛊未济巽解艮贲未济观豫损蛊晋噬嗑晋旅解大畜困未济随蒙升解睽未济井困未济旅萃未济震蒙未济师涣归妹大有'
  2. dic={'坤': '000000', '剥': '000001', '比': '000010', '观': '000011', '豫': '000100', '晋': '000101', '萃': '000110', '否': '000111', '谦': '001000', '艮': '001001', '蹇': '001010', '渐': '001011', '小过': '001100', '旅': '001101', '咸': '001110', '遁': '001111', '师': '010000', '蒙': '010001', '坎': '010010', '涣': '010011', '解': '010100', '未济': '010101', '困': '010110', '讼': '010111', '升': '011000', '蛊': '011001', '井': '011010', '巽': '011011', '恒': '011100', '鼎': '011101', '大过': '011110', '姤': '011111', '复': '100000', '颐': '100001', '屯': '100010', '益': '100011', '震': '100100', '噬嗑': '100101', '随': '100110', '无妄': '100111', '明夷': '101000', '贲': '101001', '既济': '101010', '家人': '101011', '丰': '101100', '离': '101101', '革': '101110', '同人': '101111', '临': '110000', '损': '110001', '节': '110010', '中孚': '110011', '归妹': '110100', '睽': '110101', '兑': '110110', '履': '110111', '泰': '111000', '大畜': '111001', '需': '111010', '小畜': '111011', '大壮': '111100', '大有': '111101', '夬': '111110', '乾': '111111'}
  3. li=[]
  4. k=0
  5. """
  6. 老规矩来解释一下下面的脚本是什么意思:
  7. 首先创建一个循环结构,找到每个字相对应的值,但是我们仔细观察可以发现
  8. 六十四卦表中并不是一个二进制数字对应一个字,例如 '大过': '011110'就是两个字
  9. 所以我们可以使用try语句来尝试,如果碰到对应两个字的,就用expect后的程序
  10. 然后关于k值,因为我们在取得了两个字的二进制数后,i就会相对少1,因此我们可以用continue语句来解决
  11. 可能说的有一些抽象,可以通过调试来解决一下问题
  12. """
  13. for i in range(len(s)):
  14. if k ==1:
  15. k=0
  16. continue
  17. try:
  18. li.append(dic[s[i]])
  19. except:
  20. t=''
  21. t=t+s[i]+s[i+1]
  22. li.append(dic[t])
  23. k=1
  24. ss=''.join(li)
  25. print(ss)
'
运行

得到二进制数后,我试了一下二进制数的转换,但是没有啥用,因此还需要对二进制数动一些手脚,现在就是拼一下脑洞,六十四+二进制,可以试试base64,但是base64是每八个二进制数为一个单位,因此还需要写脚本

  1. enc=''
  2. for i in range(0,len(ss),8):
  3. enc+=chr(eval('0b'+ss[i:i+8]))
  4. print(enc)

eval是返回计算后的字符串值,0b是转换二进制数的意思.

bl1oXF1ra2FbW2VpV1dfUmBiT11dYE5NVVdXSUZYSFVDUA==

base64解码,得到了

n]h\]kka[[eiWW_R`bO]]`NMUWWIFXHUCP

这最后啥也看不出来了,但是题目还给了我们一个加密脚本

  1. from secret import flag
  2. def encrpyt5():
  3. enc=''
  4. for i in flag:
  5. enc+=chr((a*(ord(i)-97)+b)%26+97)
  6. return(enc)
  7. def encrypt4():
  8. temp=''
  9. offset=5
  10. for i in range(len(enc)):
  11. temp+=chr(ord(enc[i])-offset-i)
  12. return(temp)

那就只需要逆着它写了,它先5再4,那我们写的时候就先4再5

  1. def decrypt4(enc):
  2. temp=''
  3. offset=5
  4. for i in range(len(enc)):
  5. temp+=chr(ord(enc[i])+offset+i)
  6. return temp
  7. #decrypt5
  8. def decrypt5(flag):
  9. for a in range(1,200):
  10. enc = ''
  11. for i in flag:
  12. for k in range(200):
  13. if (ord(i) - 97 - 7+26*k)%a==0:
  14. enc+= chr((ord(i) - 97 - 7 + 26 * k) // a + 97)
  15. break
  16. print(enc)
'
运行

把所有脚本加起来,就是最后的答案了

  1. #decrypt4
  2. def decrypt4(enc):
  3. temp=''
  4. offset=5
  5. for i in range(len(enc)):
  6. temp+=chr(ord(enc[i])+offset+i)
  7. return temp
  8. #decrypt5
  9. def decrypt5(flag):
  10. for a in range(1,200):
  11. enc = ''
  12. for i in flag:
  13. for k in range(200):
  14. if (ord(i) - 97 - 7+26*k)%a==0:
  15. enc+= chr((ord(i) - 97 - 7 + 26 * k) // a + 97)
  16. break
  17. print(enc)
  18. #暴力破解
  19. s='升随临损巽睽颐萃小过讼艮颐小过震蛊屯未济中孚艮困恒晋升损蛊萃蛊未济巽解艮贲未济观豫损蛊晋噬嗑晋旅解大畜困未济随蒙升解睽未济井困未济旅萃未济震蒙未济师涣归妹大有'
  20. dic={'坤': '000000', '剥': '000001', '比': '000010', '观': '000011', '豫': '000100', '晋': '000101', '萃': '000110', '否': '000111', '谦': '001000', '艮': '001001', '蹇': '001010', '渐': '001011', '小过': '001100', '旅': '001101', '咸': '001110', '遁': '001111', '师': '010000', '蒙': '010001', '坎': '010010', '涣': '010011', '解': '010100', '未济': '010101', '困': '010110', '讼': '010111', '升': '011000', '蛊': '011001', '井': '011010', '巽': '011011', '恒': '011100', '鼎': '011101', '大过': '011110', '姤': '011111', '复': '100000', '颐': '100001', '屯': '100010', '益': '100011', '震': '100100', '噬嗑': '100101', '随': '100110', '无妄': '100111', '明夷': '101000', '贲': '101001', '既济': '101010', '家人': '101011', '丰': '101100', '离': '101101', '革': '101110', '同人': '101111', '临': '110000', '损': '110001', '节': '110010', '中孚': '110011', '归妹': '110100', '睽': '110101', '兑': '110110', '履': '110111', '泰': '111000', '大畜': '111001', '需': '111010', '小畜': '111011', '大壮': '111100', '大有': '111101', '夬': '111110', '乾': '111111'}
  21. li=[]
  22. k=0
  23. for i in range(len(s)):
  24. if k ==1:
  25. k=0
  26. continue
  27. try:
  28. li.append(dic[s[i]])
  29. except:
  30. t=''
  31. t=t+s[i]+s[i+1]
  32. li.append(dic[t])
  33. k=1
  34. ss=''.join(li)
  35. print(ss)
  36. #二进制转换
  37. enc=''
  38. for i in range(0,len(ss),8):
  39. enc+=chr(eval('0b'+ss[i:i+8]))
  40. print(enc)
  41. #base64解码
  42. import base64
  43. x=base64.b64decode(enc).decode()
  44. print(x)
  45. decrypt4(x)
  46. decrypt5(x)
'
运行

36D-Crypto-你rot了吗

W9@F0>:2?0D9:07=28X/3/TUW/o/7/PUo/ST7/T/6/R

提示给我们要先rot,再看键盘,在rot47解码之后,我们得到

(hou_mian_shi_flag)^b^%&(^@^f^!&@^$%f^%^e^#

但后面是错误答案,所以是嵌套类型的,把上面的特殊字符均转换为数字,再16进制解密即可。

The  Dancing  Men

题目给了我们一张图片

 看过福尔摩斯的人都知道,这是出现在其作品里的人形密码

 带方框的小人代表着一个单词的结束,这个只能一个一个推导,最后是

  1. please use underslash between every word with initivals in capitals
  2. the flag is everyone loves taoshen

小提示,记得加下划线。

RSAZE

题目给了四个文件,三个加密文件一个密钥文件,老规矩使用代码将它们先提取出来

  1. from Crypto.PublicKey import RSA
  2. import libnum
  3. import gmpy2
  4. from Crypto.Util.number import *
  5. c1 = open('encrypted.message1', 'rb').read()
  6. c2 = open('encrypted.message2', 'rb').read()
  7. c3 = open('encrypted.message3', 'rb').read()
  8. pub1=RSA.importKey(open('public.key').read())
  9. n=pub1.n
  10. e=pub1.e

这次一口气给了3个c不像之前的共模攻击,可以一个一个解解试试,出来n之后,我们需要对其进行分解,得到需要的p和q,然后按寻常的rsa题目解题,依次得到三个c所对应的三个m。

  1. from Crypto.PublicKey import RSA
  2. import libnum
  3. import gmpy2
  4. from Crypto.Util.number import *
  5. c1 = open('encrypted.message1', 'rb').read()
  6. c2 = open('encrypted.message2', 'rb').read()
  7. c3 = open('encrypted.message3', 'rb').read()
  8. pub1=RSA.importKey(open('public.key').read())
  9. n=pub1.n
  10. e=pub1.e
  11. p=302825536744096741518546212761194311477
  12. q=325045504186436346209877301320131277983
  13. phi_n=(p-1)*(q-1)
  14. d=gmpy2.invert(e,phi_n)
  15. c1_a=bytes_to_long(c1)
  16. m1=pow(c1_a,d,n)
  17. c2_a=bytes_to_long(c2)
  18. m2=pow(c2_a,d,n)
  19. c3_a=bytes_to_long(c3)
  20. m3=pow(c3_a,d,n )
  21. print(m1)
  22. print(m2)
  23. print(m3)
  24. print(long_to_bytes(m1))
  25. print(long_to_bytes(m2))
  26. print(long_to_bytes(m3))

最后得到的是

  1. b'\x02Z\x80\x07\xe9\xad(\t\xab\xbfZ\x00flag{3b6d3806-4b2b\n'
  2. b'\x02\xd2\xb9{n\xa0\xd9\xe5\x16\x9e\x1b\xc1LH\xa0\xdb\xecT\x00-11e7-95a0-\n'
  3. b'\x02eN\xe6$Cq\xf5D+O\xc8\xb9m\x7f/\x00000c29d7e93d}\n'
'
运行

把后面的组合起来就好了。

flag{3b6d3806-4b2b-11e7-95a0-000c29d7e93d}

justshow

hlcgoyfsjqknyifnpd:bcdefghijklmnopqrstuvwxyza

给了一串密文,冒号后面可以看出来是字母表,只不过像是用凯撒加密移动了一位,复原后为

gkbfnxeripjmxhemoc:abcdefghijklmnopqrstuvwxyz

这像是冒号后面是密钥,前面是密文,可以观察一下前面的字符,只由小写字母组成,用后面的字母表推不出来什么,,再看一下个数,18个字母,为偶数,带着该密码的特征:均由小写字母组成且位数为偶数,找到了一个叫playfair密码的,用密码转换器解密Playfair Cipher

flag为flag{ctfshowicome}。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Li_阴宅/article/detail/807570
推荐阅读
相关标签
  

闽ICP备14008679号