例子:
rewriteengine on 開啟引擎
rewriterule test.html /test.php [l]
rewriterule test.html?$ /tianqi.php?s1=&s2=&s3= [qsa,l] 用於多個引數的情況
rewriterule tianqi-([0-9]+).html /tianqi.php?id=$1 [l]
注意路徑的問題。
text:
. 匹配任意單個字元
[chars] 匹配當前字元
[^chars] 不匹配當前字元
text1|text2 包含text1或者text2任何乙個
quantifiers:
? 零個或者乙個?號前的字元
* 零個或者任意個任意長度的任意字元
乙個或者任意個任意長度的字元
anchors:
^ 匹配內容開始標記
$ 匹配內容結束標記
escaping:
char 使用來進行特殊字元的轉義,包括".()"等字元的轉義
flags'redirect|r [=code]' (強制重定向 redirect)
以http: //thishost[:thisport]/(使新的url成為乙個uri) 為字首的substitution可以強制性執行乙個外部重定向。 如果code沒有指定,則產生乙個http響應**302(臨時性移動)。 如果需要使用在300-400範圍內的其他響應**,只需在此指定這個數值即可, 另外,還可以使用下列符號名稱之一: temp (預設的), permanent, seeother. 用它可以把規範化的url反饋給客戶端,如, 重寫``/~''為 ``/u/'',或對/u/user加上斜槓,等等。 注意: 在使用這個標記時,必須確保該替換欄位是乙個有效的url! 否則,它會指向乙個無效的位置! 並且要記住,此標記本身只是對url加上 http://thishost[:thisport]/的字首,重寫操作仍然會繼續。 通常,你會希望停止重寫操作而立即重定向,則還需要使用'l'標記.
'forbidden|f' (強制url為被禁止的 forbidden)
強制當前url為被禁止的,即,立即反饋乙個http響應**403(被禁止的)。 使用這個標記,可以鏈結若干rewriteconds以有條件地阻塞某些url。
'gone|g' (強制url為已廢棄的 gone)強制當前url為已廢棄的,即,立即反饋乙個http響應**410(已廢棄的)。 使用這個標記,可以標明頁面已經被廢棄而不存在了.
'proxy|p' (強制為** proxy)此 標記使替換成分被內部地強制為**請求,並立即(即, 重寫規則處理立即中斷)把處理移交給**模組。 你必須確保此替換串是乙個有效的(比如常見的以 http://hostname開頭的)能夠為apache**模組所處理的uri。 使用這個標記,可以把某些遠端成分對映到本地伺服器命名空間, 從而增強了proxypass指令的功能。 注意: 要使用這個功能,**模組必須編譯在apache伺服器中。 如果你不能確定,可以檢查``httpd -l''的輸出中是否有mod_proxy.c。 如果有,則mod_rewrite可以使用這個功能; 如果沒有,則必須啟用mod_proxy並重新編譯``httpd''程式。
'last|l' (最後乙個規則 last)立 即停止重寫操作,並不再應用其他重寫規則。 它對應於perl中的last命令或c語言中的break命令。 這個標記可以阻止當前已被重寫的url為其後繼的規則所重寫。 舉例,使用它可以重寫根路徑的url('/')為實際存在的url, 比如, '/e/www/'.
'next|n' (重新執行 next round)重新執行重寫操作(從第乙個規則重新開 始). 這時再次進行處理的url已經不是原始的url了,而是經最後乙個重寫規則處理的url。 它對應於perl中的next命令或c語言中的continue命令。 此標記可以重新開始重寫操作,即, 立即回到迴圈的頭部。但是要小心,不要製造死迴圈!
'chain|c' (與下乙個規則相鏈結 chained)此 標記使當前規則與下乙個(其本身又可以與其後繼規則相鏈結的, 並可以如此反覆的)規則相鏈結。 它產生這樣乙個效果: 如果乙個規則被匹配,通常會繼續處理其後繼規則, 即,這個標記不起作用;如果規則不能被匹配, 則其後繼的鏈結的規則會被忽略。比如,在執行乙個外部重定向時, 對乙個目錄級規則集,你可能需要刪除``.www'' (此處不應該出現``.www''的)。
'nosubreq|ns' (僅用於不對內部子請求進行處理 no internal sub-request)在 當前請求是乙個內部子請求時,此標記強制重寫引擎跳過該重寫規則。 比如,在mod_include試圖搜尋可能的目錄預設檔案(index.***)時, apache會內部地產生子請求。對子請求,它不一定有用的,而且如果整個規則集都起作用, 它甚至可能會引發錯誤。所以,可以用這個標記來排除某些規則。 根據你的需要遵循以下原則: 如果你使用了有cgi指令碼的url字首,以強制它們由cgi指令碼處理, 而對子請求處理的出錯率(或者開銷)很高,在這種情況下,可以使用這個標記。
'nocase|nc' (忽略大小寫 no case)它使pattern忽略大小寫,即, 在pattern與當前url匹配時,'a-z' 和'a-z'沒有區別。
'noescape|ne' (在輸出中不對uri作轉義 no uri escaping)此 標記阻止mod_rewrite對重寫結果應用常規的uri轉義規則。 一般情況下,特殊字元(如'%', '$', ';'等)會被轉義為等值的十六進製制編碼。 此標記可以阻止這樣的轉義,以允許百分號等符號出現在輸出中,如: rewriterule /foo/(.*) /bar?arg=p1/%3d$1 [r,ne]
可以使'/foo/zed'轉向到乙個安全的請求'/bar?arg=p1=zed'.
'passthrough|pt' (移交給下乙個處理器 pass through)此 標記強制重寫引擎將內部結構request_rec中的uri欄位設定為 filename欄位的值,它只是乙個小修改,使之能對來自其他uri到檔名翻譯器的 alias,scriptalias, redirect 等指令的輸出進行後續處理。舉乙個能說明其含義的例子: 如果要通過mod_rewrite的重寫引擎重寫/abc為/def, 然後通過mod_alias使/def轉變為/ghi,可以這樣: rewriterule ^/abc(.*) /def$1 [pt]
alias /def /ghi
如果省略了pt標記,雖然mod_rewrite運作正常, 即, 作為乙個使用api的uri到檔名翻譯器, 它可以重寫uri=/abc/...為filename=/def/..., 但是,後續的mod_alias在試圖作uri到檔名的翻譯時,則會失效。
注意: 如果需要混合使用不同的包含uri到檔名翻譯器的模組時, 就必須使用這個標記。混合使用mod_alias和mod_rewrite就是個典型的例子。
for apache hackers
如 果當前apache api除了uri到檔名hook之外,還有乙個檔名到檔名的hook, 就不需要這個標記了! 但是,如果沒有這樣乙個hook,則此標記是唯一的解決方案。 apache group討論過這個問題,並在apache 2.0 版本中會增加這樣乙個hook。
'skip|s=num' (跳過後繼的規則 skip)此標記強制重寫引擎跳過當前匹配規則後繼的num個規則。 它可以實現乙個偽if-then-else的構造: 最後乙個規則是then從句,而被跳過的skip=n個規則是else從句. (它和'chain|c'標記是不同的!)
'env|e=var:val' (設定環境變數 environment variable)此 標記使環境變數var的值為val, val可以包含可擴充套件的反向引用的正規表示式$n和%n。 此標記可以多次使用以設定多個變數。 這些變數可以在其後許多情況下被間接引用,但通常是在xssi (via or cgi (如 $env)中, 也可以在後繼的rewritecond指令的pattern中通過%作引用。 使用它可以從url中剝離並記住一些資訊。
'cookie|co=name:val:domain[:lifetime[:path]]' (設定cookie)它在客戶端瀏覽器上設定乙個cookie。 cookie的名稱是name,其值是val。 domain欄位是該cookie的域,比如'.apache.org', 可選的lifetime是cookie生命期的分鐘數, 可選的path是cookie的路徑。
附:path_info的讀取
url方式: test.php/s1/2/s2/3
if(!empty($_server['path_info']))
}
Spring MVC 註解說明
最近在專案中用到spring mvc 好多註解不知道怎麼用 在網上搜了一下,我大概其的 說一下在哪些地方使用 component productdao 一般寫在介面實現類頂部 字面意思就是元件 寫好了元件 component註解之後,就要呼叫此介面的實現 resource name productd...
swagger註解說明
前言 使用swagger的主要好處就是不用手動寫文件了,通過註解就可以自動化文件。文件和 同步更新,更新之後不需要再更新文件。使用swagger框架可以除錯api,在瀏覽器端可以看到更多的 request 和 response 資訊。本文章重點描述下swagger應用注釋說明。示例 首先是 cmsc...
Swagger註解說明
1.api 用在類上,說明該類的作用 api value usercontroller description 使用者相關api 2.apioperation 用在方法上,說明方法的作用 3 apiimplicitparams 用在方法上包含一組引數說明 4.apiimplicitparam 用在 ...