亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在nginx中使用rewrite 配置偽靜態

發布時間:2021-03-09 15:34:55 來源:億速云 閱讀:339 作者:Leah 欄目:服務器

本篇文章為大家展示了怎么在nginx中使用rewrite 配置偽靜態,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

正則表達式匹配,其中: 

* ~ 為區分大小寫匹配 
* ~* 為不區分大小寫匹配 
* !~和!~*分別為區分大小寫不匹配及不區分大小寫不匹配 
文件及目錄匹配,其中: 

* -f和!-f用來判斷是否存在文件 
* -d和!-d用來判斷是否存在目錄 
* -e和!-e用來判斷是否存在文件或目錄 
* -x和!-x用來判斷文件是否可執行 
flag標記有: 

* last 相當于Apache里的[L]標記,表示完成rewrite 
* break 終止匹配, 不再匹配后面的規則 
* redirect 返回302臨時重定向 地址欄會顯示跳轉后的地址 
* permanent 返回301永久重定向 地址欄會顯示跳轉后的地址 
一些可用的全局變量有,可以用做條件判斷(待補全) 

復制代碼代碼如下:


$args 
$content_length 
$content_type 
$document_root 
$document_uri 
$host 
$http_user_agent 
$http_cookie 
$limit_rate 
$request_body_file 
$request_method 
$remote_addr 
$remote_port 
$remote_user 
$request_filename 
$request_uri 
$query_string 
$scheme 
$server_protocol 
$server_addr 
$server_name 
$server_port 
$uri 


結合QeePHP的例子 

復制代碼代碼如下:


if (!-d $request_filename) { 
rewrite ^/([a-z-A-Z]+)/([a-z-A-Z]+)/?(.*)$ /index.php?namespace=user&controller=$1&action=$2&$3 last; 
rewrite ^/([a-z-A-Z]+)/?$ /index.php?namespace=user&controller=$1 last; 
break; 


多目錄轉成參數 

復制代碼代碼如下:


abc.domian.com/sort/2 => abc.domian.com/index.php?act=sort&name=abc&id=2 

if ($host ~* (.*)\.domain\.com) { 
set $sub_name $1; 
rewrite ^/sort\/(\d+)\/?$ /index.php?act=sort&cid=$sub_name&id=$1 last; 


目錄對換 

復制代碼代碼如下:


/123456/xxxx -> /xxxx?id=123456 
rewrite ^/(\d+)/(.+)/ /$2?id=$1 last; 


例如下面設定nginx在用戶使用ie的使用重定向到/nginx-ie目錄下: 

復制代碼代碼如下:


if ($http_user_agent ~ MSIE) { 
rewrite ^(.*)$ /nginx-ie/$1 break; 


目錄自動加“/” 

復制代碼代碼如下:


if (-d $request_filename){ 
rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent; 


禁止htaccess 

復制代碼代碼如下:


location ~/\.ht { 
deny all; 


禁止多個目錄 

復制代碼代碼如下:


location ~ ^/(cron|templates)/ { 
deny all; 
break; 


禁止以/data開頭的文件 
可以禁止/data/下多級目錄下.log.txt等請求; 

復制代碼代碼如下:


location ~ ^/data { 
deny all; 


禁止單個目錄 
不能禁止.log.txt能請求 

復制代碼代碼如下:


location /searchword/cron/ { 
deny all; 


禁止單個文件 

復制代碼代碼如下:


location ~ /data/sql/data.sql { 
deny all; 


給favicon.ico和robots.txt設置過期時間; 
這里為favicon.ico為99天,robots.txt為7天并不記錄404錯誤日志 

復制代碼代碼如下:


location ~(favicon.ico) { 
log_not_found off; 
expires 99d; 
break; 


location ~(robots.txt) { 
log_not_found off; 
expires 7d; 
break; 


設定某個文件的過期時間;這里為600秒,并不記錄訪問日志 

復制代碼代碼如下:


location ^~ /html/scripts/loadhead_1.js { 
access_log off; 
root /opt/lampp/htdocs/web; 
expires 600; 
break; 


文件反盜鏈并設置過期時間 
這里的return 412 為自定義的http狀態碼,默認為403,方便找出正確的盜鏈的請求 
“rewrite ^/ https://cache.yisu.com/upload/information/20210309/289/48136.jpg;”顯示一張防盜鏈圖片 
“access_log off;”不記錄訪問日志,減輕壓力 
“expires 3d”所有文件3天的瀏覽器緩存 

復制代碼代碼如下:


location ~* ^.+\.(jpg|jpeg|gif|png|swf|rar|zip|css|js)$ { 
valid_referers none blocked *.ZZVIPS.com *.ZZVIPS.net localhost 208.97.167.194; 
if ($invalid_referer) { 
rewrite ^/ https://cache.yisu.com/upload/information/20210309/289/48136.jpg; 
return 412; 
break; 

access_log off; 
root /opt/lampp/htdocs/web; 
expires 3d; 
break; 


只充許固定ip訪問網站,并加上密碼 

復制代碼代碼如下:


root /opt/htdocs/www; 
allow 208.97.167.194; 
allow 222.33.1.2; 
allow 231.152.49.4; 
deny all; 
auth_basic "C1G_ADMIN"; 
auth_basic_user_file htpasswd; 


將多級目錄下的文件轉成一個文件,增強seo效果 

復制代碼代碼如下:


/job-123-456-789.html 指向/job/123/456/789.html 
rewrite ^/job-([0-9]+)-([0-9]+)-([0-9]+)\.html$ /job/$1/$2/jobshow_$3.html last; 


將根目錄下某個文件夾指向2級目錄 
如/shanghaijob/ 指向 /area/shanghai/ 
如果你將last改成permanent,那么瀏覽器地址欄顯是/location/shanghai/ 

復制代碼代碼如下:


rewrite ^/([0-9a-z]+)job/(.*)$ /area/$1/$2 last; 


上面例子有個問題是訪問/shanghai 時將不會匹配 

復制代碼代碼如下:


rewrite ^/([0-9a-z]+)job$ /area/$1/ last; 
rewrite ^/([0-9a-z]+)job/(.*)$ /area/$1/$2 last; 


這樣/shanghai 也可以訪問了,但頁面中的相對鏈接無法使用, 
如./list_1.html真實地址是/area/shanghia/list_1.html會變成/list_1.html,導至無法訪問。 

那我加上自動跳轉也是不行咯 
(-d $request_filename)它有個條件是必需為真實目錄,而我的rewrite不是的,所以沒有效果 

復制代碼代碼如下:


if (-d $request_filename){ 
rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent; 


知道原因后就好辦了,讓我手動跳轉吧 

復制代碼代碼如下:


rewrite ^/([0-9a-z]+)job$ /$1job/ permanent; 
rewrite ^/([0-9a-z]+)job/(.*)$ /area/$1/$2 last; 


文件和目錄不存在的時候重定向: 

復制代碼代碼如下:


if (!-e $request_filename) { 
proxy_pass http://127.0.0.1; 


域名跳轉 

復制代碼代碼如下:


server 

listen 80; 
server_name jump.ZZVIPS.com; 
index index.html index.htm index.php; 
root /opt/lampp/htdocs/www; 
rewrite ^/ http://www.ZZVIPS.com/; 
access_log off; 


多域名轉向 

復制代碼代碼如下:


server_name www.ZZVIPS.com www.ZZVIPS.net; 
index index.html index.htm index.php; 
root /opt/lampp/htdocs; 
if ($host ~ "ZZVIPS\.net") { 
rewrite ^(.*) http://www.ZZVIPS.com$1 permanent; 


三級域名跳轉 

復制代碼代碼如下:


if ($http_host ~* "^(.*)\.i\.ZZVIPS\.com$") { 
rewrite ^(.*) http://top.yingjiesheng.com$1; 
break; 


域名鏡向 

復制代碼代碼如下:


server 

listen 80; 
server_name mirror.ZZVIPS.com; 
index index.html index.htm index.php; 
root /opt/lampp/htdocs/www; 
rewrite ^/(.*) http://www.ZZVIPS.com/$1 last; 
access_log off; 


某個子目錄作鏡向 

復制代碼代碼如下:


location ^~ /zhaopinhui { 
rewrite ^.+ http://zph.ZZVIPS.com/ last; 
break; 

discuz ucenter home (uchome) rewrite 

rewrite ^/(space|network)-(.+)\.html$ /$1.php?rewrite=$2 last; 
rewrite ^/(space|network)\.html$ /$1.php last; 
rewrite ^/([0-9]+)$ /space.php?uid=$1 last; 
discuz 7 rewrite 

rewrite ^(.*)/archiver/((fid|tid)-[\w\-]+\.html)$ $1/archiver/index.php?$2 last; 
rewrite ^(.*)/forum-([0-9]+)-([0-9]+)\.html$ $1/forumdisplay.php?fid=$2&page=$3 last; 
rewrite ^(.*)/thread-([0-9]+)-([0-9]+)-([0-9]+)\.html$ $1/viewthread.php?tid=$2&extra=page\%3D$4&page=$3 last; 
rewrite ^(.*)/profile-(username|uid)-(.+)\.html$ $1/viewpro.php?$2=$3 last; 
rewrite ^(.*)/space-(username|uid)-(.+)\.html$ $1/space.php?$2=$3 last; 
rewrite ^(.*)/tag-(.+)\.html$ $1/tag.php?name=$2 last; 


給discuz某版塊單獨配置域名 

復制代碼代碼如下:


server_name bbs.ZZVIPS.com news.ZZVIPS.com; 

location = / { 
if ($http_host ~ news\.ZZVIPS.com$) { 
rewrite ^.+ http://news.ZZVIPS.com/forum-831-1.html last; 
break; 


discuz ucenter 頭像 rewrite 優化 

復制代碼代碼如下:


location ^~ /ucenter { 
location ~ .*\.php?$ 

#fastcgi_pass unix:/tmp/php-cgi.sock; 
fastcgi_pass 127.0.0.1:9000; 
fastcgi_index index.php; 
include fcgi.conf; 


location /ucenter/data/avatar { 
log_not_found off; 
access_log off; 
location ~ /(.*)_big\.jpg$ { 
error_page 404 /ucenter/images/noavatar_big.gif; 

location ~ /(.*)_middle\.jpg$ { 
error_page 404 /ucenter/images/noavatar_middle.gif; 

location ~ /(.*)_small\.jpg$ { 
error_page 404 /ucenter/images/noavatar_small.gif; 

expires 300; 
break; 


jspace rewrite 

復制代碼代碼如下:


location ~ .*\.php?$ 

#fastcgi_pass unix:/tmp/php-cgi.sock; 
fastcgi_pass 127.0.0.1:9000; 
fastcgi_index index.php; 
include fcgi.conf; 


location ~* ^/index.php/ 

rewrite ^/index.php/(.*) /index.php?$1 break; 
fastcgi_pass 127.0.0.1:9000; 
fastcgi_index index.php; 
include fcgi.conf; 

上述內容就是怎么在nginx中使用rewrite 配置偽靜態,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

漾濞| 永善县| 潼南县| 邵阳县| 镇平县| 洛南县| 荃湾区| 武夷山市| 商丘市| 勐海县| 青冈县| 阳谷县| 抚州市| 鄂州市| 即墨市| 兴山县| 松原市| 奈曼旗| 平塘县| 龙泉市| 泾源县| 苏尼特左旗| 泗水县| 搜索| 镇原县| 泌阳县| 囊谦县| 镇巴县| 丰城市| 尼玛县| 山西省| 遂昌县| 印江| 固阳县| 泰安市| 吴忠市| 阳曲县| 陈巴尔虎旗| 鹰潭市| 四子王旗| 巨鹿县|