首页 > 编程语言 >[PHP](MD5、sha1)比较漏洞-笔记

[PHP](MD5、sha1)比较漏洞-笔记

时间:2023-05-24 19:13:50浏览次数:48  
标签:字符 sha1 字符串 hexString2 hexString1 PHP ASCII 比较 MD5

PhP (MD5、sha1)比较漏洞(弱比较、强比较、强碰撞)

弱比较

md5和sha1弱比较都是利用php解析哈希值以“0E”开头的特性,结果都为0符合参数1的字符串值和参数2的字符串值不相等,但md5值相等。

如:240610708,aabg7XSs,aabC9RqS,s878926199a这四段字符串MD5编码后结果分别对应

240610708:0E462097431906509019562988736854

aabg7XSs:0E087386482136013740957780965295

aabC9RqS:0E041022518165728065344349536299

s878926199a:0E545993274517709034328855841020

而在php代码中处理哈希字符串时,会把“0E”开头的哈希值都解析为0,比较时0=0为true绕过

同理使用sha1加密的值为)0E开头的字符串有如下:

aaroZmOk,aaK1STfy,aaO8zKZF,aa3OFF9m

#coding=utf-8
<?php
error_reporting(0);
include "flag.php";

$a = $_POST['a'];
$b = $_POST['b'];


if($a != $b && md5($a) == md5($b)){
    echo $flag;
}

/*
if($a != $b && sha1($a) == sha1($b)){
    echo $flag;
}
*/

?>

payload:

MD5:a=240610708&b=aabg7XSs
SHA1: a=aaroZmOk&b=aaK1STfy

强比较

使用php的强比较类型来解析的话,就是除了比较值,也比较类型。弱比较只比较值,不比较类型

所以上面的方法就失效了,我们可以使用数组来绕过强比较,因为md5和sha1无法计算数组,但不会报错,会输出null,所以我们可以使用“空类型=空类型,null=null“来绕过强比较的比较类型

#coding=utf-8
<?php
error_reporting(0);
include "flag.php";

$a = $_POST['a'];
$b = $_POST['b'];


if($a !== $b && md5($a) === md5($b)){
    echo $flag;
}

/*
if($a !== $b && sha1($a) === sha1($b)){
    echo $flag;
}
*/

?>

payload:

/* 
在php中,变量名后加个中括号就代表这个变量的值为数组
如: $demo[] = 123;
*/
MD5 and SHA1:a[]=1&b[]=2

强碰撞

强碰撞我现在还是不怎么理解,只是从其他博主的文章解释和下面大佬写的一段代码分析。

它的工作原理可以分为以下几个步骤:

首先,我们有一个hex字符串,类似于密码一样的形式。

然后,我们将这个字符串分割成两个字符一组的形式,每两个字符代表一个十六进制数。

接着,我们将每个两位的十六进制数转换成对应的十进制数。

然后,将这些十进制数转换成相应的 ASCII 字符。

最后,将转换后的 ASCII 字符写入二进制文件,以便我们可以保存和使用。

这个是将hex写入到bin文件的python脚本源码:

#!coding:utf-8
hexString1 = '4dc968ff0ee35c209572d4777b721587d36fa7b21bdc56b74a3dc0783e7b9518afbfa200a8284bf36e8e4b55b35f427593d849676da0d1555d8360fb5f07fea2'
hexString2 = '4dc968ff0ee35c209572d4777b721587d36fa7b21bdc56b74a3dc0783e7b9518afbfa202a8284bf36e8e4b55b35f427593d849676da0d1d55d8360fb5f07fea2'

hexList1 = []  # 存储hexString1拆分后的每个字符
intList1 = []  # 存储hexList1转换成的整数
asciiString1 = ''  # 存储转换后的ASCII字符串

# 将hexString1拆分为每两个字符,存储到hexList1中
while True:
    intString1 = hexString1[0:2]  # 获取hexString1的前两个字符
    hexString1 = hexString1[2:]  # 移除已获取的字符
    hexList1.append(intString1)  # 将获取的字符添加到hexList1中
    if hexString1 == '':
        break

# 将hexList1中的每个字符转换为整数,并存储到intList1中
for i in hexList1:
    intList1.append(int(i, 16))

# 将intList1中的每个整数转换为对应的ASCII字符,并拼接到asciiString1中
for j in intList1:
    asciiString1 += chr(j)

# 将转换后的ASCII字符串写入名为"1.bin"的二进制文件中
with open('1.bin', 'w') as f:
    f.write(asciiString1)

hexList2 = []  # 存储hexString2拆分后的每个字符
intList2 = []  # 存储hexList2转换成的整数
asciiString2 = ''  # 存储转换后的ASCII字符串

# 将hexString2拆分为每两个字符,存储到hexList2中
while True:
    intString2 = hexString2[0:2]  # 获取hexString2的前两个字符
    hexString2 = hexString2[2:]  # 移除已获取的字符
    hexList2.append(intString2)  # 将获取的字符添加到hexList2中
    if hexString2 == '':
        break

# 将hexList2中的每个字符转换为整数,并存储到intList2中
for i in hexList2:
    intList2.append(int(i, 16))

# 将intList2中的每个整数转换为对应的ASCII字符,并拼接到asciiString2中
for j in intList2:
    asciiString2 += chr(j)

# 将转换后的ASCII字符串写入名为"2.bin"的二进制文件中
with open('2.bin', 'w') as f:
    f.write(asciiString2)

这一段代码是将生成的2进制文件内容再次进行url编码输出:

#!coding:utf-8
import urllib 

urlString1=''
urlString2 = ''

for line in open('1.bin'):
    urlString1 +=  urllib.quote(line)

for line in open('2.bin'):
    urlString2 +=  urllib.quote(line)

print urlString1
print urlString2

参考:

https://www.cnblogs.com/kuaile1314/p/11968108.html

https://blog.csdn.net/EC_Carrot/article/details/109525162

标签:字符,sha1,字符串,hexString2,hexString1,PHP,ASCII,比较,MD5
From: https://www.cnblogs.com/ping-ka/p/17429252.html

相关文章

  • 关于PHP正则表达式这回事
    ......
  • php特性第一天
    目录899091929394959697989989preg_match()返回pattern的匹配次数。它的值将是0次(不匹配)或1次,因为preg_match()在第一次匹配后将会停止搜索。preg_match_all()不同于此,它会一直搜索subject直到到达结尾。如果发生错误preg_match()返回FALSE。get方式传入num参数,然后通......
  • php特性第二天
    99array_push()函数向第一个参数的数组尾部添加一个或多个元素(入栈),然后返回新数组的长度。该函数等于多次调用$array[]=$value。in_array()函数搜索数组中是否存在指定的值。(注意:in_array()函数有漏洞没有设置第三个参数就可以形成自动转换)file_put_contents()函......
  • 制作一个生产环境可用的PHP基础镜像
    目录引言了解PHP基础镜像需求分析以及镜像选择构建准备最终的Dockerfile引言初学docker一定会觉得Dockerfile很难,其实只是无从下手的缘故。最好的学习方法就是看完每个Dokerfile指令的作用,然后不要急着去搞清楚,直接挑选一个你比较熟悉的服务软件动手自己制作一个。最......
  • openbiz PHP开源框架,企业级应用的功能基本都有了
    [url]http://www.iteye.com/topic/1128832[/url]openbizPHP开源框架,企业级应用的功能基本都有了我使用了一段时间,感觉还不错,现在推荐大家试试开源下载地址:http://code.google.com/p/openbiz-cubiQ群214408120[img]http://dl.iteye.com/upload/attach......
  • centos7安装erlang、rabbitmq以及php扩展
    centos7安装erlang、rabbitmq以及php扩展标签(空格分隔):liunx,php安装Erlang版本:el7erlang-20.3.8.25erlang-20.3.8.25-1.el7.x86_64.rpm1.下载wget--content-disposition"https://packagecloud.io/rabbitmq/erlang/packages/el/7/erlang-20.3.8.25-1.el7.x86_64.rpm/d......
  • 【web 开发】PHP8中数组的序列化和反序列化
    前言数组的序列化(serialize)用来将数组的数据转换为字符串,以方便传递和数据库的存储。与之相对应的操作就是反序列化(unserialize),把字符串数据转换为数组加以使用。数组的序列化主要通过serialize()函数来完成。字符串的反序列化主要通过unserialize()函数来完成。对象的序列化与反序......
  • Graphpad Prism9.5.1 数据处理绘图软件详细安装教程 (含Win/Mac版)
    GraphPadPrismGraphPadPrism是一款非常专业强大的科研医学生物数据处理绘图软件,它可以将科学图形、综合曲线拟合(非线性回归)、可理解的统计数据、数据组织结合在一起,除了最基本的数据统计分析外,还能自动生成统计图。  安装教程下面就简单的介绍一下Win版的安装教程详细图文教程......
  • php反序列化逃逸
    之前就对字符串逃逸这一块理解的不是很深刻,下面通过一位师傅的博客来进一步深入理解一下有关php字符串逃逸的相关内容。贴上师傅的博客地址:https://blog.csdn.net/qq_45521281/article/details/107135706先来说一下什么是字符串逃逸,就是我们可以构造一些恶意代码,让其在反序列化......
  • xctf_easyphp
    easyphp类型:PHP代码审计1.审查传值2.观看分析条件从上往下看:1.if(isset($a)&&intval($a)>6000000&&strlen($a)<=3)2.if(isset($b)&&'8b184b'===substr(md5($b),-6,6))3.$c=(array)json_decode(@$_GET['c'])4.if(is_a......