三、nginx301跳转302跳转

1 301跳转设置:
2   server {
3   listen 80;
4   server_name downcc.com;
5   rewrite ^/(.*) http://www.downcc.com/$1 permanent;
6   access_log off;
7   }
301跳转设置:
1 302跳转设置:
2   server {
3   listen 80;
4   server_name downcc.com;
5   rewrite ^/(.*) http://www.downcc.com/$1 redirect;
6   access_log off;
7   }
302跳转设置

last – 基本上都用这个Flag。

  break – 中止Rewirte,不在继续匹配

  redirect – 返回临时重定向的HTTP状态302

  permanent – 返回永久重定向的HTTP状态301

  Nginx的重定向用到了Nginx的HttpRewriteModule,下面简单解释以下如何使用的方法:

  rewrite命令

  nginx的rewrite相当于apache的rewriterule(大多数情况下可以把原有apache的rewrite规则加上引号就可以直接使用),它可以用在server,location 和IF条件判断块中,命令格式如下:

  rewrite 正则表达式 替换目标 flag标记

  flag标记可以用以下几种格式:

  last – 基本上都用这个Flag。

  break – 中止Rewirte,不在继续匹配

  redirect – 返回临时重定向的HTTP状态302

  permanent – 返回永久重定向的HTTP状态301

  特别注意:

  last和break用来实现URL重写,浏览器地址栏的URL地址不变,但是在服务器端访问的路径发生了变化;

  redirect和permanent用来实现URL跳转,浏览器地址栏会显示跳转后的URL地址;

  例如下面这段设定nginx将某个目录下面的文件重定向到另一个目录,$2对应第二个括号(.*)中对应的字符串:

1 location /download/ {
2   rewrite ^(/download/.*)/m/(.*)..*$ $1/nginx-rewrite/$2.gz break;
3   }

nginx重定向的IF条件判断

  在server和location两种情况下可以使用nginx的IF条件判断,条件可以为以下几种:

  正则表达式

  如:

  匹配判断

  ~ 为区分大小写匹配; !~为区分大小写不匹配

  ~* 为不区分大小写匹配;!~为不区分大小写不匹配

  例如下面设定nginx在用户使用ie的使用重定向到/nginx-ie目录下:

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

文件和目录判断

  -f和!-f判断是否存在文件

  -d和!-d判断是否存在目录

  -e和!-e判断是否存在文件或目录

  -x和!-x判断文件是否可执行

  例如下面设定nginx在文件和目录不存在的时候重定向:

1  if (!-e $request_filename) {
2   proxy_pass http://127.0.0.1;
3   }
4   return

返回http代码,例如设置nginx防盗链:

1 location ~* .(gif|jpg|png|swf|flv)$ {
2   valid_referers none blocked www.downcc.com www.test1.com;
3   if ($invalid_referer) {
4   return 404;
5   }
6   }
 1 worker_processes 1;  
 2 error_log /usr/local/nginx/logs/error.log crit;  
 3 pid /usr/local/nginx/logs/nginx.pid;  
 4 events {  
 5 worker_connections 64;  
 6 }  
 7   
 8 http {  
 9 include /usr/local/nginx/conf/mime.types;  
10 default_type application/octet-stream;  
11   
12 #charset gb2312;  
13   
14 server_names_hash_bucket_size 128;  
15 client_header_buffer_size 32k;  
16 large_client_header_buffers 4 32k;  
17   
18 keepalive_timeout 60;  
19   
20 fastcgi_connect_timeout 300;  
21 fastcgi_send_timeout 300;  
22 fastcgi_read_timeout 300;  
23 fastcgi_buffer_size 128k;  
24 fastcgi_buffers 4 128k;  
25 fastcgi_busy_buffers_size 128k;  
26 fastcgi_temp_file_write_size 128k;  
27 client_body_temp_path /usr/local/nginx/client_body_temp;  
28 proxy_temp_path /usr/local/nginx/proxy_temp;  
29 fastcgi_temp_path /usr/local/nginx/fastcgi_temp;  
30   
31 gzip on;  
32 gzip_min_length 1k;  
33 gzip_buffers 4 16k;  
34 gzip_http_version 1.0;  
35 gzip_comp_level 2;  
36 gzip_types text/plain application/x-javascript text/css application/xml;  
37 gzip_vary on;  
38   
39 client_header_timeout 3m;  
40 client_body_timeout 3m;  
41 send_timeout 3m;  
42 sendfile on;  
43 tcp_nopush on;  
44 tcp_nodelay on;  
45 #设定虚拟主机  
46 include /usr/local/nginx/conf/vhost/aa.test.com;
47 }
个人实验环境nginx.conf配置
 1 server {  
 2 listen 192.168.1.101:80; #换成你的IP地址  
 3 client_max_body_size 100M;  
 4 #server_name 192.168.1.101; #换成你的域名  
 5 charset gb2312;  
 6 index index.html index.htm index.php;  
 7 root /usr/local/nginx/html; #你的站点路径  
 8 access_log off;
 9 
10 
11 if (-d $request_filename) {  
12     rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent;  
13     rewrite ^/(.*)([^/])$ http://www.baidu.com/ permanent;  
14 
15 }
16 #301跳转
17 if ($host = '192.168.1.101' ) {   
18     rewrite ^/($) http://www.cnblogs.com/nb-blog permanent; 
19             }
20 if ($host = '192.168.1.101' ) {   
21     rewrite ^/(tomcat)$ http://192.168.1.101:8080/manager break;
22                 }
个人实验环境
原文地址:https://www.cnblogs.com/nb-blog/p/5271097.html