zoukankan      html  css  js  c++  java
  • HANDLER进行堆叠注入

    HANDLER进行堆叠注入

    [GYCTF2020]Blacklist

    image-20201120161425003

    过滤了很多的关键词

    image-20201120161508722

    你可以尽情堆叠,但是令人难过的是你读不出来,也不能像强网杯那样alert改名字。

    但是我们还有handler这个东西

    mysql除可使用select查询表中的数据,也可使用handler语句,这条语句使我们能够一行一行的浏览一个表中的数据,不过handler语句并不具备select语句的所有功能。它是mysql专用的语句,并没有包含到SQL标准中。
    HANDLER语句提供通往表的直接通道的存储引擎接口,可以用于MyISAM和InnoDB表。

    HANDLER tbl_name OPEN [ [AS] alias]
     
    HANDLER tbl_name READ index_name { = | <= | >= | < | > } (value1,value2,...)
        [ WHERE where_condition ] [LIMIT ... ]
    HANDLER tbl_name READ index_name { FIRST | NEXT | PREV | LAST }
        [ WHERE where_condition ] [LIMIT ... ]
    HANDLER tbl_name READ { FIRST | NEXT }
        [ WHERE where_condition ] [LIMIT ... ]
     
    HANDLER tbl_name CLOSE
    
    通过HANDLER tbl_name OPEN打开一张表,无返回结果,实际上我们在这里声明了一个名为tb1_name的句柄。
    通过HANDLER tbl_name READ FIRST获取句柄的第一行,通过READ NEXT依次获取其它行。最后一行执行之后再执行NEXT会返回一个空的结果。
    通过HANDLER tbl_name CLOSE来关闭打开的句柄。
    
    通过索引去查看的话可以按照一定的顺序,获取表中的数据。
    通过HANDLER tbl_name READ index_name FIRST,获取句柄第一行(索引最小的一行),NEXT获取下一行,PREV获取前一行,LAST获取最后一行(索引最大的一行)。
    
    通过索引列指定一个值,可以指定从哪一行开始。
    通过HANDLER tbl_name READ index_name = value,指定从哪一行开始,通过NEXT继续浏览。
    

    image-20201120162237893

    使用:

    ?inject=1';HANDLER `FlagHere` OPEN;HANDLER `FlagHere` READ FIRST;
    

    来读取内容,get到flag

    同时,这种解法也适用于强网杯

    [强网杯 2019]随便注

    show tables看看都有什么表。

    image-20201120165436885

    网上的wp有改表名的,也有预处理的,在此不再赘述,我们直接使用handler:

    image-20201120170055119

    数据库真是太美妙了

  • 相关阅读:
    [转]在Ubuntu 下安装Redis 并使用init 脚本启动
    [资源]PHP使用消息队列
    [转]reids客户端 redis-cli用法
    [转]redis.conf的配置解析
    【转】微信公共号开发,提示“该公众号暂时无法提供服务,请稍后再试”,如何解决?
    [转]php 解决json_encode中文UNICODE转码问题
    [资料]Keychain 获取设备唯一
    [转]PHP 获取服务器详细信息代码
    crontab任务取消发送邮件
    [转]php返回json数据中文显示的问题
  • 原文地址:https://www.cnblogs.com/DorinXL/p/14012013.html
Copyright © 2011-2022 走看看