DOKK / manpages / debian 11 / manpages-zh / safe.3tcl.zh_TW
safe(3tcl) Tcl Built-In Commands safe(3tcl)

Safe - 用來建立和操縱安全解釋器的機制。

總覽 SYNOPSIS

::safe::interpCreate ?slave? ?options...?

::safe::interpInit slave ?options...?

::safe::interpConfigure slave ?options...?

::safe::interpDelete slave

::safe::interpAddToAccessPath slave directory

::safe::interpFindInAccessPath slave directory

::safe::setLogCmd ?cmd arg...?

?-accessPath pathList? ?-statics boolean? ?-noStatics? ?-nested boolean? ?-nestedLoadOk? ?-deleteHook script?

描述 DESCRIPTION

Safe Tcl 是一種機制,用於安全的執行不可信任的 Tcl 腳本,併爲有潛在危險功能的腳本提供訪問中介。

Safe Base 確保不可信任的 Tcl 腳本不能損壞宿主應用。Safe Base 防止完整性和隱私攻擊。防止不可信任的 Tcl 腳本敗壞宿主應用或計算機的狀況。防止不可信任的腳本把存儲在宿主主機或宿主應用中的信息泄露給任何人羣。

Safe Base 允許一個主解釋器建立安全、受限制的解釋器,它包括爲 source, load, file, encoding, 和 exit 命令預定義的一系列別名,並可以使用自動裝載和包機制。

不向安全解釋器透露文件系統的任何東西,它只能訪問包含記號(token)的虛擬的路徑。當安全解釋器請求 source(載入)一個文件的時候,它使用在虛擬路徑中的記號作爲要 source 的文件名的一部分;主解釋器透明的把這個記號轉換成一個實際的路徑名並執行所要求的操作 (詳情參見下面的 SECURITY 安全 章節). 可以使用下面描述的命令標誌來選擇不同的安全級別。

Safe Base 在主解釋器中提供的所有命令駐留在 safe 名字空間中:

命令 COMMANDS

在主解釋器中提供了下列命令:

::safe::interpCreate ?slave? ?options...?
建立一個安全解釋器,安裝在ALIASES 別名 章節中描述的別名並初始化在 OPTIONS 選項 中提供的自動裝載和包機制。對可選擇的參數的描述請參見下面 OPTIONS 選項 章節。如果省略了slave 參數,則生成一個名字。::safe::interpCreate 總是返回解釋器的名字。
::safe::interpInit slave ?options...?
除了不建立安全解釋器之外,這個命令類似於 interpCreate 命令。必須已經通過其他方式如 interp create -safe建立了這個 slave
如果未給出 options,則把給指名的這個解釋器所有選項的設置返回爲給這個 slave 的選項和它們當前的值的一個列表。如果提供了一個單一的補充參數,它將返回有兩個元素 namevalue 的一個列表,這裏的 name 是選項的全名而 value 是給 slave 的這個選項當前值。如果提供多於兩個補充選項,它將重新配置這個安全解釋器並只改變每個提供的選項。關於選項的描述請參見下面的 OPTIONS 章節。使用的例子:
# Create a new interp with the same configuration as "$i0" : set i1 [eval safe::interpCreate [safe::interpConfigure $i0]] # Get the current deleteHook set dh [safe::interpConfigure $i0 -del] # Change (only) the statics loading ok attribute of an interp # and its deleteHook (leaving the rest unchanged) : safe::interpConfigure $i0 -delete {foo bar} -statics 0 ;
::safe::interpDelete slave
刪除這個安全解釋器並清除相應的主解釋器數據結構。如果爲這個解釋器指定了一個 deleteHook 腳本,則在刪除這個解釋器之前執行這個腳本,把這個解釋器的名字作爲一個補充參數。
::safe::interpFindInAccessPath slave directory
這個命令尋找並返回在安全解釋器的當前虛擬訪問路徑中給實際路徑 directory 的記號。如果未找到這個路徑則生成一個錯誤。使用的例子:
$slave eval [list set tk_library [::safe::interpFindInAccessPath $name $tk_library]]
::safe::interpAddToAccessPath slave directory
這個命令把 directory 添加到在主解釋器中爲安全解釋器維護的虛擬路徑中,並返回可在安全解釋器中被用來獲得到在這個目錄中的文件的訪問的記號。如果這個路徑已經存在於虛擬路徑中,則它只返回記號而不再次把這個路徑添加到虛擬路徑中。使用的例子:
$slave eval [list set tk_library [::safe::interpAddToAccessPath $name $tk_library]]
::safe::setLogCmd ?cmd arg...?
這個命令安裝在一個腳本,在這個安全解釋器的特定的生命週期事件發生的時候將被調用。在調用這個命令而不加參數時,它返回當前安裝的腳本。在調用並加一個參數空串時,則刪除當前安裝的腳本並關閉日誌記錄。調用這個腳本時將加上一個補充參數,它描述所感興趣的事件。主要的目的是幫助調試安全解釋器。在安全解釋器只能得到一個一般錯誤消息的時候你可以使用這個設施獲得完整的錯誤消息。這防止安全解釋器見到關於失敗的消息和其他可能包含敏感信息如真實路徑名的其他事件的消息。
使用的例子:

::safe::setLogCmd puts stderr

下面是一個樣本對話的輸出,這裏一個安全解釋器嘗試着 source 一個在它的虛擬 訪問路徑中找不到的文件。注意這個安全解釋器只接收到一個錯誤消息,說這個文 件未找到:

NOTICE for slave interp10 : Created
NOTICE for slave interp10 : Setting accessPath=(/foo/bar) staticsok=1 nestedok=0 deletehook=()
NOTICE for slave interp10 : auto_path in interp10 has been set to {$p(:0:)}
ERROR for slave interp10 : /foo/bar/init.tcl: no such file or directory

選項 OPTIONS

下列選項通用於 ::safe::interpCreate::safe::interpInit、和 ::safe::interpConfigure。任何選項都可縮寫爲它的最小的無歧義的名字。選項的名字是大小寫不敏感的。

這個選項設置目錄的列表,安全解釋器可以從中 sourceload 文件。如果未指定這個選項,或者它被給定爲一個空列表,安全解釋器將使用的目錄同與它的主解釋器用於自動裝載的目錄。關於虛擬路徑、記號和訪問控制的詳情請參見下面的 SECURITY 安全 章節。
這個選項指定是否允許這個安全解釋器裝載靜態連接包(如 load {} Tk)。缺省值是 true : 允許安全解釋器裝載靜態連接包。
這個選項是 -statics false 的一個方便的簡寫,它指定不允許這個安全解釋器裝載靜態連接包。
這個選項指定是否允許這個安全解釋器把包裝載到它自己的子解釋器中。缺省值是 false : 不允許安全解釋器把包裝載到它自己的子解釋器中。
這個選項是 -nested true 的一個方便的簡寫,它指定允許安全解釋器把包裝載到它自己的子解釋器中。
當給這個選項以一個非空的 script 的時候,它將在實際刪除這個從解釋器之前在主解釋器中被求值,並加上這個安全解釋器的名字作爲一個補充的參數。給予一個空值則去除任何當前爲這個安全解釋器安裝的刪除回調(hook)腳本。缺省值({})是沒有任何刪除回調腳本。

別名 ALIASES

在安全解釋器中提供了下列別名:

如果找到了要求的這個 Tcl 源文件,則把它 source(裝載)到安全解釋器中。 source 別名只可以從給這個安全解釋器的虛擬路徑中的目錄 source 文件。 關於在有效文件名上的限制的更多信息請參見 SECURITY 安全 章節。
如果找到了要求的這個共享的目標文件,則把它動態的裝載到安全解釋器中。爲了能成功的找到它,文件名必須包含在給這個安全解釋器的虛擬路徑中提及的一個記號的名字。還有,這個共享的目標文件必須包含一個安全入口點;詳情請參見 load 命令的手冊條目。
file 別名提供到 file命令的子命令的一個安全子集的訪問;它只允許 dirnamejoinextensionroottailpathnamesplit 子命令。關於這些子命令的詳情請參見 file 命令的手冊條目。
enconding 別名提供到 encoding 命令的子命令的一個安全子集的訪問;它不允許設置系統編碼,不允許其他子命令包括 system 檢查當前編碼。
刪除調用它的腳本並停止它的計算,但這個解釋器存在於其中的那個 Tcl 進程不被終止。

安全 SECURITY

Safe Base 不嘗試完全的防止煩惱(annoyance)和拒絕服務攻擊。這些形式的攻擊妨礙應用或用戶臨時的使用計算機來完成有用的工作,例如消耗所有可利用的 CPU 時間或所有可利用的屏幕 real estate。這些攻擊儘管很惡劣,但一般不如 Safe Base 主要防護的完整性和隱私攻擊那麼重要。

除了在 interp 手冊頁中定義的安全命令集之外,在安全解釋器中可獲得的命令還包括給 sourceloadexit 的作爲中介的(mediate)別名以及 fileencoding 命令的安全子集。安全解釋器還可以自動裝載代碼並可以請求裝載包。

因爲這些命令中的一些命令訪問本地文件系統,存在着對它的目錄結構的潛在的信息泄露。爲了防止這個問題,接受文件名作爲參數的命令在安全解釋器中使用記號來替代真實的目錄名。在主解釋器中介一個要求例如 source 一個文件的時候,把這些記號轉換成實際路徑名。在主解釋器中維護這個虛擬路徑系統,針對每個用 ::safe::interpCreate 建立的或用 ::safe::interpInit 初始化的安全解釋器,這個路徑把在安全解釋器中可訪問的記號映射成在本地文件系統上的真實路徑名,這樣就防止了安全解釋器去獲取關於這個解釋器在其上執行的主機的文件系統結構的知識。可以提供給從解釋器中的 sourceload 別名的有效的文件名參數只能是下面這種形式的路徑: [file join token filename] (比如,在使用本地文件路徑格式的時候: 在 Unix 上是 token/filename,在 Windows 上是 token\filename,在 Mac 上是 token:filename ),這裏的 token 表示 accessPath 列表中的一個目錄而 filename 是在這個目錄中一個文件(不允許訪問子目錄)。

在一個安全解釋器中,當在要 source 或裝載一個文件的一個請求中使用一個記號的時候,檢查這個記號並把它轉換成真實路徑名,並在文件系統上定位要被 source 或裝載的文件。安全解釋器不能獲取關於文件系統上在其下存儲這個文件的實際路徑名的知識。

爲了進一步防止潛在的對偶然的包括在可以被安全解釋器 source 的文件集中的敏 感文件的信息泄露,限制 source 別名爲訪問滿足下列約束的文件: 文件名 必須是十四個字符或更短,必須不包含多於一個的點(“.”),不許終止於擴 展 .tcl 或是被調用的 tclIndex

初始的訪問路徑列表中的每個元素將分配一個記號,它們將被設置在從解釋器的 auto_path 中並且這個列表的第一個元素將被設置爲這個從解釋器的 tcl_library

如果未給出訪問路徑參數或者是一個空列表,缺省的行爲是讓從解釋器訪問的包與主解釋器已經訪問了的包相同(更精確的描述: 只允許用 Tcl 寫成的包(因爲它們將在從解釋器中運行所以不可能是危險的)和提供 Safe_Init 入口點的 C 擴展)。爲此,用主解釋器的 auto_path 來構造從解釋器的訪問路徑。爲了從解釋器能成功的裝載 Tcl 庫文件(它自身包括自動裝載機制),如果需要的話,把 tcl_library 增加或移動到在從解釋器的訪問路徑中的第一個的位置上,這樣從解釋器的 tcl_library 將與主解釋器的相同(它的真實路徑對從解釋器仍是不可見的)。爲了使自動裝載對於從解釋器和主解釋器在缺省的情況下以相同的方式工作,在主解釋器 auto_path 中的每個目錄的第一層子目錄將被添加(如果未曾包含的話)到從解釋器的訪問路徑中。你總是可以通過顯式的使用 -accessPath 標誌指定你的目錄列表,而不是依賴於這個缺省機制,來指定一個更受限制的路徑,它的子目錄永遠不能被查找。

在首次建立或初始化(例如通過 interpConfigure -accessPath list)之後變更 accessPath 的時候,將在安全解釋器中自動的求值 auto_reset 來使它的 auto_index 與新的記號列表同步。

參見 SEE ALSO

interp(n), library(n), load(n), package(n), source(n), unknown(n)

關鍵字 KEYWORDS

alias, auto-loading, auto_mkindex, load, master interpreter, safe interpreter, slave interpreter, source

寒蟬退士

2001/11/07

《中國 Linux 論壇 man 手冊頁翻譯計劃》:

http://cmpp.linuxforum.net

本頁面中文版由中文 man 手冊頁計劃提供。
中文 man 手冊頁計劃:https://github.com/man-pages-zh/manpages-zh

8.0 Tcl