bugku的部分wp
MISC
闪的好快
下载文件是一个动态二维码,扫描第一帧之后会返回一个S,所以猜测就是所有二维码的字符串就是flag,所以写个脚本:
1 | #-*- coding: UTF-8 -*- |
得到flag:SYC{F1aSh_so_f4sT}
啊哒
用binwalk查看文件
发现有个压缩包,binwalk分离文件,直接分离文件
得到myzip,进行解压,发现需要密码,这个时候查看一些图片的具体信息,发现
将这部分16进制转成字符串,得到sdnisc_2018
输入,得到flag.txt,
得到flag{3XiF_iNf0rM@ti0n}
come_game
打开文件,发现:
打开游戏运行,界面如下
发现新生成了三个文件:
用winhex打开看看,最后发现是save1文件中,存储着关卡信息,更改2对应16进制,将32改为33
发现关卡发生改变,接着改到35时,出现flag:
所以flag为FLAG{6E23F259D98DF153}
白哥的鸽子
下载下来一个jpg二进制文件,猜测可能是图片,改一下文件名,
放到linux下,binwalk查看一下隐藏文件,发现没有什么特殊的地方,用winhex打开,
在末尾发现一段可用字符串,可能被加密了,用各种基本解密方法尝试解密,发现是栅栏密码,
发现flag{w22_is_v3ry_cool}
linux
下载下来一个压缩包文件,然后在linux中进行解压,得到一个flag的二进制文件,使用cat进行捕捉,发现flag:
隐写3
下载一个压缩包,打开发现里面有张图片
放到linux中尝试看看是否有隐藏文件,发现不能打开,所以猜测是CRC校验的问题,修改高度对应位置:
得到flag{He1l0_d4_ba1}
做个游戏(08067CTF)
打开文件,一个java程序,运行:
题目描述说,60秒,后面的速度越来越快,不太行~
尝试使用逆向工具,
代码文件里面翻阅,发现
得到flag{RGFqaURhbGlfSmlud2FuQ2hpamk=}
交上去发现不对,看其中被base64加密了,解密后flag{DajiDali_JinwanChiji}
Web
Web2
打开链接:
查看源码,查找flag
KEY{Web-2-bugKssNNikls9100}
计算器
打开链接,发现只能输入一位
按f12打开控制台,查看相关源代码,发现maxlen=1,将其改为2,
重新输入,结果21即可得到flag{CTF-bugku-0032}
web基础$_GET
打开链接,发现以下代码:
1 | $what=$_GET['what']; |
很简单就是用GET方法进行传值,注意在index.php界面进行传值,payload如下:
http://123.206.87.240:8002/get/index.php?what=flag
得到flag{bugku_get_su8kej2en}
web基础$_POST
跟上题很像,只是传参方法换了,使用POST方法,使用hackbar,直接传参:
得到flag{bugku_get_ssseint67se}
矛盾
打开链接,得到这个:
1 | $num=$_GET['num']; |
==
是比较运算符号 不会检查条件式的表达式的类型,所以我们可以构造一组整数等于1的字符串payload如下:http://123.206.87.240:8002/get/index1.php?num=1s
得到flag{bugku-789-ps-ssdf}
web3
打开链接:
查看源码。发现一组编码:
KEY{J2sa42ahJK-HS11III}
unicode编码,解码得到KEY{J2sa42ahJK-HS11III}
域名解析
直接添加hosts文件,在尾部加上123.206.87.240 flag.baidu.com
在浏览器中输入:flag.baidu.com
得到KEY{DSAHDSJ82HDS2211}
你必须让他停下
打开链接,发现:
看源码,会发现图片一直在变,在这个页面一直刷新就行,就能得到flag
本地包含
1 |
|
方法一:eval存在命令执行漏洞,使用hello构造payload
http://123.206.87.240:8003/index.php?hello=1);show_source(%27flag.php%27);var_dump(3
1 | int(1) |
方法二:
http://123.206.87.240:8003/index.php?hello=1);include $_POST['f'];
在POST区域:f=php://filter/convert.base64-encode/resource=flag.php
方法三:直接将flag.php文件读入变量hello中
?hello=get_file_contents('flag.php')
备份是个好习惯
利用md5或者php中“==”
的漏洞进行操作
1 |
|
关键代码就是需要key1与key2的值相等,但是加密之前的值不同
md5()函数无法处理数组,如果传入的为数组,会返回NULL,所以两个数组经过加密后得到的都是NULL,也就是相等的
1
http://123.206.87.240:8002/web16?kkeyey1[]=something&kkeyey2[]=nothing
如果两个字符经MD5加密后的值为 0exxxxx形式,就会被认为是科学计数法,且表示的是0*10的xxxx次方,还是零,都是相等的。
1
2
3
4
5
6
7
8
9
10
11
12
13
14下列的字符串的MD5值都是0e开头的:
QNKCDZO
240610708
s878926199a
s155964671a
s214587387a
s214587387a
http://123.206.87.240:8002/web16?kkeyey1=QNKCDZO&kkeyey2=240610708
秋名山老司机
2s秒内需要计算出结果然后post value值上去,可以用脚本进行计算
1 | import requests |
得到flag: Bugku{YOU_DID_IT_BY_SECOND}
速度要快
看看源代码,需要我们post一个margin值上去
尝试抓包,发送repeater一下,然后go,发现flag,base64解密
交上去,发现不对,然后将margin赋值,用post方法传上去,发现也不对,再go几次发现,flag值在变化..…..…
想想题目说速度要快,所以可能需要通过脚本进行传值
1 | import requests |
cookie欺骗
打开看是一堆字符串,而且是一组重复出现,尝试MD5解密,没有结果。之后看看url
http://123.206.87.240:8002/web11/index.php?line=&filename=a2V5cy50eHQ=
filename后的好像是base64编码,尝试解码:keys.txt
也就是说我们可以通过filename来得到文件信息,而我们想得到flag可以尝试看一下后台index.php的源码,同样需要将iindex.php编码,用line控制行数可将其打印出。
http://123.206.87.240:8002/web11/index.php?line=1&filename=aW5kZXgucGhw
使用脚本
1 | import requests |
得到
1 |
|
我们可以尝试添加Cookie,然后将keys.php编码后传上去
得到flag:KEY{key_keys}
nerve give up
还是看看源码:
所以访问下http://123.206.87.240:8006/test/1p.html
1 | <HTML> |
得到一组base64加密字符串,注意这里%3D%3D-–%3E是url加密,解密的是==-->
所以直接进行base64解密得到:
1 | ";if(!$_GET['id']) |
尝试直接访问f4l2a3g.txt
文件,得到flag:flag{tHis_iS_THe_fLaG}
welcome to bugkuctf
打开链接,还是啥都没有,看看源代码
1 | <!-- |
这里就要使用php伪协议了。这道题目为了解决第二个条件,要用到 “php://input”协议。大致的意思是让 txt=php://input ,之后在post过去一个字符串
http://123.206.87.240:8006/index.php?txt=php://input
welcome to the bugkuctf
//将其post上去
此时根据提示我们可以把包含的文件读出来了,这里要用到php的第二个伪协议:php://filter
txt=php://input&file=php://filter/read=convert.base64-encode/resource=hint.php
(简单来说就是利用伪协议读取所包含文件的base64值)
1 | PD9waHAgIA0KICANCmNsYXNzIEZsYWd7Ly9mbGFnLnBocCAgDQogICAgcHVibGljICRmaWxlOyAgDQogICAgcHVibGljIGZ1bmN0aW9uIF9fdG9zdHJpbmcoKXsgIA0KICAgICAgICBpZihpc3NldCgkdGhpcy0+ZmlsZSkpeyAgDQogICAgICAgICAgICBlY2hvIGZpbGVfZ2V0X2NvbnRlbnRzKCR0aGlzLT5maWxlKTsgDQoJCQllY2hvICI8YnI+IjsNCgkJcmV0dXJuICgiZ29vZCIpOw0KICAgICAgICB9ICANCiAgICB9ICANCn0gIA0KPz4gIA== |
看看能不能直接读flag:
显然没有flag,所以不能直接访问。这个信息返回到index.php页面,所以讲hint.php改成index.php看看里面的信息。
1 |
|
我们发现当Flag方法当做字符串执行时,会自动执行 __tostring 方法,方法中写了如果file文件存在,那么就输出file文件中的内容。构造一个Flag类型的参数,并把这个参数传给password然后get进去。并且这个file的值要是hint.php(因为要利用hint.php中的函数)
1 |
|
O:4:"Flag":1:{s:4:"file";s:8:"flag.php";}
所以构造的url为:http://123.206.87.240:8006/index.php?txt=php://input&file=hint.php&password=O:4:"Flag":1:{s:4:"file";s:8:"flag.php";}
得到flag:flag{php_is_the_best_language}
字符?正则?
利用正则匹配构造id的值,用GET方法传上去
1 | /代表匹配的开始与结束两个/里面的内容就是要匹配的内容 |
前女友(SKCTF)
打开链接出现这个,查看源码,
点击一下,可以得到code.txt中的内容
1 |
|
跟前面一道题很像,绕过md5,这里需要说一下就是strcmp在比较数组的时候返回应该是0,所以url构造如下:http://123.206.31.85:49162/index.php?v1=QNKCDZO&v2=240610708&v3[]=something
得到flag:SKCTF{Php_1s_tH3_B3St_L4NgUag3}
login1(SKCTF)
随便注册一下,发现,无法登陆,发现可以注册账号,之后登陆发现需要获取管理员权限
在SQL中执行字符串处理时,字符串末尾的空格符将会被删除。换句话说“vampire”等同于“vampire ”,对于绝大多数情况来说都是成立的(诸如WHERE子句中的字符串或INSERT语句中的字符串)例如以下语句的查询结果,与使用用户名“vampire”进行查询时的结果是一样的
SELECT * FROM users WHERE username='vampire ';
在所有的INSERT查询中,SQL都会根据varchar(n)来限制字符串的最大长度。也就是说,如果字符串的长度大于“n”个字符的话,那么仅使用字符串的前“n”个字符。比如特定列的长度约束为“5”个字符,那么在插入字符串“vampire”时,实际上只能插入字符串的前5个字符,即“vampi”。
注意密码是大小字母还要加数字,还有admin后的空格需要足够多的。
我的注册是:
1 | admin 123 |
之后登陆就能得到flag:SKCTF{4Dm1n_HaV3_GreAt_p0w3R}
你从哪里来
伪造一下来源,改一下referer
referer: https://www.google.com
得到flag{bug-ku_ai_admin}
目前遇到几个有关请求头的题,这里就稍微做一下总结
通用首部字段
请求首部字段
响应首部字段
md5 collision(NUPT_CTF)
根据题目所说,md5冲突,无非就是两个不同的值,但md5相等,所以先试试0e开头的
http://123.206.87.240:9009/md5.php?a=s878926199a
得到flag:flag{md5_collision_is_easy}
程序员本地网站
从本地访问,可以很清楚地看出,需要我们改一下X-Forwarded-For的值为:127.0.0.1
可以用burpsuite抓包,得到flag:flag{loc-al-h-o-st1}
各种绕过
打开链接会发现:
1 |
|
首先id=urlencode(margin)=margin,uname不能和passwd相等,但是sha1之后要相等,sha1只对字符型进行处理,是数组的话返回false,注意是在index.php中传值。
所以payload:http://123.206.87.240:8002/web7/index.php?id=margin&uname[]=something
还需要post:passwd[]=nothing
可以用hackbar完成操作,得到Flag: flag{HACK_45hhs_213sDD}
web8
1 |
|
题目中提出有txt文件,尝试1.txt,index.txt,flag.txt,最后发现flag.txt中有文件,
所以payload:http://123.206.87.240:8002/web8/index.php?ac=flags&fn=flag.txt
得到flag:flag{3cfb7a90fc0de31}
细心
打开链接发现这样的页面:
我还以为这道题又被大佬们给干掉了,看了别人的博客发现可以做,那就接着走..…..…
查看源码,什么也没有。怎么办??用御剑扫一下后台吧
发现可以访问,robots.txt,打开看看
接着做
题目是想办法变成admin,所以试试下面这个payload=http://123.206.87.240:8002/web13/resusl.php?x=admin
得到flag:flag(ctf_0098_lkji-s)
求getshell
打开链接,
大佬说的,如果是walf严格匹配,通过修改Content-type后字母的大小写可以绕过检测,使得需要上传的文件可以到达服务器端,而服务器的容错率较高,一般我们上传的文件可以解析。然后就需要确定我们如何上传文件,这里将文件的后缀名改为.jpg和.png都不可行,在分别将后缀名修改为php2, php3, php4, php5, phps, pht, phtm, phtml(php的别名),发现只有php5没有被过滤,成功上传,得到flag
先传一张图片,进行抓包,然后修改下面两个地方:
- filename 改为 1.php5
- 消息头中的Content-type将其后随便一个字母改为大写
Re
入门逆向
下载下来,查看一下文件类型:
32位应用程序,所以用ida打开:
发现一组ASCII码的数据,直接进行解码就行
flag{Re_1s_S0_C0oL}
Easy_vb
下载解题文件,查看一下文件类型:
用ida打开看看:
发现flag,看题目要求,flag最终为:flag{_N3t_Rev_1s_E4ay_}
Easy_re
下载解题文件后,先查看文件类型
运行试试:
现在用ida打开看看,容易找到相应位置
逆序,DUTCTF{We1c0met0DUTCTF}
Easy_re
下载解题文件后,先查看文件类型
运行试试:
现在用ida打开看看,容易找到相应位置
逆序,DUTCTF{We1c0met0DUTCTF}
游戏过关
方法一
这是一道exe逆向问题,而网上大多教程都是用OD解题,此时我对OD的使用情况并不是特别的熟练,尝试用ida进行解题。
用ida打开,
尝试找到main函数,可以i搜索,在function中用CTRL+F进行搜索:
查看main函数:
读完函数逻辑,查看其中的if-else判断,经逐个测试,发现最终会进入到:
顺着思路,发现sub_45E940
函数,打开查看逻辑:
1 | sub_45A7BE("done!!! the flag is "); |
写个python脚本:
1 | #encoing=utf-8 |
得到zsctf{T9is_tOpic_1s_v5ry_int7resting_b6t_others_are_n0t}
方法二
查看文件,
运行看看,
用OD打开,查找关键字符串,找到相应位置:
所以我们需要跳转到这来即可,现在我们重新查找关键字符串,找到输入的地方,下一个断点:
开始动态调试:
找到一个可以跳转的函数,将此处改为我们刚刚查找的地址:
jle long 0141E968
取消断点,运行一下:
得到flag:zsctf{T9is_tOpic_1s_v5ry_int7resting_b6t_others_are_n0t}
Timer
一个apk文件,安装之后出现一个读秒的,用apktool进行反编译,查看 MainActivity函数。
1 | package net.bluelotus.tomorrow.easyandroid; |
解题待定..….我先去学下java
逆向入门
下载得到一个admin.exe,运行提示,您的电脑版本不支持
file一下该文件,得到:
发现它并不是一个exe文件,是一个ASCII text文件,使用cat得到该文件的类容:
1 |  |
是一个base64的照片格式,还原扫码得到flag:bugku{inde_9882ihsd8-0}
love
下载下来发现一个reverse_3.exe文件,运行之后提示“没有相应的动态链接库”,查看文件类型
用ida打开,找到相应main函数的地方进行反编译,
输入接收是通过一个函数来实现的,点入查看,发现有一串函数连续调用,然后查看一些字符串,得到,发现:
怀疑上面的函数是经过base64加密而成,然后进行其他运算,最后与e3nifIH9b_C@n@dH
进行比较,可得到相应flag,所以我们进行逆向:
1 | #encoding=utf8 |
Mountain climbing
查看文件类型:
用ida打开:
发现只有一个start,怀疑是加过壳,经过PEID扫描发现经过Upx压缩,用对应工具脱壳,之后用ida打开,进入main函数:
1 | __int64 main_0() |
点入sub_41114F函数,一直点下去,发现一个这样的函数:
1 | BOOL __cdecl sub_411750(LPCVOID lpAddress, int a2, int a3) |
Pwn
pwn1
访问nc 114.116.54.89 10001
打印一下当前目录的文件,会发现:
直接 cat flag即可
flag{6979d853add353c9}
PWN2
下载文件,看一下开了什么防护:
没有栈溢出防护,随机化地址也没有。
用ida打开看看:
发现这个文件存在shell,所以大概思路就是利用read函数溢出覆盖到getshell的位置,由于这是调用静态的链接库,所以相对位移是不变的,直接可以得到此时shell的位置
看看read函数中的参数s的数组大小:
1 | -0000000000000030 s db ? |
也就是说,覆盖0x30+0x8才能进入return,所以直接可以写脚本:
1 | from pwn import * |
flag{n0w_y0u_kn0w_the_Stack0verfl0w}
PWN4
下载文件,查看一下保护机制:
没有栈溢出防护,可执行,没有地址随机化,有代码可执行段。
在ida64中打开,先看看main函数:
1 | __int64 __fastcall main(__int64 a1, char **a2, char **a3) |
没有栈溢出防护,而且有read函数,可以进行栈溢出,现在我们需要找到可以执行的shell位置,
shift+F12
查看文件中的字符串,看看有没有可疑字符串:
里面发现存在system函数,以及敏感字$0
,$0
在linux中为为shell或shell脚本的名称。system()
会调用fork()
产生子进程,由子进程来调用/bin/sh -c string
来执行参数string
字符串所代表的命令,此命令执行完后随即返回原调用的进程。
所以如果将$0
作为system
的参数,能达到传入'/bin/sh'
一样的效果。
接着我们就可以开始传入参数,64位是利用寄存器进行传参,32位使用栈进行传参
这里我们需要找到pop | ret
来进行相应的赋值,利用ROPgadget:
1 | kali:Desktop # ROPgadget --binary pwn4 --only 'pop|ret' |
这里注意一下原因:我们需要找出 pop | ret
来进行传值,而上述只有rdi
是可以存入数据,rbp
和r15
是called saved
然后我们还需要找到$0
的位置和调用system函数的位置
1 | kali:Desktop # ROPgadget --binary pwn4 --string '\$0' |
现在可以开始写脚本:
1 | from pwn import * |
得到flag{264bc50112318cd6e1a67b0724d6d3af}
Crypto
easy_crypto
1 | 0010 0100 01 110 1111011 11 11111 010 000 0 001101 1010 111 100 0 001101 01111 000 001101 00 10 1 0 010 0 000 1 01111 10 11110 101011 1111101 |
打开链接,发现这样的一段字符串,可以看出是莫斯电码,
根据上表进行相应的解码程序:
1 | #owner=houhuiting |
解出flag:FLAG{M0RSE_CODE_1S_INTEREST1N9!}
但是交上去是错的,换成小写试试,flag{m0rse_code_1s_interest1n9!}
成功
散乱的密文
lf5{ag024c483549d7fd@@1}
一张纸条上凌乱的写着2 1 6 5 3 4
2 | 1 | 6 | 5 | 3 | 4 |
---|---|---|---|---|---|
l | f | 5 | { | a | g |
0 | 2 | 4 | c | 4 | 8 |
3 | 5 | 4 | 9 | d | 7 |
f | d | @ | @ | 1 | } |
按照上述顺序弄出,得到flag{52048c453d794df1}
ps: 将后面两个@@去掉
凯撒部长的奖励
给出一串字符串:
1 | MSW{byly_Cm_sIol_lYqUlx_yhdIs_Cn_Wuymul_il_wuff_bcg_pCwnIl_cm_u_Yrwyffyhn_guh_cz_sio_quhn_ni_ayn_bcm_chzilguncihm_sio_wuh_dich_om} |
直接凯撒解密:
1 | SYC{here_Is_yOur_rEwArd_enjOy_It_Caesar_or_call_him_vIctOr_is_a_Excellent_man_if_you_want_to_get_his_informations_you_can_join_us} |
一段base64
打开解题链接,发现有个flag.txt
,说是base64
,直接解码(用在线网站解码的话很容易卡死,可能是数据太多)
这里决定用python脚本来完成解密,后面紧跟着一堆加密形式,在脚本中呈现效果
1 | #coding=utf-8 |
flag{ctf_tfc201717qwe}
.!?
一个ook形式的加密,直接在线解密
+[]-
一段brainfuck加密,还是在线解密
奇怪的密码
看到这种没见过的古典密码,习惯先看看ASCII,看上面的字符串,€符号像{,那么前面四个字母可能就是flag
字母 | ASCII | 字母 | ASCII |
---|---|---|---|
g | 103 | f | 102 |
n | 110 | l | 108 |
d | 100 | a | 97 |
k | 107 | g | 103 |
发现,这四个貌似间隔是1,2,3,4
所以想着是不是顺次替换,直接在python上通过chr
会产生报错,因为€的编码是8364,chr只能处理256之内的ASCII,所以我们将相应编码通过程序得到:
102 108 97 103 8359 108 101 105 95 99 105 95 106 105 97 109 105
然后通过在线工具进行解密:
得到文本信息:flag₧lei_ci_jiami
尝试flag格式,最后得到flag{lei_ci_jiami}
托马斯.杰斐逊
用一般方法试着解密,发现结果是错误的。
百度一下托马斯·杰斐逊,发现:
现在开始直接利用该方法进行解密:
先将字母表按照密钥顺序排列:
1
2
3
4
5
6
7
8
9
10
11
12
13
142: <KPBELNACZDTRXMJQOYHGVSFUWI <
5: <IHFRLABEUOTSGJVDKCPMNZQWXY <
1: <ZWAXJGDLUBVIQHKYPNTCRMOSFE <
3: <BDMAIZVRNSJUWFHTEQGYXPLOCK <
6: <AMKGHIWPNYCJBFZDRUSLOQXVET <
4: <RPLNDVHGFCUKTEBSXQYIZMJWAO <
9: <QWATDSRFHENYVUBMCOIKZGJXPL <
7: <GWTHSPYBXIZULVKMRAFDCEONJQ <
8: <NOZUTWDCVRJLXKISEFAPMYGHBQ <
14: <XPHKZGJTDSENYVUBMLAOIRFCQW <
10: <WABMCXPLTDSRJQZGOIKFHENYVU <
13: <BMCSRFHLTDENQWAOXPYVUIKZGJ <
11: <XPLTDAOIKFZGHENYSRUBMCQWVJ <
12: <TDSWAYXPLVUBOIKZGJRFHENMCQ <然后根据密文将每行的首字母变为相应密文
1
2
3
4
5
6
7
8
9
10
11
12
13
14HGVSFUWIKPBELNACZDTRXMJQOY
CPMNZQWXYIHFRLABEUOTSGJVDK
BVIQHKYPNTCRMOSFEZWAXJGDLU
TEQGYXPLOCKBDMAIZVRNSJUWFH
SLOQXVETAMKGHIWPNYCJBFZDRU
XQYIZMJWAORPLNDVHGFCUKTEBS
WATDSRFHENYVUBMCOIKZGJXPLQ
CEONJQGWTHSPYBXIZULVKMRAFD
RJLXKISEFAPMYGHBQNOZUTWDCV
QWXPHKZGJTDSENYVUBMLAOIRFC
GOIKFHENYVUWABMCXPLTDSRJQZ
LTDENQWAOXPYVUIKZGJBMCSRFH
ENYSRUBMCQWVJXPLTDAOIKFZGH
SWAYXPLVUBOIKZGJRFHENMCQTD得到
flag{XSXSBUGKUADMIN}
输入发现不对,但题目明确说了是解密的内容,最后发现flag是小写,
flag{xsxsbugkuadmin}
zip伪加密
直接在winhex中修改:
将图中所示改成00即可
解压得到flag{Adm1N-B2G-kU-SZIP}
告诉你个秘密(ISCCCTF)
得到下面这样的字符串:
1 | 63 6A 56 35 52 79 42 73 63 44 6C 4A 49 45 4A 71 54 53 42 30 52 6D 68 43 |
看起来就像是16进制,使用16进制进行编码,然后将其变为ASCII
1 | cjV5RyBscDlJIEJqTSB0RmhCVDZ1aCB5N2lKIFFzWiBiaE0g |
开始以为是md5,发现不能解密,尝试常用的加密方式进行解密,发现是base64,
1 | r5yG lp9I BjM tFhB T6uh y7iJ QsZ bhM |
发现r5yg中间包含的是字母T,将所有的解出为tongyuan
,
发现不对,试试大写:TONGYUAN
,发下flag格式就是大写
这不是md5
1 | 66 6c 61 67 7b 61 65 37 33 35 38 37 62 61 35 36 62 61 65 66 35 7d |
发现跟上题思路类似,解出flag{ae73587ba56baef5}
贝斯家族
1 | @iH<,{bdR2H;i6*Tm,Wx2izpx2! |
将知道的base16,32,64都尝试一遍,发现不能解码,尝试base58,91,最后发现是base91编码,解密网站是:http://ctf.ssleye.com/base91.html
,但是可能需要收费
还有一种选择是,下载这个解码软件:
http://base91.sourceforge.net/
flag{554a5058c9021c76}
富强民主
这是一个核心价值观编码
直接在线解密:flag{90025f7fb1959936}
python
得到两个文件
challenge.py
1 | from N1ES import N1ES |
N1ES.py
1 | # -*- coding: utf-8 -*- |
这题就当作经验积累吧,这是个Feistel
密码,他的加密和解密的算法是相同的,只是需要将密钥取反而已
1 | # -*- coding: utf-8 -*- |
还有一种方法就是直接都算法,进行暴力破解:
1 | import base64,string,N1ES |
进制转换
1 | d87 x65 x6c x63 o157 d109 o145 b100000 d116 b1101111 o40 x6b b1100101 b1101100 o141 d105 x62 d101 b1101001 d46 o40 d71 x69 d118 x65 x20 b1111001 o157 b1110101 d32 o141 d32 d102 o154 x61 x67 b100000 o141 d115 b100000 b1100001 d32 x67 o151 x66 d116 b101110 b100000 d32 d102 d108 d97 o147 d123 x31 b1100101 b110100 d98 d102 b111000 d49 b1100001 d54 b110011 x39 o64 o144 o145 d53 x61 b1100010 b1100011 o60 d48 o65 b1100001 x63 b110110 d101 o63 b111001 d97 d51 o70 d55 b1100010 d125 x20 b101110 x20 b1001000 d97 d118 o145 x20 d97 o40 d103 d111 d111 x64 d32 o164 b1101001 x6d o145 x7e |
直接python脚本解密即可
1 | #coding=utf-8 |
得到Welcome to kelaibei. Give you a flag as a gift. flag{1e4bf81a6394de5abc005ac6e39a387b} . Have a good time~
affine
题目是仿射,所以猜想是flag里面内容需要仿射密码,用脚本解决
1 | #coding=utf-8 |
得到flag:
1 | flag{affineshift} |
Crack it
下载一个shadow文件,查一下有关信息:
Linux操作系统下有一个文件负责所有用户的密码。那就是shadow。该文件的权限必须设置为:-r- — — (400)或者 -rw — —(600)即:Linux /etc/shadow文件是只有系统管理员才有权利进行查看和修改的文件。
使用more命令查看其中一些基本信息:
1 | root@DESKTOP-OORTB87:/mnt/c/Users/X1TABLET/Desktop# more shadow root:$6$HRMJoyGA$26FIgg6CU0bGUOfqFB0Qo9AE2LRZxG8N3H.3BK8t49wGlYbkFbxVFtGOZqVIq3qQ6k0oetDbn2aVzdhuVQ6US.:17770:0:99999:7::: |
这里使用kali中john工具进行密码爆破:
1 | root@DESKTOP-OORTB87:/mnt/c/Users/X1TABLET/Desktop# john shadow Using default input encoding: UTF-8 Loaded 1 password hash (sha512crypt, crypt(3) $6$ [SHA512 256/256 AVX2 4x]) Cost 1 (iteration count) is 5000 for all loaded hashes Will run 4 OpenMP threads Proceeding with single, rules:Single Press 'q' or Ctrl-C to abort, almost any other key for status Warning: Only 14 candidates buffered for the current salt, minimum 16 needed for performance. Warning: Only 10 candidates buffered for the current salt, minimum 16 needed for performance. Warning: Only 15 candidates buffered for the current salt, minimum 16 needed for performance. Almost done: Processing the remaining buffered candidate passwords, if any. Warning: Only 8 candidates buffered for the current salt, minimum 16 needed for performance. Proceeding with wordlist:/usr/share/john/password.lst, rules:Wordlist hellokitty (root) //这里有内容 1g 0:00:00:04 DONE 2/3 (2019-10-11 19:50) 0.2427g/s 1337p/s 1337c/s 1337C/s ilovegod..ford Use the "--show" option to display all of the cracked passwords reliably Session completed |
ps:
如果之前已经执行过上面命令,想再次看结果,可以使用john shadow --show
所以flag{hellokitty}
RSA
1 | N : 460657813884289609896372056585544172485318117026246263899744329237492701820627219556007788200590119136173895989001382151536006853823326382892363143604314518686388786002989248800814861248595075326277099645338694977097459168530898776007293695728101976069423971696524237755227187061418202849911479124793990722597 |
e比较大,使用维纳攻击获得d,使用rsa-wiener-attack工具求出d,
ps:
开始本来想着使用yafu
求出p,q
,但是分解不出来。
下载链接:https://github.com/pablocelayes/rsa-wiener-attack
修改其中的RSAwienerHacker.py
:
1 | if __name__ == "__main__": |
d = 8264667972294275017293339772371783322168822149471976834221082393409363691895
最后直接用脚本解密即可:
1 | #coding:utf-8 |
得到flag{Wien3r_4tt@ck_1s_3AsY}
来自宇宙的信号
还是积累太少啊。这是标准银河密码
对照得到flag{nopqrst}