实例:将所有lishiba.com lishiba.cn的域名都跳转到www.lishiba.com这个域名,避免泛解析,有利于SEO
server
{
listen 80;
server_name *.lishiba.com *.lishiba.cn
index index.html index.php;
root /xxxxx/webroot;
if ($host != 'www.lishiba.com' ) {
rewrite ^/(.*)$ http://www.lishiba.com/$1 permanent;
}
apache 重定向
<VirtualHost *:80>DocumentRoot /wwwroot/ErrorLog "logs/vhost-error_log"CustomLog "logs/vhost-access_log" commonRewriteEngine OnRewriteCond %{HTTP_HOST} !^www.lishiba.com$ [NC]RewriteRule ^(.*) http://www.lishiba.com/ [L,R=301]</VirtualHost>
注释拓展:
last – 基本上都用这个Flag。
break – 中止Rewirte,不在继续匹配
redirect – 返回临时重定向的HTTP状态302
permanent – 返回永久重定向的HTTP状态301
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)/ {
禁止以/data开头的文件
可以禁止/data/下多级目录下.log.txt等请求;
location ~ ^/data {
禁止单个目录
不能禁止.log.txt能请求
location /searchword/cron/ {
禁止单个文件
location ~ /data/sql/data.sql {
给favicon.ico和robots.txt设置过期时间;
这里为favicon.ico为99 天,robots.txt为7天并不记录404错误日志
location ~(favicon.ico) {
log_not_found off;
expires 99d;
location ~(robots.txt) {
expires 7d;
设定某个文件的过期时间;这里为600秒,并不记录访问日志
location ^~ /html/scripts/loadhead_1.js {
access_log off;
root /opt/lampp/htdocs/web;
expires 600;
举报/反馈

XWDESIGN

232获赞 219粉丝
金华网络公司,金华SEO,网站建设,小程序
金华市悦企信息技术有限公司
关注
0
0
收藏
分享