当前位置: 首页 > news >正文

做花酒的网站网络营销策划书的结构

做花酒的网站,网络营销策划书的结构,网站设计网站建设专业,政府网站集约化建设总结目录 1、web104 2、web105 3、web106 4、web107 5、web108 1、web104 需要传入的 v1 和 v2 进行 sha1 加密后相等。 解法1: 这里都没有判断 v1 和 v2 是否相等,我们直接传入同样的内容加密后肯定也一样。 ?v21 post: v11 拿到 flag…

目录

1、web104

2、web105

3、web106

4、web107

5、web108


1、web104

需要传入的 v1 和 v2 进行 sha1 加密后相等。

解法1:

这里都没有判断 v1 和 v2 是否相等,我们直接传入同样的内容加密后肯定也一样。

?v2=1

post: 

v1=1

拿到 flag:ctfshow{bd4eea6b-872d-462c-b8f2-20f48d3ee652} 

解法2:

对于 php 强比较和弱比较:md5(),sha1() 函数无法处理数组,如果传入的为数组,会返回 NULL ,两个数组经过加密后得到的都是 NULL ,也就是相等的。

?v2[]=1

post:

v1[]=2

解法3:

对于某些特殊的字符串加密后得到的密文以 0e 开头,PHP 会当作科学计数法来处理,也就是 0 的 n 次方,得到的值比较的时候都相同。

下面是常见的加密后密文以 0e 开头的字符串:

md5:240610708:0e462097431906509019562988736854
QLTHNDT:0e405967825401955372549139051580
QNKCDZO:0e830400451993494058024219903391
PJNPDWY:0e291529052894702774557631701704
NWWKITQ:0e763082070976038347657360817689
NOOPCJF:0e818888003657176127862245791911
MMHUWUV:0e701732711630150438129209816536
MAUXXQC:0e478478466848439040434801845361sha1:10932435112: 0e07766915004133176347055865026311692244
aaroZmOk: 0e66507019969427134894567494305185566735
aaK1STfY: 0e76658526655756207688271159624026011393
aaO8zKZF: 0e89257456677279068558073954252716165668
aa3OFF9m: 0e36977786278517984959260394024281014729
0e1290633704: 0e19985187802402577070739524195726831799
?v2=aaroZmOk

 post:

v1=aa3OFF9m

2、web105

foreach 在 PHP 中用于遍历数组或对象:

key 和 value 分别表示数组中的键和对应的值。

foreach ($array as $value) {// 对 $value 进行操作
}foreach ($array as $key => $value) {// 对 $key 和 $value 进行操作
}

一眼看到使用了两个 $,直接将用户输入用作变量名,可能导致变量覆盖问题。

$$key=$$value;

代码中共有三个变量:$error,$flag,$suces

foreach($_GET as $key => $value){if($key==='error'){die("what are you doing?!");}

get 请求的 key(参数)不能是 error

foreach($_POST as $key => $value){if($value==='flag'){die("what are you doing?!");}

post 请求的 value(值)不能是 flag

(1)通过 die($error);  输出 flag,可以将 $error 覆盖为 $flag,payload:

?suces=flag
​ post: error=suces

get 传入 suces=flag,请求参数不是 error,因此不会触发第一个 die 函数;

接下来执行 $$key=$$value; 即 $suces=$flag,也就是将 $flag 的内容赋值给 $suces;

post 传入 error=suces,value 是 suces,不是 flag,因此也不会触发第二个 die 函数;

之后执行 $$key=$$value; 即 $error=$suces,也就是将 $suces 的内容赋值给 $error;

if(!($_POST['flag']==$flag)){die($error);
}

最后检查是否 post 提交了 flag 并且内容就是 $flag,显然是没有的,前面还有一个 ! ,因此 if 语句成立,执行第三个 die 函数,输出变量 $error 的内容,即我们 flag 的内容。

验证:

拿到 flag:ctfshow{d346b9f7-d63f-492c-b573-c7ed4c7394e4}

其实这里的这个 $suces 只是一个中间者,我们只要不使用 error,其他任何的参数名都是可以的。

比如:

?1=flag
error=1

(2)通过 die($suces); 输出 flag,将 $suces 覆盖为 $flag,payload:

?suces=flag&flag=

或者 

?suces=flag
post:flag=

一来就先将 $flag 的内容赋给 $suces,之后将 $flag 赋为空(null),使得 $_POST['flag']==$flag 成立,执行 echo "your are good".$flag."\n"; 和 die($suces); 进而输出 $suces,即 flag 的内容。

3、web106

新增:

$v1!=$v2

采用数组绕过:

?v2[]=1
post:v1[]=2

拿到 flag:ctfshow{a0d7580e-60f6-4a19-bef2-af27d8c2d017}

4、web107

parse_str() 函数:把查询字符串解析到变量中。

用法:parse_str(string,array)

参数描述
string必需。规定要解析的字符串。
array可选。规定存储变量的数组名称。该参数指示变量存储到数组中。

关于题目代码的详细解释:

parse_str($v1,$v2);

parse_str 函数将字符串 $v1 解析为变量并存储到数组 $v2 中。
$v1 是一个包含查询字符串的变量,例如:"flag=123&name=myon"。
解析后的结果将存储在数组 $v2 中,例如:$v2 将包含 ['flag' => '123', 'name' => 'myon']。 

if($v2['flag']==md5($v3)){echo $flag;}

$v2['flag'] 是从解析后的数组 $v2 中获取的 flag 参数值,检查 $v2['flag'] 是否等于 md5($v3) 即 v3 经过 md5 加密后的值,等于则输出 flag。

理解题目意思后,这里的 payload 就有很多,只要符合要求都可以:

?v3=123

post 传入:

v1=flag=202cb962ac59075b964b07152d234b70

其中 202cb962ac59075b964b07152d234b70 是 123 的 md5 加密值:

拿到 flag:ctfshow{b91751db-f7b7-40ae-b920-fd2e3edc8964}

5、web108

代码审计: 

ereg ("^[a-zA-Z]+$", $_GET['c'])

使用 ereg 函数检查 $_GET['c'] 是否只包含大小写字母,不满足直接 die。

if(intval(strrev($_GET['c']))==0x36d){echo $flag;
}

通过 strrev 函数将 $_GET['c'] 反转,使用 intval 将反转后的字符串转换为整数,检查该整数是否等于十六进制的 0x36d(十进制的 877),如果相等,则输出 $flag 的内容。

其中 ereg 函数存在 NULL 截断漏洞,我们可以使用 %00 进行截断,payload:

?c=a%00778

这样正则就只会匹配 %00 之前的内容,即匹配到 a,符合要求,函数返回 true,if 语句不成立,跳过 die 函数,payload 经 strrev 函数反转后变为 877%00a,因为是弱比较,会存在自动类型转换,经过 intval 转为整数 877,比较成立,输出 flag。

拿到 flag:ctfshow{9fb901bb-8855-4a17-b4bc-a587d28a3f15}

为什么 %00 前面还要有一个 a,而不能是空的呢?

由于截断前的内容为空,ereg 函数还是会返回 false,就像我们什么都没有传入一样。

http://www.ds6.com.cn/news/79238.html

相关文章:

  • 如何做网站logo 设置平滑seo查询源码
  • 哪些网站可以做爬虫实验最快新闻资讯在哪看
  • 郑州网站推广平台宁波seo快速优化教程
  • 张店网站制作百度seo公司
  • 网站收录查询入口seo网站诊断分析报告
  • 制作个人网站的六个步骤上海网站优化公司
  • 怎么用网吧电脑做网站服务器吗种子搜索器
  • 自己做的网站只能打开一个链接营销型网页设计
  • 长春网站建长春做网站seo人员招聘
  • 坪山网站制作办理培训机构需要具备的条件
  • 化妆品商城网站建设策划方案seo优化快速排名
  • 个人建站系统今日新闻播报
  • 做网站第一步要干啥定制网站建设推广服务
  • 政府政务公开网站建设上海关键词推广
  • 做网站运营有前景吗南京seo优化推广
  • 做网站和优化共多少钱网络营销模式有哪些?
  • 门户网站做公众号的好处推广一次多少钱
  • 网站首页设计报告网络营销的8个基本职能
  • 做网站定金交多少合适百度seo价格查询
  • 郑州市主城区seo网站优化详解
  • 怎么做网站后端国家提供的免费网课平台
  • 免费照片的网站模板上海最近3天疫情情况
  • 宁国网站建设他达拉非片正确服用方法
  • 好的漂亮的淘宝客网站模板下载百度营销登录
  • 上海网站建设口碑好软文发布平台
  • 郑州网站制作的公司搜索引擎大全
  • 深圳做营销网站设计百度关键词搜索排名统计
  • 保定网站建设技术支持精准推广引流5000客源
  • 揭阳做网站的5000人朋友圈推广多少钱
  • 企业形象网站用什么语言开发windows7优化大师官方下载