Buuctf-Web-[极客大挑战 2019]Havefun 题解思路总结

2024-02-19 23:59

本文主要是介绍Buuctf-Web-[极客大挑战 2019]Havefun 题解思路总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

启动靶机
在这里插入图片描述

做题过程

第一步——查看源代码

看到此处有被注释掉的php代码
在这里插入图片描述

     <!--$cat=$_GET['cat'];echo $cat;if($cat=='dog'){echo 'Syc{cat_cat_cat_cat}';}-->

php采用c语言的语法,但有一些区别。

$cat

$符号的意思:表示一个自定义的普通变量
$加上字符串,就是一个变量名或对象名
拓展:
$$符号的意思:表示一个可变变量,用于储存变量的值

$_GET

$_GET变量是一个数组,内容是由HTTP GET方式发送的变量名和值
$_GET用于收集来自 method=“get” 的表单中的值。从带有GET 方法的表单发送的信息,对任何人都是可见的(会显示在浏览器的地址栏),并且对发送的信息量也有限制(最多 100 个字符)
注:
属于GET请求的有:from标签中method="get"
在使用 $_GET 变量时,所有的变量名和值都会显示在 URL 中。所以在发送密码或其他敏感信息时,不应该使用这个方法。不过,正因为变量显示在 URL 中,因此可以在收藏夹中收藏该页面。在某些情况下,这是很有用的

echo $cat;

echo
PHP中有两个基本的输出方式:echoprint
echo和print的区别:
1、echo - 可以输出一个或多个字符串
2、print - 只允许输出一个字符串,返回值总为 1
注:
echo 是一个语言结构,使用的时候可以不用加括号,也可以加上括号: echo 或 echo()。

Syc{dog_dog_dog_dog}这句话猜测是和后端有关的。

这一段的代码就提示我们,当cat=dog时,会输出一段东西。
那么此时输出的东西很可能就是和flag相关的。
所以我们接下来就先构造payload,将这段东西输出来看看。

第二步——构造payload

知识点:
1.相对路径和绝对路径
2.访问路径问题—带斜杠和不带斜杠的区别

方法一:直接在网页地址栏中构造payload

原先的地址

在这里插入图片描述
然后在地址后面加上

/?cat=dog

在这里插入图片描述

因为这里是绝对路径,所以要自己加一个斜杠后,再写上传递参数“?cat=dog”(由第一步源代码中的$_GET可以知道,此处为GET请求)

方法二:使用HackBar构造payload

点击“Load URL”,将地址栏url框下来
在这里插入图片描述
输入

?cat=dog   //(?表示传参)

在这里插入图片描述
然后点击“Execute”

得到flag
flag{e391e786-e24f-4b19-8cd4-651300cb0200}

思路总结

题目类型:

  1. 网页传参

做题步骤:

  1. 查看网页源代码
  2. 构造payload

这篇关于Buuctf-Web-[极客大挑战 2019]Havefun 题解思路总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/726426

相关文章

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Nginx Location映射规则总结归纳与最佳实践

《NginxLocation映射规则总结归纳与最佳实践》Nginx的location指令是配置请求路由的核心机制,其匹配规则直接影响请求的处理流程,下面给大家介绍NginxLocation映射规则... 目录一、Location匹配规则与优先级1. 匹配模式2. 优先级顺序3. 匹配示例二、Proxy_pa

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

python web 开发之Flask中间件与请求处理钩子的最佳实践

《pythonweb开发之Flask中间件与请求处理钩子的最佳实践》Flask作为轻量级Web框架,提供了灵活的请求处理机制,中间件和请求钩子允许开发者在请求处理的不同阶段插入自定义逻辑,实现诸如... 目录Flask中间件与请求处理钩子完全指南1. 引言2. 请求处理生命周期概述3. 请求钩子详解3.1

MySQL基本查询示例总结

《MySQL基本查询示例总结》:本文主要介绍MySQL基本查询示例总结,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Create插入替换Retrieve(读取)select(确定列)where条件(确定行)null查询order by语句li

SpringBoot项目Web拦截器使用的多种方式

《SpringBoot项目Web拦截器使用的多种方式》在SpringBoot应用中,Web拦截器(Interceptor)是一种用于在请求处理的不同阶段执行自定义逻辑的机制,下面给大家介绍Sprin... 目录一、实现 HandlerInterceptor 接口1、创建HandlerInterceptor实

Web技术与Nginx网站环境部署教程

《Web技术与Nginx网站环境部署教程》:本文主要介绍Web技术与Nginx网站环境部署教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Web基础1.域名系统DNS2.Hosts文件3.DNS4.域名注册二.网页与html1.网页概述2.HTML概述3.

Python使用Reflex构建现代Web应用的完全指南

《Python使用Reflex构建现代Web应用的完全指南》这篇文章为大家深入介绍了Reflex框架的设计理念,技术特性,项目结构,核心API,实际开发流程以及与其他框架的对比和部署建议,感兴趣的小伙... 目录什么是 ReFlex?为什么选择 Reflex?安装与环境配置构建你的第一个应用核心概念解析组件

Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例

《Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例》本文介绍Nginx+Keepalived实现Web集群高可用负载均衡的部署与测试,涵盖架构设计、环境配置、健康检查、... 目录前言一、架构设计二、环境准备三、案例部署配置 前端 Keepalived配置 前端 Nginx

Python MCPInspector调试思路详解

《PythonMCPInspector调试思路详解》:本文主要介绍PythonMCPInspector调试思路详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录python-MCPInspector调试1-核心知识点2-思路整理1-核心思路2-核心代码3-参考网址