Smarty安全

2018-12-10 17:04 更新

安全

當(dāng)你有非可信任的第三方來編輯模板時(shí),比如說通過FTP編輯,安全機(jī)制可以幫助你通過 模板語言的限制,來減少可能對系統(tǒng)安全產(chǎn)生的危害。

安全機(jī)制可以通過Smarty_Security對象的屬性來進(jìn)行設(shè)置。 這里是允許的設(shè)置:

  • $php_handling明確定義了Smarty如何處理內(nèi)嵌到模板的PHP代碼: 可用值是:

    • Smarty::PHP_PASSTHRU -> 原樣顯示PHP代碼

    • Smarty::PHP_QUOTE -> 將PHP代碼轉(zhuǎn)換成HTML實(shí)體顯示

    • Smarty::PHP_REMOVE -> 刪除PHP代碼

    • Smarty::PHP_ALLOW -> 執(zhí)行PHP代碼

    默認(rèn)值是Smarty::PHP_PASSTHRU。

    如果安全機(jī)制開啟,Smarty對象的$php_handling 設(shè)置將不會(huì)被檢查。

  • $secure_dir是安全模板目錄的數(shù)組。 $template_dir 同樣也被看作安全的目錄。 默認(rèn)這是空的數(shù)組。

  • $trusted_dir是可信任目錄的數(shù)組。 信任目錄可以允許你存放PHP文件,這些PHP文件可以通過 {include_php}包含到模板中, 并且直接運(yùn)行。 默認(rèn)這是空的數(shù)組。

  • $trusted_uri是一個(gè)包含了匹配URL的正則表達(dá)式的數(shù)組,這些URL都被認(rèn)為是可信的。 這個(gè)安全功能用于 {fetch} 和 {html_image}。 在這些函數(shù)內(nèi)使用的URL,必須類似{$PROTOCOL}://{$HOSTNAME}的格式, 并且可以使用一些簡單的正則表達(dá)式。 (不包括一些極端的例子如authentication-tokens)

    正則表達(dá)式'#https?://.*smarty.net$#i'將允許下面的URL:

    • http://smarty.net/foo

    • http://smarty.net/foo

    • http://www.smarty.net/foo

    • http://smarty.net/foo

    • https://foo.bar.www.smarty.net/foo/bla?blubb=1

    但不允許以下的URL:

    • http://smarty.com/foo (不匹配頂級域名"com")

    • ftp://www.smarty.net/foo (不匹配協(xié)議"ftp")

    • http://www.smarty.net.otherdomain.com/foo (不匹配域名"smarty.net")

  • $static_classes是一個(gè)包含了可信的靜態(tài)類的數(shù)組。 默認(rèn)是空數(shù)組,表示信任任何的靜態(tài)類。 設(shè)置不信任全部靜態(tài)類可以設(shè)置$static_classes = null。

  • $php_functions是一個(gè)包含了可用的PHP函數(shù)的數(shù)組,這些函數(shù)可以在模板內(nèi)直接使用。 空數(shù)組 ( $php_functions = array() ) 表示全部PHP函數(shù)都是可用的。 設(shè)置全部函數(shù)不可用,需要設(shè)置$php_functions = null。 默認(rèn)值是array('isset', 'empty', 'count', 'sizeof', 'in_array', 'is_array','time','nl2br')。

  • $php_modifiers是一個(gè)包含了可用的PHP函數(shù)的數(shù)組,這些函數(shù)可以在模板內(nèi)當(dāng)作修飾器來使用。 空數(shù)組 ( $php_functions = array() ) 表示全部PHP函數(shù)修飾器都是可用的。 設(shè)置全部函數(shù)修飾器不可用,需要設(shè)置$php_modifier = null。 默認(rèn)值是array('escape','count')。

  • $streams是一個(gè)包含了可用數(shù)據(jù)流的數(shù)組,這些數(shù)據(jù)流可以直接在模板內(nèi)使用。 空數(shù)組 ( $streams = array() ) 表示全部數(shù)據(jù)流都是可用的。 設(shè)置全部數(shù)據(jù)流不可用,需要設(shè)置$streams = null。 默認(rèn)值是array('file')。

  • $allowed_modifiers是一個(gè)包含了可用的(注冊的/自動(dòng)加載的)修飾器數(shù)組。 如果非空,則只有列表上的修飾器才能使用。這是一個(gè)白名單。

  • $disabled_modifiers是一個(gè)包含了不可用的(注冊的/自動(dòng)加載的)修飾器數(shù)組。

  • $allowed_tags是一個(gè)控制哪些區(qū)塊標(biāo)簽、函數(shù)和過濾器能夠在模板內(nèi)使用的數(shù)組。 如果非空,則只有列表上的標(biāo)簽才能使用。這是一個(gè)白名單。

  • $disabled_tags是一個(gè)包含了不可用的區(qū)塊標(biāo)簽、函數(shù)和過濾器的數(shù)組。

  • $allow_constants布爾值,代表了是否允許在模板內(nèi)使用常量。 默認(rèn)是true。

  • $allow_super_globals布爾值,代表了是否允許在模板內(nèi)使用PHP的全局變量。 默認(rèn)是true。

  • $allow_php_tag布爾值,代表了是否允許在模板內(nèi)使用{php} 和 {include_php}標(biāo)簽。 默認(rèn)是false。

如果安全機(jī)制開啟,私有的成員方法、靜態(tài)類/對象的私有函數(shù)或者私有屬性都不能在模板內(nèi)使用。

自定義你自己的安全策略,可以擴(kuò)展繼承Smarty_Security類或者是建立它的實(shí)例。

Example 17.1. 擴(kuò)展Smarty_Security 類來設(shè)置安全策略

<?php
require 'Smarty.class.php';

class My_Security_Policy extends Smarty_Security {
  // 關(guān)閉全部PHP函數(shù)
  public $php_functions = null;
  // 刪除PHP標(biāo)簽
  public $php_handling = Smarty::PHP_REMOVE;
  // 允許任何函數(shù)成為修飾器
  public $modifiers = array();
}
$smarty = new Smarty();
// 開啟自定義安全機(jī)制
$smarty->enableSecurity('My_Security_Policy');
?>

Example 17.2. 通過Smarty_Security類的實(shí)例來自定義安全策略

<?php
require 'Smarty.class.php';
$smarty = new Smarty();
$my_security_policy = new Smarty_Security($smarty);
// 關(guān)閉全部PHP函數(shù)
$my_security_policy->php_functions = null;
// 刪除PHP標(biāo)簽
$my_security_policy->php_handling = Smarty::PHP_REMOVE;
// 允許任何函數(shù)成為修飾器
$my_security_policy->$modifiers = array();
// 開啟自定義安全機(jī)制
$smarty->enableSecurity($my_security_policy);
?>

Example 17.3. 開啟默認(rèn)的安全設(shè)置

<?php
require 'Smarty.class.php';
$smarty = new Smarty();
// 開啟默認(rèn)安全設(shè)置
$smarty->enableSecurity();
?>

溫馨提示

安全機(jī)制只會(huì)在模板編譯時(shí)進(jìn)行檢查。 所以當(dāng)你修改了安全設(shè)置后,必須刪除全部緩存和編譯文件并重新編譯。

以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號