你知道在apache中怎么開啟偽靜態嗎?那么今天愛站小編將為大家詳細介紹apache開啟偽靜態的方法,相信這是很多小伙伴們都是非常好奇的,那么下面就一起去看看吧。
環境:
系統 Windows
Apache 2.2
加載Rewrite模塊:
在conf目錄下httpd.conf中找到
LoadModule rewrite_module modules/mod_rewrite.so
這句,去掉前邊的注釋符號“#”,或添加這句。
允許在任何目錄中使用“.htaccess”文件,將“AllowOverride”改成“All”(默認為“None”):
AllowOverride controls what directives may be placed in .htaccess files.
It can be “All”, “None”, or any combination of the keywords:
Options FileInfo AuthConfig Limit
AllowOverride All
在Windows系統下不能直接建立“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用記事本編輯。
Apache Rewrite模塊的簡單應用:
Rewrite的所有判斷規則均基於Perl風格的正則表達式,通過以下基礎示例能寫出符合自己跳轉需求的代碼。
1、請求跳轉
目的是如果請求為.jsp文件,則跳轉至其它域名訪問。
例如:訪問www.aizhan.com/a.php跳轉至b.jb51.net/b.php網頁,訪問www.aizhan.com/news/index.php跳轉至b.jb51.net/news/index.php網頁
注意:不是使用HTML技術中的meta或者javascript方式,因為www.aizhan.com/a.php這個文件並不存在,用的是Apache2.2服務器中的Rewrite模塊。
修改 .htaccess或apche的配置文件httpd.conf文件,添加以下內容
RewriteEngine on
#開啟Rewrite模塊
RewriteRule (.*).php$ http://b.jb51.net/$1.jsp [R=301,L,NC]
#截獲所有.jsp請求,跳轉到http://b.jb51.net/加上原來的請求再加上.php。R=301為301跳轉,L為rewrite規則到此終止,NC為不區分大小寫
2、域名跳轉
如果請求為old.jb51.net下的所有URL,跳轉至b.jb51.net
RewriteEngine on
#開啟Rewrite模塊
RewriteCond %{REMOTE_HOST} ^old.studenthome.cn$ [NC]
#針對host為old.jb51.net的主機做處理,^為開始字符,$為結尾字符
RewriteRule (.*) http://b.jb51.net/$1 [R=301,L,NC]
3、防盜鏈
如果本網站的圖片不想讓其它網站調用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下內容
RewriteEngine on
#開啟Rewrite模塊
RewriteCond %{HTTP_REFERER} !^$
#如果不是直接輸入圖片地址
RewriteCond %{HTTP_REFERER} !img.jb51.net$ [NC]
#且如果不是img.jb51.net所有子域名調用的
RewriteCond %{HTTP_REFERER} !img.jb51.net/(.)$ [NC]
RewriteCond %{HTTP_REFERER} !zhuaxia.com [NC]
RewriteCond %{HTTP_REFERER} !google.com [NC]
RewriteCond %{HTTP_REFERER} !google.cn [NC]
RewriteCond %{HTTP_REFERER} !baidu.com [NC]
RewriteCond %{HTTP_REFERER} !feedsky.com [NC]
RewriteRule (.).(jpg|jpeg|jpe|gif|bmp|png|wma|mp3|wav|avi|mp4|flv|swf)$ [R=301,L,NC]
#截獲所有.jpg或.jpeg……請求,跳轉到提示錯誤的圖片,注:該圖片不能在原域名下,也不能在該.htaccess文件有效控制的文件夾中
4、不需要定義.htaccess文件
在Apache2\conf\httpd.conf 最后一行添加
RewriteEngine On
RewriteRule ^(.)-htm-(.)$ $1.php?$2
重啟Apache
登陸后台開啟全偽
看完后你知道apache怎么開啟偽靜態了嗎?