規則集參考 rule-set-reference

「影像伺服」支援以規則運算式相符和替代規則為基礎的簡單要求前置處理機制。

前置處理規則的集合(規則集)可以附加到影像目錄或預設目錄。 只有當請求未識別特定的主要影像目錄時,才會套用預設目錄中的規則。

要求前置處理規則可在Platform Server的剖析器處理要求之前,修改要求的路徑和查詢部分,包括操作路徑、新增命令、變更命令值,以及套用範本或巨集。 規則也可用來設定和覆寫某些安全性功能,這些功能通常僅由目錄屬性控制,例如要求模糊化、加上注水標籤,以及將服務限制在特定的使用者端IP位址。

規則集會儲存為XML檔案檔案。 必須在attribute::RuleSetFile中指定規則集檔案的相對或絕對路徑。

一般結構 section-8bcbd91ea8a946f28051bde8ad21827f

 <?xml version="1.0" encoding="UTF-8"?>
<ruleset>
   <rule>
      <expression>
<varname>
  expression
</varname></expression>
      <substitution>
<varname>
  substitution
</varname></substitution>
      <addressfilter>
<varname>
  addressFilter
</varname></addressfilter>
      <header>
<varname>
  headerValue
</varname></header>
   </rule>
</ruleset>

在有效的規則集XML檔案中,<?xml><ruleset>專案永遠是必要的,即使未定義實際規則。

允許一個包含任意數目<rule>個元素的<ruleset>元素。

預先處理規則檔案的內容區分大小寫。

規則集驗證 section-d8d101a0b4d74580835e37d128d05567

RuleSet.xsd的復本在目錄資料夾中提供,並且應該用來在註冊到catalog.ini檔案之前驗證規則集檔案。 請注意,「影像伺服」使用RuleSet.xsd的內部復本進行驗證。

URL前置處理 section-2c09a2d79ada46b994857c6a7fb4c13a

在任何其他處理作業之前,會先對傳入的HTTP要求進行部分剖析,以決定應套用哪個影像目錄。 識別目錄後,將套用所選目錄的規則集(或預設目錄,如果未識別特定目錄)。

<rule>元素會依照指定的順序搜尋,以符合<expression>元素( expression)的內容。

如果符合<rule>,則會套用選用的​ substitution,並將修改過的要求字串傳遞給伺服器的要求剖析器,以進行正常處理。

如果到達<ruleset>的結尾時未成功比對,則未修改即會將要求傳遞至剖析器。

OnMatch屬性 section-ed952fa55d99422db0ee68a2b9d395d3

可以使用<rule>專案的OnMatch屬性修改預設行為。 OnMatch可設為break (預設)、continueerror

元素和屬性
發生符合時的行為
<rule OnMatch="break">
在套用此規則的替代之後,規則處理會立即終止。 預設。
<rule OnMatch="continue">
會套用替代,並會繼續處理下一個規則。
<rule OnMatch="error">
規則處理會立即終止,且「已拒絕要求」回應狀態會傳回給使用者端。

覆寫目錄屬性 section-3f1e33a65c5346d1b4a69958c61432f3

rule元素可選擇性地定義屬性,以在成功比對規則時覆寫對應的目錄屬性。 如果有多個相符的規則設定了相同的屬性,則最後一個規則會優先。 如需可使用規則控制的屬性清單,請參閱規則元素。

規則運算式 section-3f77bb9a265147b38c645f63ab1bad8b

簡單字串比對適用於非常基本的應用程式,但在大多數情況下都需要規則運算式。 雖然規則運算式是符合業界標準的,但具體的實施會因例項而異。

package java.util.regex說明「影像伺服」使用的特定規則運算式實作。

擷取的子字串 section-066e659406d5403599cd26ae35e80d68

為了便於修改複雜的URL,您可以在運算式中擷取子字串,方法是以括弧(…)括住子字串。 擷取的子字串會根據前括弧的位置,從1開始依序編號。 擷取的子字串可以使用 $ *n*插入替代中,其中​ n ​是擷取的子字串的序號。

管理規則集檔案 section-0598a608e4044bb4805fe93ceebe10a9

一個規則集檔案可附加至每個具有目錄屬性attribute::RuleSetFile的影像目錄。 雖然您可以隨時編輯規則集檔案,但影像伺服器只有在重新載入關聯的影像目錄時,才會辨識變更。 當平台伺服器啟動或重新啟動時,以及當具有.ini檔案字尾的主要目錄檔案被修改或「接觸」以變更檔案日期時,就會發生這種重新載入。

範例 section-aa769437d967459299b83a4bf34fe924

範例A. ​如果影像名稱尾碼為「_hg」,請定義增加影像品質設定的規則:

<rule>
   <expression>(?i)_hg$</expression>
   <substitution>\?&amp;qlt=95,1&amp;resmode=bicub</substitution>
</rule>

規則運算式在URL字串的結尾指定「_hg」的相符項(不區分大小寫)。 字尾會取代為指定的查詢字串,而這會變更影像品質設定。 請注意,替代字串中的?字元已逸出,因為這是規則運算式中的特殊字元。

NOTE
&字元的必要編碼。 或者,替代字串可以包含在CDATA區塊中:

<substitution><![CDATA[&qlt=95,1&resmode=bicub]]></substitution>

範例B. ​特定的Web應用程式不允許查詢字串。 定義將結尾路徑元素smallmediumlarge轉譯為範本的規則,使用路徑的其餘部分作為影像名稱。 例如,myCat/myImage/small會轉譯為myCat/smallTemplate?src=myCat/myImage

我們可以使用子字串來重新建構請求:

<rule>
   <expression>([^/]+)/(small|medium|large)$</expression>
   <substitution>$2Template?src=sample/$1</substitution>
</rule>

另請參閱 section-9b748e7c5cff4759a70f96657bd43352

封裝java.util.regex

recommendation-more-help
a26166cd-f2f4-45ce-996d-96a0f0d6cf49