欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

13個(gè)實(shí)用的Apache Rewrite重寫規(guī)則

 更新時(shí)間:2014年03月10日 15:34:39   作者:  
這篇文章主要介紹了13個(gè)實(shí)用的Apache Rewrite重寫規(guī)則,需要的朋友可以參考下

1.去掉域名中的www標(biāo)記

復(fù)制代碼 代碼如下:
RewriteCond %{HTTP_HOST} !^jb51\.net$ [NC]
RewriteRule .? http://jb51.net%{REQUEST_URI} [R=301,L]

2.去掉www標(biāo)記,但是保存子域名
復(fù)制代碼 代碼如下:
RewriteCond %{HTTP_HOST} ^www\.(([a-z0-9_]+\.)?jb51\.net)$ [NC]
RewriteRule .? http://%1%{REQUEST_URI} [R=301,L]

這里,當(dāng)匹配到1%變量以后,子域名才會(huì)在%2(內(nèi)部原子)中抓取到,而我們需要的正是這個(gè)%1變量。
3.給子域名加www標(biāo)記
復(fù)制代碼 代碼如下:
RewriteCond %{HTTP_HOST} ^([a-z.]+)?jb51\.net$ [NC]
RewriteCond %{HTTP_HOST} !^www\. [NC]
RewriteRule .? http://www.%1jb51.net%{REQUEST_URI} [R=301,L]

這個(gè)規(guī)則抓取二級(jí)域名的%1變量,如果不是以www開始,那么就加www,以前的域名以及{REQUEST_URI}會(huì)跟在其后。
4.防止圖片盜鏈
一些站長不擇手段的將你的圖片盜鏈在他們網(wǎng)站上,耗費(fèi)你的帶寬。你可以加一下代碼阻止這種行為。
復(fù)制代碼 代碼如下:
RewriteCond %{HTTP_REFERER} !^$
RewriteCond %{HTTP_REFERER} !^http://(www\.)?jb51\.net/ [NC]
RewriteRule \.(gif|jpg|png)$ – [F]

如果{HTTP_REFERER}值不為空,或者不是來自你自己的域名,這個(gè)規(guī)則用[F]FLAG阻止以gif|jpg|png 結(jié)尾的URL
如果對(duì)這種盜鏈你是堅(jiān)決鄙視的,你還可以改變圖片,讓訪問盜鏈網(wǎng)站的用戶知道該網(wǎng)站正在盜用你的圖片。
復(fù)制代碼 代碼如下:
RewriteCond %{HTTP_REFERER} !^$
RewriteCond %{HTTP_REFERER} !^http://(www\.)?jb51\.net/.*$ [NC]
RewriteRule \.(gif|jpg|png)$ 你的圖片地址 [R=301,L]

除了阻止圖片盜鏈鏈接,以上規(guī)則將其盜鏈的圖片全部替換成了你設(shè)置的圖片。
你還可以阻止特定域名盜鏈你的圖片:
復(fù)制代碼 代碼如下:
RewriteCond %{HTTP_REFERER} !^http://(www\.)?leech_site\.net/ [NC]
RewriteRule \.(gif|jpg|png)$ – [F,L]

這個(gè)規(guī)則將阻止域名黑名單上所有的圖片鏈接請求。
當(dāng)然以上這些規(guī)則都是以{HTTP_REFERER}獲取域名為基礎(chǔ)的,如果你想改用成IP地址,用{REMOTE_ADDR}就可以了。
5.如果文件不存在重定向到404頁面
如果你的主機(jī)沒有提供404頁面重定向服務(wù),那么我們自己創(chuàng)建。
復(fù)制代碼 代碼如下:
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule .? /404.php [L]

這里-f匹配的是存在的文件名,-d匹配的存在的路徑名。這段代碼在進(jìn)行404重定向之前,會(huì)判斷你的文件名以及路徑名是否存在。你還可以在404頁面上加一個(gè)?url=$1參數(shù):
復(fù)制代碼 代碼如下:
RewriteRule ^/?(.*)$ /404.php?url=$1 [L]

這樣,你的404頁面就可以做一些其他的事情,例如默認(rèn)信心,發(fā)一個(gè)郵件提醒,加一個(gè)搜索,等等。
6.重命名目錄
如果你想在網(wǎng)站上重命名目錄,試試這個(gè):
復(fù)制代碼 代碼如下:
RewriteRule ^/?old_directory/([a-z/.]+)$ new_directory/$1 [R=301,L]

在規(guī)則里我添加了一個(gè)“.”(注意不是代表得所有字符,前面有轉(zhuǎn)義符)來匹配文件的后綴名。
7.將.html后綴名轉(zhuǎn)換成.php
前提是.html文件能繼續(xù)訪問的情況下,更新你的網(wǎng)站鏈接。
復(fù)制代碼 代碼如下:
RewriteRule ^/?([a-z/]+)\.html$ $1.php [L]

這不是一個(gè)網(wǎng)頁重定向,所以訪問者是不可見的。讓他作為一個(gè)永久重定向(可見的),將FLAG修改[R=301,L]。
8.創(chuàng)建無文件后綴名鏈接
如果你想使你的PHP網(wǎng)站的鏈接更加簡潔易記-或者隱藏文件的后綴名,試試這個(gè):
復(fù)制代碼 代碼如下:
RewriteRule ^/?([a-z]+)$ $1.php [L]

如果網(wǎng)站混有PHP以及HTML文件,你可以用RewriteCond先判斷該后綴的文件是否存在,然后進(jìn)行替換:
復(fù)制代碼 代碼如下:
RewriteCond %{REQUEST_FILENAME}.php -f
RewriteRule ^/?([a-zA-Z0-9]+)$ $1.php [L]
RewriteCond %{REQUEST_FILENAME}.html -f
RewriteRule ^/?([a-zA-Z0-9]+)$ $1.html [L]

如果文件是以.php為后綴,這條規(guī)則將被執(zhí)行。
9.檢查查詢變量里的特定參數(shù)
如果在URL里面有一個(gè)特殊的參數(shù),你可用RewriteCond鑒別其是否存在:
復(fù)制代碼 代碼如下:
RewriteCond %{QUERY_STRING} !uniquekey=
RewriteRule ^/?script_that_requires_uniquekey\.php$ other_script.php [QSA,L]

以上規(guī)則將檢查{QUERY_STRING}里面的uniquekey參數(shù)是否存在,如果{REQUEST_URI}值為script_that_requires_uniquekey,將會(huì)定向到新的URL。
10.刪除查詢變量
Apache的mod_rewrite模塊會(huì)自動(dòng)辨識(shí)查詢變量,除非你做了以下改動(dòng):
a).分配一個(gè)新的查詢參數(shù)(你可以用[QSA,L]FLAG保存最初的查詢變量)
b).在文件名后面加一個(gè)“?”(比如index.php?)。符號(hào)“?”不會(huì)在瀏覽器的地址欄里顯示。
11.用新的格式展示當(dāng)前URI
如果這就是我們當(dāng)前正在運(yùn)行的URLs:/index.php?id=nnnn。我們非常希望將其更改成/nnnn并且讓搜索引擎以新格式展現(xiàn)。首先,我們?yōu)榱俗屗阉饕娓鲁尚碌?,得將舊的URLs重定向到新的格式,但是,我們還得保證以前的index.php照樣能夠運(yùn)行。是不是被我搞迷糊了?
實(shí)現(xiàn)以上功能,訣竅就在于在查詢變量中加了一個(gè)訪問者看不到的標(biāo)記符“marker”。我們只將查詢變量中沒有出現(xiàn)“marker”標(biāo)記的鏈接進(jìn)行重定向,然后將原有的鏈接替換成新的格式,并且通過[QSA]FLAG在已有的參數(shù)加一個(gè)“marker”標(biāo)記。以下為實(shí)現(xiàn)的方式:
復(fù)制代碼 代碼如下:
RewriteCond %{QUERY_STRING} !marker
RewriteCond %{QUERY_STRING} id=([-a-zA-Z0-9_+]+)
RewriteRule ^/?index\.php$ %1? [R=301,L]
RewriteRule ^/?([-a-zA-Z0-9_+]+)$ index.php?marker &id=$1 [L]

這里,原先的URL:http://www.dbjr.com.cn/index.php?id=nnnn,不包含marker,所以被第一個(gè)規(guī)則永久重定向到http://www.dbjr.com.cn/nnnn,第二個(gè)規(guī)則將http://www.dbjr.com.cn/nnnn反定向到http://www.dbjr.com.cn/index.php?marker&id=nnnn,并且加了marker以及id=nnnn兩個(gè)變量,最后mod_rewrite就開始進(jìn)行處理過程。
第二次匹配,marker被匹配,所以忽略第一條規(guī)則,這里有一個(gè)“.”字符會(huì)出現(xiàn)在http://www.dbjr.com.cn/index.php?marker&id=nnnn中,所以第二條規(guī)則也會(huì)被忽略,這樣我們就完成了。
注意,這個(gè)解決方案要求Apache的一些擴(kuò)展功能,所以如果你的網(wǎng)站放于在共享主機(jī)中會(huì)遇到很多障礙。
12.保證安全服務(wù)啟用
Apache可以用兩種方法辨別你是否開啟了安全服務(wù),分別引用{HTTPS}和{SERVER_PORT}變量:
復(fù)制代碼 代碼如下:
RewriteCond %{REQUEST_URI} ^secure_page\.php$
RewriteCond %{HTTPS} !on
RewriteRule ^/?(secure_page\.php)$ http://www.dbjr.com.cn/$1 [R=301,L]

以上規(guī)則測試{REQUEST_URI}值是否等于我們的安全頁代碼,并且{HTTPS}不等于on。如果這兩個(gè)條件同時(shí)滿足,請求將被重定向到安全服務(wù)URI.另外你可用{SERVER_PORT}做同樣的測試,443是常用的安全服務(wù)端口
復(fù)制代碼 代碼如下:
RewriteCond %{REQUEST_URI} ^secure_page\.php$
RewriteCond %{SERVER_PORT} !^443$
RewriteRule ^/?(secure_page\.php)$ http://www.dbjr.com.cn/$1 [R=301,L]

13.在特定的頁面上強(qiáng)制執(zhí)行安全服務(wù)
遇到同一個(gè)服務(wù)器根目錄下分別有一個(gè)安全服務(wù)域名和一個(gè)非安全服務(wù)域名,所以你就需要用RewriteCond 判斷安全服務(wù)端口是否占用,并且只將以下列表的頁面要求為安全服務(wù):
復(fù)制代碼 代碼如下:
RewriteCond %{SERVER_PORT} !^443$
RewriteRule ^/?(page1|page2|page3|page4|page5)$ http://www.dbjr.com.cn/%1[R=301,L]

以下是怎樣將沒有設(shè)置成安全服務(wù)的頁面返回到80端口:
復(fù)制代碼 代碼如下:
RewriteCond %{ SERVER_PORT } ^443$
RewriteRule !^/?(page6|page7|page8|page9)$http://www.dbjr.com.cn%{REQUEST_URI} [R=301,L]

其實(shí)Rewrite里運(yùn)用最多的還應(yīng)該是正則表達(dá)式,如果了解點(diǎn)兒正則的話,寫起這個(gè)規(guī)則還是比較簡單的。

相關(guān)文章

  • Apache添加多端口及實(shí)現(xiàn)單ip多端口映射的方法

    Apache添加多端口及實(shí)現(xiàn)單ip多端口映射的方法

    這篇文章主要介紹了Apache添加多端口及實(shí)現(xiàn)單ip多端口映射的方法的相關(guān)資料,需要的朋友可以參考下
    2016-02-02
  • Linux seq命令的使用方法

    Linux seq命令的使用方法

    這篇文章主要介紹了Linux seq命令的使用方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • 簡單實(shí)現(xiàn)linux聊天室程序

    簡單實(shí)現(xiàn)linux聊天室程序

    這篇文章主要介紹了簡單實(shí)現(xiàn)linux聊天室程序的詳細(xì)代碼,幫助大家了解聊天室的實(shí)現(xiàn)原理,感興趣的小伙伴們可以參考一下
    2015-12-12
  • linux之普通用戶與root用戶之間切換方法

    linux之普通用戶與root用戶之間切換方法

    下面小編就為大家?guī)硪黄猯inux之普通用戶與root用戶之間切換方法。小編覺得挺不錯(cuò)的?,F(xiàn)在就分享給大家。也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-12-12
  • Ubuntu部署python3.5的開發(fā)和運(yùn)行環(huán)境

    Ubuntu部署python3.5的開發(fā)和運(yùn)行環(huán)境

    這篇文章主要介紹了Ubuntu部署python3.5的開發(fā)和運(yùn)行環(huán)境,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-01-01
  • windows10安裝ubuntu20.04雙系統(tǒng)詳細(xì)圖文教程

    windows10安裝ubuntu20.04雙系統(tǒng)詳細(xì)圖文教程

    這篇文章主要介紹了windows10安裝ubuntu20.04雙系統(tǒng)詳細(xì)圖文教程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • linux 打包當(dāng)前文件夾下所有文件的方法

    linux 打包當(dāng)前文件夾下所有文件的方法

    下面小編就為大家分享一篇linux 打包當(dāng)前文件夾下所有文件的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-04-04
  • Linux堆內(nèi)存修改及清理命令方式

    Linux堆內(nèi)存修改及清理命令方式

    這篇文章主要介紹了Linux堆內(nèi)存修改及清理命令方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • 谷歌云Google Cloud 啟用Ubuntu的SSH服務(wù)

    谷歌云Google Cloud 啟用Ubuntu的SSH服務(wù)

    默認(rèn)情況下,當(dāng) Ubuntu 最初被安裝的時(shí)候,通過 SSH 進(jìn)行遠(yuǎn)程訪問是不被允許的,在 Ubuntu 上啟用 SSH 非常的簡單直接,需要的朋友可以參考下
    2023-12-12
  • 詳解如何在Ubuntu 16.04上增加Swap分區(qū)

    詳解如何在Ubuntu 16.04上增加Swap分區(qū)

    本篇文章主要介紹了詳解如何在Ubuntu 16.04上增加Swap分區(qū),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-05-05

最新評(píng)論