每日作业

各种绕过

 

<?php 
highlight_file
('flag.php'); 
$_GET['id'] = urldecode($_GET['id']); 
$flag 'flag{xxxxxxxxxxxxxxxxxx}'
if (isset(
$_GET['uname']) and isset($_POST['passwd'])) { 
    if (
$_GET['uname'] == $_POST['passwd']) 

        print 
'passwd can not be uname.'

    else if (
sha1($_GET['uname']) === sha1($_POST['passwd'])&($_GET['id']=='margin')) 

        die(
'Flag: '.$flag); 

    else 

        print 
'sorry!'


?>

 

 

陌生函数sha1存在构造数组的方式进行绕过

 

 

 

(sha1($_GET['uname']) === sha1($_POST['passwd'])&($_GET['id']=='margin'))

Unameidget  passwdpost

 passwd can not be uname

构造

 

 

 

 

 

Web8

 

<?php
extract
($_GET);
if (!empty(
$ac))
{
$f trim(file_get_contents($fn));
if (
$ac === $f)
{
echo 
"<p>This is flag:" .$flag</p>";
}
else
{
echo 
"<p>sorry!</p>";
}
}
?>

 

 

 

 

 

 

 

 

extract 可以将$_GET数组的值转为变量,默认是如果有冲突,则覆盖已有的变量

 

file_get_contents参考的


构造

 

 

 

 

 

 

字符正则

<?php 
highlight_file
('2.php');
$key='KEY{********************************}';
$IMpreg_match("/key.*key.{4,7}key:\/.\/(.*key)[a-z][[:punct:]]/i"trim($_GET["id"]), $match);
if( 
$IM ){ 
  die(
'key is: '.$key);
}
?>

 

 

/key.*key.{4,7}key:\/.\/(.*key)[a-z][[:punct:]]/i将式中正则表达式转化成符号

构造

http://120.24.86.145:8002/web10/?id=keyaakey11111key:/a/aakeya.

 

 

 

 

 

细心

dirsearch扫描目录

index.php里什么都没有




 

http://120.24.86.145:8002/web13//resusl.php?x=admin


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值