PHP在CTF中的应用场景

简介: 本文介绍了PHP在CTF(Capture The Flag)比赛中的应用,重点讲解了PHP常用函数和技巧。包括字符串查找、替换、数组操作、文件读写以及条件判断等。还提到了如何利用特定函数进行安全绕过,如`strpos`的换行绕过、`preg_replace`的双写绕过、`str_replace`的过滤绕过等。此外,文中还讨论了变量大小写敏感性、类型转换函数如`intval`和`is_numeric`的使用,以及安全检查和绕过方法。最后,提到了代码高亮函数`highlight_file`和一些安全检查的例子。

PHP在CTF中的应用场景

PHP常用函数

strpos("1","2")1中查找二并返回索引或false
str_replace("1","2","3")3中找1并替换为2
define()定义大小写不敏感的常量
!==不全等,完全不同
<?php 
$colors = array("red","green","blue","yellow"); 
foreach ($colors as $value) 
  echo "$value <br>";
array()
count() 函数用于返回数组的长度(元素数
htmlspecialchars() 函数把特殊字符转换为 HTML 实体
(通过 PHP trim() 函数)去除用户输入数据中不必要的字符(多余的空格、制表符、换行)
(通过 PHP stripslashes() 函数)删除用户输入数据中的反斜杠(\)

这些超全局变量是:
$GLOBALS
$_SERVER
$_REQUEST
$_POST
$_GET
$_FILES
$_ENV
$_COOKIE
$_SESSION
includerequire 语句是相同的,除了错误处理方面
require 会生成致命错误(E_COMPILE_ERROR)并停止脚本
include 只生成警告(E_WARNING),并且脚本会继续
readfile()读取文件并输出文字
fopen()fclose()fwrite()
fread() 的第一个参数包含待读取文件的文件名,第二个参数规定待读取的最大字节数
fgets()读取文件首行
feof() 函数检查是否已到达 "end-of-file" (EOF)
模式 描述
r 打开文件为只读。文件指针在文件的开头开始。
w 打开文件为只写。删除文件的内容或创建一个新的文件,如果它不存在。文件指针在文件的开头开始。
a 打开文件为只写。文件中的现有数据会被保留。文件指针在文件结尾开始。创建新的文件,如果文件不存在。
x 创建新文件为只写。返回 FALSE 和错误,如果文件已存在。
r+ 打开文件为读/写、文件指针在文件开头开始。
w+ 打开文件为读/写。删除文件内容或创建新文件,如果它不存在。文件指针在文件开头开始。
a+ 打开文件为读/写。文件中已有的数据会被保留。文件指针在文件结尾开始。创建新文件,如果它不存在。
x+ 创建新文件为读/写。返回 FALSE 和错误,如果文件已存在。

==php中所有用户自定义的函数类和关键词(if else echo)不区分大小写==但是变量大小写敏感

php is_numeric()绕过 [判断是否为数字或数字字符串]

用url编码中的空字符%00或%20进行绕过

strpos(find,found,offset查询位置)查询函数 有返回<0,max>,无返回false
我们可以利用换行绕过(%0a)

$i='666';
$ii=$_GET['n'];
if(strpos($i,$ii,offset:'0')){
   
    echo $flag;
}//?n=%0a666

preg_replace("$$a",'$b',$c);从c中找到a并把a替换为b 一般会用双写绕过和大小写 ```php $dir=str_replace(array('../','./'),' ',$_GET['dir']); //将../和 ./都过滤掉,可双写为....// ..// ``` md5($$a)===md5($b) $a!=$b NULL===NULL a=name[],b=password[] md5(array)->null

MD5(‘QNKCDZO’)=0e8304004519 MD5(‘240610708’)=0e4620074319

intval(var:,base:)强制转换为整数(base:0时会检测var格式以0开头转换为8进制,包含0x用16进制,否则用10进制)

$i='666';
$ii=$_GET['n'];
if(intval(var:$ii==$i,base:0)){
   
echo $flag;
}//传入?n=0x29a(666的十六进制)
$whitelist=[1,2,3];
$page=$_GET['i'];
if(in_array($page,$whitelist)){
   
    echo 'yes';
}//?i=1白名单形式
if(isset($_GET['n'])){
   
    $num=$_GET['n'];
    if(preg_match("/[0-9]/",$num)){
   
        die("no no no !");
    }
    if(intval($n,0)){
   //第二个参数是转换为几进制,如果为零则按照第一个参数进行输出
//有intval()可传入小数
        echo $flag;
    }
}//i是严格匹配大小写,m是换行匹配
highlight_file(_FILE):
if(isset($_GET['num'])){
   
    $num=$_GET['num'];
    if($num==="4476"){
   
    die("nonono!");
    }
    if (preg_match("/[a-z]/i",$num)){
   
    die("nono no!"):
    }
    if(strpos($num,0)){
   
    die("nono no!"):
    }
    if (intval($num,'0')===4476)(
    echo $flag;
}//?num=4476.0  ?num=%204476  空格换行,正则没有m
目录
相关文章
|
2月前
|
设计模式 PHP
PHP中的设计模式:单一职责原则在软件开发中的应用
【10月更文挑战第8天】 在软件开发中,设计模式是解决常见问题的经验总结,而单一职责原则作为面向对象设计的基本原则之一,强调一个类应该只有一个引起变化的原因。本文将探讨单一职责原则在PHP中的应用,通过实际代码示例展示如何运用该原则来提高代码的可维护性和可扩展性。
34 1
|
18天前
|
SQL 安全 前端开发
PHP与现代Web开发:构建高效的网络应用
【10月更文挑战第37天】在数字化时代,PHP作为一门强大的服务器端脚本语言,持续影响着Web开发的面貌。本文将深入探讨PHP在现代Web开发中的角色,包括其核心优势、面临的挑战以及如何利用PHP构建高效、安全的网络应用。通过具体代码示例和最佳实践的分享,旨在为开发者提供实用指南,帮助他们在不断变化的技术环境中保持竞争力。
|
22天前
|
IDE PHP 开发工具
【PHP开发专栏】Xdebug在PHP调试中的应用
Xdebug 是一个功能强大的 PHP 扩展,提供调试、代码分析和性能分析等功能。本文介绍了 Xdebug 的基本概念、安装配置方法及在 PHP 调试中的应用技巧,包括断点调试、堆栈跟踪、远程调试和性能分析等。通过合理使用 Xdebug,可以显著提高调试效率和代码质量。
31 3
|
24天前
|
安全 编译器 PHP
PHP 8新特性解析与实践应用####
————探索PHP 8的创新功能及其在现代Web开发中的实际应用
|
29天前
|
测试技术 持续交付 PHP
PHP在Web开发中的应用与最佳实践###
【10月更文挑战第25天】 本文将深入探讨PHP在现代Web开发中的应用及其优势,并分享一些最佳实践来帮助开发者更有效地使用PHP。无论是初学者还是有经验的开发者,都能从中受益。 ###
58 1
|
1月前
|
设计模式 存储 数据库连接
PHP中的设计模式:单例模式的深入理解与应用
【10月更文挑战第22天】 在软件开发中,设计模式是解决特定问题的通用解决方案。本文将通过通俗易懂的语言和实例,深入探讨PHP中单例模式的概念、实现方法及其在实际开发中的应用,帮助读者更好地理解和运用这一重要的设计模式。
19 1
|
2月前
|
前端开发 安全 关系型数据库
PHP在Web开发中的应用及其优势###
【10月更文挑战第16天】 — 本文探讨了PHP在现代Web开发中的广泛应用及其显著优势。通过分析PHP的核心特性,如灵活性、易用性和广泛的应用支持,阐述了为何PHP成为众多开发者和公司的首选技术。文章还介绍了PHP与其他编程语言的比较,并展望了其未来的发展趋势。 ###
46 2
|
2月前
|
设计模式 PHP 开发者
PHP中的设计模式:桥接模式的解析与应用
在软件开发的浩瀚海洋中,设计模式如同灯塔一般,为开发者们指引方向。本文将深入探讨PHP中的一种重要设计模式——桥接模式。桥接模式巧妙地将抽象与实现分离,通过封装一个抽象的接口,使得实现和抽象可以独立变化。本文将阐述桥接模式的定义、结构、优缺点及其应用场景,并通过具体的PHP示例代码展示如何在实际项目中灵活运用这一设计模式。让我们一起走进桥接模式的世界,感受它的魅力所在。
|
2月前
|
小程序 物联网 API
PHP在哪些领域有应用?
【10月更文挑战第11天】PHP在哪些领域有应用?
64 2
|
2月前
|
运维 监控 物联网
PHP的应用的应用场景
【10月更文挑战第11天】PHP的应用的应用场景
21 1