日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > linux >内容正文

linux

杰奇linux伪静态,常用的13个.htaccess重写URL的伪静态规则

發(fā)布時間:2025/3/21 linux 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 杰奇linux伪静态,常用的13个.htaccess重写URL的伪静态规则 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

網站偽靜態(tài)重寫url是提高URL標準化一個比較實用的方法:

下面是我收集的13種偽靜態(tài)重寫規(guī)則,

使用方法:把規(guī)則里的域名 http://example.com 改成你自己的網站域名

放在網站根目錄下的.htaccess文件里就可以啦。

一般偽靜態(tài)需要

1、偽靜態(tài)規(guī)則文件

2、網站后臺的支持,比如wordpress除了修改好.htaccess文件的規(guī)則還需要到后臺【設置】-【固定鏈接】里去設置好

3、空間支持,一般情況下商用的空間只有l(wèi)inux空間才支持.htaccess文件

1.去掉域名中的www標記

RewriteCond?%{HTTP_HOST}?!^example\.com$?[NC]

RewriteRule?.??http://example.com%{REQUEST_URI}?[R=301,L]

2.去掉www標記,但是保存子域名

RewriteCond?%{HTTP_HOST}?^www\.(([a-z0-9_]+\.)?example\.com)$?[NC]

RewriteRule?.??http://%1%{REQUEST_URI}?[R=301,L]

這里,當匹配到1%變量以后,子域名才會在%2(內部原子)中抓取到,而我們需要的正是這個%1變量。

3.給子域名加www標記

RewriteCond?%{HTTP_HOST}?^([a-z.]+)?example\.com$?[NC]

RewriteCond?%{HTTP_HOST}?!^www\.?[NC]

RewriteRule?.??http://www.%1example.com%{REQUEST_URI}?[R=301,L]

這個規(guī)則抓取二級域名的%1變量,如果不是以www開始,那么就加www,以前的域名以及{REQUEST_URI}會跟在其后。

4.防止圖片盜鏈

一些站長不擇手段的將你的圖片盜鏈在他們網站上,耗費你的帶寬。你可以加一下代碼阻止這種行為。

RewriteCond?%{HTTP_REFERER}?!^$

RewriteCond?%{HTTP_REFERER}?!^http://(www\.)?example\.com/?[NC]

RewriteRule?\.(gif|jpg|png)$?-?[F]

如果{HTTP_REFERER}值不為空,或者不是來自你自己的域名,這個規(guī)則用[F]FLAG阻止以gif|jpg|png?結尾的URL

如果對這種盜鏈你是堅決鄙視的,你還可以改變圖片,讓訪問盜鏈網站的用戶知道該網站正在盜用你的圖片。

RewriteCond?%{HTTP_REFERER}?!^$

RewriteCond?%{HTTP_REFERER}?!^http://(www\.)?example\.com/.*$?[NC]

RewriteRule?\.(gif|jpg|png)$?你的圖片地址?[R=301,L]

除了阻止圖片盜鏈鏈接,以上規(guī)則將其盜鏈的圖片全部替換成了你設置的圖片。

你還可以阻止特定域名盜鏈你的圖片:

RewriteCond?%{HTTP_REFERER}?!^http://(www\.)?leech_site\.com/?[NC]

RewriteRule?\.(gif|jpg|png)$?-?[F,L]

這個規(guī)則將阻止域名黑名單上所有的圖片鏈接請求。

當然以上這些規(guī)則都是以{HTTP_REFERER}獲取域名為基礎的,如果你想改用成IP地址,用{REMOTE_ADDR}就可以了。

5.如果文件不存在重定向到404頁面

如果你的主機沒有提供404頁面重定向服務,那么我們自己創(chuàng)建。

RewriteCond?%{REQUEST_FILENAME}?!-f

RewriteCond?%{REQUEST_FILENAME}?!-d

RewriteRule?.??/404.php?[L]

這里-f匹配的是存在的文件名,-d匹配的存在的路徑名。這段代碼在進行404重定向之前,會判斷你的文件名以及路徑名是否存在。你還可以在404頁面上加一個?url=$1參數:

RewriteRule?^/?(.*)$?/404.php?url=$1?[L]

這樣,你的404頁面就可以做一些其他的事情,例如默認信心,發(fā)一個郵件提醒,加一個搜索,等等。

6.重命名目錄

如果你想在網站上重命名目錄,試試這個:

RewriteRule?^/?old_directory/([a-z/.]+)$?new_directory/$1?[R=301,L]

在規(guī)則里我添加了一個“.”(注意不是代表得所有字符,前面有轉義符)來匹配文件的后綴名。

7.將.html后綴名轉換成.php

前提是.html文件能繼續(xù)訪問的情況下,更新你的網站鏈接。

RewriteRule?^/?([a-z/]+)\.html$?$1.php?[L]

這不是一個網頁重定向,所以訪問者是不可見的。讓他作為一個永久重定向(可見的),將FLAG修改[R=301,L]。

8.創(chuàng)建無文件后綴名鏈接

如果你想使你的PHP網站的鏈接更加簡潔易記-或者隱藏文件的后綴名,試試這個:

RewriteRule?^/?([a-z]+)$?$1.php?[L]

如果網站混有PHP以及HTML文件,你可以用RewriteCond先判斷該后綴的文件是否存在,然后進行替換:

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.檢查查詢變量里的特定參數

如果在URL里面有一個特殊的參數,你可用RewriteCond鑒別其是否存在:

RewriteCond?%{QUERY_STRING}?!uniquekey=

RewriteRule?^/?script_that_requires_uniquekey\.php$?other_script.php?[QSA,L]

以上規(guī)則將檢查{QUERY_STRING}里面的uniquekey參數是否存在,如果{REQUEST_URI}值為script_that_requires_uniquekey,將會定向到新的URL。

10.刪除查詢變量

Apache的mod_rewrite模塊會自動辨識查詢變量,除非你做了以下改動:

a).分配一個新的查詢參數(你可以用[QSA,L]FLAG保存最初的查詢變量)

b).在文件名后面加一個“?”(比如index.php?)。符號“?”不會在瀏覽器的地址欄里顯示。

11.用新的格式展示當前URI

如果這就是我們當前正在運行的URLs:/index.php?id=nnnn。我們非常希望將其更改成/nnnn并且讓搜索引擎以新格式展現。首先,我

們?yōu)榱俗屗阉饕娓鲁尚碌?#xff0c;得將舊的URLs重定向到新的格式,但是,我們還得保證以前的index.php照樣能夠運行。是不是被我搞迷糊了?

實現以上功能,訣竅就在于在查詢變量中加了一個訪問者看不到的標記符“marker”。我們只將查詢變量中沒有出現“marker”標記的鏈接進行重定

向,然后將原有的鏈接替換成新的格式,并且通過[QSA]FLAG在已有的參數加一個“marker”標記。以下為實現的方式:

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.example.com/index.php?id=nnnn,不包含marker,所以被第一個規(guī)則永久重

定向到http://www.example.com/nnnn,第二個規(guī)則將http://www.example.com/nnnn反定向到

http://www.example.com/index.php?marker&id=nnnn,并且加了marker以及id=nnnn兩

個變量,最后mod_rewrite就開始進行處理過程。

第二次匹配,marker被匹配,所以忽略第一條規(guī)則,這里有一個“.”字符會出現在http://www.example.com/index.php?marker&id=nnnn中,所以第二條規(guī)則也會被忽略,這樣我們就完成了。

注意,這個解決方案要求Apache的一些擴展功能,所以如果你的網站放于在共享主機中會遇到很多障礙。

12.保證安全服務啟用

Apache可以用兩種方法辨別你是否開啟了安全服務,分別引用{HTTPS}和{SERVER_PORT}變量:

RewriteCond?%{REQUEST_URI}?^secure_page\.php$

RewriteCond?%{HTTPS}?!on

RewriteRule?^/?(secure_page\.php)$?https://www.example.com/$1?[R=301,L]

以上規(guī)則測試{REQUEST_URI}值是否等于我們的安全頁代碼,并且{HTTPS}不等于on。如果這兩個條件同時滿足,請求將被重定向到安全服務URI.另外你可用{SERVER_PORT}做同樣的測試,443是常用的安全服務端口

RewriteCond?%{REQUEST_URI}?^secure_page\.php$

RewriteCond?%{SERVER_PORT}?!^443$

RewriteRule?^/?(secure_page\.php)$?https://www.example.com/$1?[R=301,L]

13.在特定的頁面上強制執(zhí)行安全服務

遇到同一個服務器根目錄下分別有一個安全服務域名和一個非安全服務域名,所以你就需要用RewriteCond?判斷安全服務端口是否占用,并且只將以下列表的頁面要求為安全服務:

RewriteCond?%{SERVER_PORT}?!^443$

RewriteRule?^/?(page1|page2|page3|page4|page5)$?https://www.example.com/%1[R=301,L]

以下是怎樣將沒有設置成安全服務的頁面返回到80端口:

RewriteCond?%{?SERVER_PORT?}?^443$

RewriteRule?!^/?(page6|page7|page8|page9)$http://www.example.com%{REQUEST_URI}?[R=301,L]

其實Rewrite里運用最多的還應該是正則表達式,如果了解點兒正則的話,寫起這個規(guī)則還是比較簡單的。

總結

以上是生活随笔為你收集整理的杰奇linux伪静态,常用的13个.htaccess重写URL的伪静态规则的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。