BUUCTF WEB 强网杯 2019 随便注

2023-11-01

1:题目

2:解题

2.1:尝试点提交

        url变为:http://b61f33a4-644b-402a-9da5-4bdf8043f954.node4.buuoj.cn/?inject=1 

        可知传入的参数名为 inject,参数为1。

2.2:尝试万能钥匙

        输入:1' or '1'='1';#      可得到所有数据,但没有flag。

 2.3:尝试联合查询

        输入:1' union select 1,2;#

         过滤了select、update、delete、drop、insert、where、点。

2.4:尝试查询数据库

        输入:1';show databases;#

得到数据库:ctftraining、information_schema、mysql、performance_schema、supersqli、test

2.5:尝试查询表

        输入:1';show tables;#

        得到表:1919810931114514、words。

2.6:尝试查询表1919810931114514的列

        输入:1';show columns from `1919810931114514`;#

         得到表1919810931114514的列为flag,可知flag在1919810931114514表中。

注:SQL语句中有两类特殊字符:关键字、保留字

关键字:在Mysql中具有特殊含义,比如alter、static、cache。虽然具有特殊含义,但是还是可以作为Mysql中的标识符来使用的。例如你创建一个表名为static的表并没有什么问题,但不推荐这么做。

保留字:是Mysql自身保留的标识符,例如select、insert。这类字在Mysql中就比较强势了,一般情况下是不允许使用的,非要使用,则加反引号(键盘tab键上面,数字1左边的那个按键),`select` 即可作为表名了。

纯数字:纯数字作为表名和字段名也必须加反引号,如`1919810931114514`

(要尽量避免使用关键字、保留字、纯数字来作为表名和字段名)

2.7:尝试查询表words的列

        输入:1';show columns from words;#

         得到表words的列有:id、data,可知页面默认查询显示的为表words的内容,传入的inject参数为id值。

2.8:如何取得flag

2.8.1:方法一"16进制编码"

        思路:将 select * from `1919810931114514` 进行16进制编码,绕过过滤。

        输入: 

1';SET @a=0x73656c656374202a2066726f6d20603139313938313039333131313435313460;PREPARE execsql FROM @a;EXECUTE execsql;#

        原理解释:

        2.8.1.1:十六进制编码绕过 select 过滤

        MYSQL可以识别十六进制并对其进行自动转换。

        select * from `1919810931114514`十六进制编码为:

        0x73656c656374202a2066726f6d20603139313938313039333131313435313460

        2.8.1.2:SQL语法之“用户变量”  

        用户变量:用户自己定义的变量,我们可以给用户变量分配值,并且可用在任何可以正常使用标量表达式的地方。用户变量可以作用于当前整个连接,但是当当前连接断开后,其所定义的用户变量都会消失。

        定义变量:@变量名

        变量赋值:SET @userName = (SELECT name FROM user WHERE id = 2);

                          SET @userName := (SELECT name FROM user WHERE id = 2);

                          SELECT @userName := (SELECT name FROM user WHERE id = 2);

        对于SET,可以使用=或:=来赋值,对于SELECT只能使用:=来赋值。

        因为SELECT语句中,等号会被看做是比较操作符。

        2.8.1.3:SQL语法之“预处理”

       SQL语句分两种:即时 SQL、预处理SQL

  即时SQL:一次编译,单次运行

        一条 SQL 在数据库接收到后执行的流程为:词法和语义解析 -> 优化 SQL 语句,制定执行计划 -> 执行并返回结果。

       预处理 SQL:一次编译、多次运行。不会直接执行 SQL 语句,而是先将 SQL 语句编译,生成执行计划,然后通过 Execute 命令携带 SQL 参数执行 SQL 语句。

        绝大多数情况下,某一条 SQL 语句可能会被反复调用执行,或者每次执行的时候只有个别的值不同。如果每次都需要经过上面的词法语义解析、语句优化、制定执行计划等,则效率就明显不行了。所谓预编译语句就是将此类 SQL 语句中的值用占位符?替代,可以视为将 SQL 语句模板化或者说参数化,一般称这类语句叫Prepared Statements。 此外预编译语句能防止 SQL 注入。   

        定义:PREPARE statement_name FROM preparable_SQL_statement;

        执行:EXECUTE statement_name USING @var_name1 ,@var_name2 ...; 

        删除:DEALLOCATE/DROP PREPARE statement_name;

        注:DEALLOCATE、DROP都可以删除,每一次执行完EXECUTE时,养成好习惯,进行删除,释放执行中使用的所有数据库资源。

2.8.2:方法二"利用HANDLER语句"

        思路:MySQL 除了可以使用 select 查询表中的数据,也可使用 handler 语句查询数据。

        注入:1'; handler `1919810931114514` open; handler `1919810931114514` read first;#

        原理解释:        

        HANDLER语句使我们能够一行一行的浏览一个表中的数据,handler 语句并不具备 select 语句的所有功能,它是 MySQL 专用的语句,并没有包含到SQL标准中。

        语法:

        打开句柄:handler handler_table open;       

        查看数据:handler handler_table read first/next/prev/last;

        关闭句柄:handler handler_table close;

        具体参考:https://blog.csdn.net/qq_43427482/article/details/109898934

2.8.3:方法三"改表名"

        思路:因为页面默认查询显示的为表words的内容,可通过 rename 先把 words 表改名为其他的表名,再把 1919810931114514 表的名字改为 words ,给新 words 表添加新的列名 id ,id默认值为1,将 flag 改名为 data 。

        输入:1'; rename table words to word1; rename table `1919810931114514` to words; alter table words add id int(10) default 1; alter table words change flag data varchar(100); #

        这样再输入1,即可把flag值显示出来。

注 :不建议使用这种方法,如果在改表words名成功,但后面的改1919810931114514表名、加id列出错的话,将会很麻烦。更改数据库可能导致无法解题。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

BUUCTF WEB 强网杯 2019 随便注 的相关文章

随机推荐

  • 兔子生兔子问题(java实现)

    一对兔子 从出生后第3个月起每个月都生一对兔子 小兔子长到第三个月后每个月又生一对兔子 假如兔子都不死 问第n个月的兔子对数为多少 分析 第一个月是1对第二个月是1对第三个月是1 1 2对第四个月是2 1 3对第五个月是3 2 5对第六个月
  • MybatisPlus 多租户架构(SaaS)实现

    引言 读写分离要做的事情就是对于一条SQL该选择哪个数据库去执行 至于谁来做选择数据库这件事儿 无非两个 要么中间件帮我们做 要么程序自己做 因此 一般来讲 读写分离有两种实现方式 第一种是依靠中间件 比如 MyCat 也就是说应用程序连接
  • 50_Pandas读取 Excel 文件 (xlsx, xls)

    50 Pandas读取 Excel 文件 xlsx xls 要使用 pandas 将 Excel 文件 扩展名 xlsx xls 作为 pandas DataFrame 读取 请使用 pandas read excel 函数 这里 将描述以
  • python: logHelper

    encoding utf 8 版权所有 2023 涂聚文有限公司 许可信息查看 https docs python org 3 library logging html 描述 https www programcreek com pytho
  • 北京大学肖臻老师《区块链技术与应用》公开课笔记17——ETH数据结构篇1(状态树1)

    北京大学肖臻老师 区块链技术与应用 公开课笔记 以太坊数据结构篇1 状态树1 对应肖老师视频 click here 全系列笔记请见 click here 以太坊数据结构篇1 状态树2请见 click here About Me 点击进入我的
  • uniapp swiper 指示点位置修改 亲测有用

    只需要设置swiper的高度高于子元素swiper item就OK 有效回来点个赞哈
  • 解决UE4缓存使C盘膨胀的问题

    大家好 可能很多新手使用UE4的时候会发现C盘越来越小了 那是因为UE4引擎的缓存文件默认保存在C盘的缘故 下面来告诉大家怎么解决这个问题 概述 一 出现的问题 UE4的缓存文件会导致C盘膨胀 二 解决的方式 请严格按照下列步骤来执行 1
  • springdata JPA@Query注解及@Modifying注解

    Query注解查询适用于所查询的数据无法通过关键字查询得到结果的查询 这种查询可以摆脱像关键字查询那样的约束 将查询直接在相应的接口方法中声明 结构更为清晰 这是Spring Data的特有实现 索引参数与命名参数 1 索引参数如下所示 索
  • c#操作符operate的用法

    operate operate 的用法 看代码 public struct CorePoint
  • 用户自定义类型(User-defined Type)参数的传递

    用户自定义类型 User defined Type 参数的传递 用户自定义类型在VB中是一种重要的数据类型 它为编程者提供了很大的灵活性 使开发人员可以根据需要构造自己的数据结构 它相当于C C 中的结构类型 structure 在VB中
  • 转【】浅谈sql中的in与not in,exists与not exists的区别_

    浅谈sql中的in与not in exists与not exists的区别 1 in和exists in是把外表和内表作hash连接 而exists是对外表作loop循环 每次loop循环再对内表进行查询 一直以来认为exists比in效率
  • 基于Cesium的实景三维模型动态更新-以3Dtiles为例(一)

    一 简介 Cesium众所周知 是一个前端的三维框架 本项目利用Cesium平台来实现实景三维模型的动态更新 不认识Cesium的同学戳这里 cesium中文网 学习cesiumjs 的好地方 伐罗密 实景三维模型 概括来讲就是倾斜摄影三维
  • CocosCreator-3D 3D物体触摸移动(跟随移动)

    版本 cocoscreator3 4 0 基本原理 通过触摸屏幕上的点生成一个射线 通过物理射线检测 获得是否点击到物体 通过射线的检测结果 raycastResults 获得碰撞点 hitPoint 设置物体的x z为碰撞点的x y即可
  • JSP分页处理

    作为代码萌新的我今天尝试做了一个JSP的分页处理 如果有什么不好的地方请在评论区留下建议 废话不多说 先看我做的效果图 我在查询数据的时候使用了异步AJAX 在数据绑定的时候使用的是vue 因为我感觉vue用来绑定数据更方便一点 分页插件使
  • java 实现SMS短信发送

    准备工作 注册账号 http sms webchinese cn reg shtml 查看短信密钥 代码实现 package com activiti test import org apache commons httpclient He
  • Eureka的黑白名单过滤机制(Eureka的注册黑白名单)

    参考链接 Eureka的注册黑白名单 不过这篇博文只提供了实现思路和大致 我这边帮忙把完整代码贴出来 通过springboot的autoconfigure实现 大致思路是用自己定义的Eureka注册包装类替换原来的Eureka注册类 当Eu
  • SpaceX预计到2022年Starlink用户将达到2000万,但最终达到了100万

    SpaceX的Starlink部门还没有接近实现客户和收入的预测 该公司在建立卫星网络之前与投资者分享了这一点华尔街日报报道今天出版 据报道 2015年的一份题为 SpaceX用来从投资者那里筹集资金 的报告预计 到2022年 Starli
  • C++ String去除头尾空格 实现trim()方法

    虽然C 11的标准库中并没有提供trim 方法 但我们可以使用string的find first not of 和find last not of方法实现trim include
  • centos linux介绍,关于CentOS使用的简介

    CentOS对大家来说已经很熟悉 什么是CentOS呢 CentOS Community ENTerprise Operating System 是Linux发行版之一 它是来自于Red Hat Enterprise Linux依照开放源代
  • BUUCTF WEB 强网杯 2019 随便注

    1 题目 2 解题 2 1 尝试点提交 url变为 http b61f33a4 644b 402a 9da5 4bdf8043f954 node4 buuoj cn inject 1 可知传入的参数名为 inject 参数为1 2 2 尝试