首页 运维 nginx Nginx Rewrite模块应用的场景有哪些

Nginx Rewrite模块应用的场景有哪些

May 24, 2023 pm 03:52 PM
nginx rewrite

应用场景1——基于域名的跳转

公司旧域名 ,因业务需求有变更,需要使用新域名www.kgc.com 代替

1.不能废除旧域名
2.从旧域名跳转到新域名,且保持其参数不变

部署环境

一台linux服务器(192.168.142.130)
一台测试主机windows 7

1,安装nginx服务

[root@localhost ~]# rpm -uvh http://nginx.org/packages/centos/7/noarch/rpms/nginx-release-centos-7-0.el7.ngx.noarch.rpm
#安装nginx官方源

[root@localhost ~]# yum install nginx -y  
#yum安装nginx
登录后复制

2,修改nginx默认配置文件

[root@localhost ~]# vim /etc/nginx/conf.d/default.conf ##修改默认配置文件
server {
    listen    80;
    server_name www.accp.com;  ##修改主机名

    #charset koi8-r;
    access_log /var/log/nginx/www.accp.com-access.log main;  ##开启日志服务
登录后复制

3,安装bind解析服务

[root@localhost ~]# yum install bind -y
登录后复制

4,修改主配置文件(named.conf)

[root@localhost ~]# vim /etc/named.conf 
options {
                listen-on port 53 { any; };     ##监听所有
                ...
                allow-query   { any; };      ##允许所有
登录后复制

5,修改区域配置文件(named.rfc1912.zones)

[root@localhost ~]# vim /etc/named.rfc1912.zones  ##配置区域配置文件

zone "accp.com" in {
                type master;
                file "accp.com.zone";       ##accp区域数据配置文件
                allow-update { none; };
};
登录后复制

6,修改区域数据配置文件(accp.com.zone)

[root@localhost ~]# cd /var/named/ 
[root@localhost named]# cp -p named.localhost accp.com.zone  ##复制模板
[root@localhost named]# vim accp.com.zone  ##修改区域配置文件

$ttl 1d
@    in soa @ rname.invalid. (
                                    1d   ; refresh
                                    1h   ; retry
                                    1w   ; expire
                                    3h )  ; minimum
                ns   @
                a    127.0.0.1
www in a    192.168.142.130         ##本机地址
[root@localhost named]# systemctl start named   ##开启dns服务
[root@localhost named]# systemctl stop firewalld.service  ##关闭防火墙
[root@localhost named]# setenforce 0
[root@localhost named]# systemctl start nginx  ##开启nginx服务
登录后复制

7,用测试机测试网页

Nginx Rewrite模块应用的场景有哪些

8,修改配置文件,设置域名跳转

[root@localhost named]# vim /etc/nginx/conf.d/default.conf ##修改配置文件
  server {
      listen    80;
      server_name www.accp.com;

      #charset koi8-r;
      access_log /var/log/nginx/www.accp.com-access.log main;

      location / {
          if ($host = "www.accp.com"){    ##匹配如果域名是老域名
                  rewrite ^/(.*)$ http://www.kgc.com/$1 permanent;  ##则永久设置跳转新域名
          }
          root  /usr/share/nginx/html;
          index index.html index.htm;
      }
登录后复制

9,添加新域名解析

[root@localhost named]# vim /etc/named.rfc1912.zones 

zone "kgc.com" in {
                type master;
                file "kgc.com.zone";       ##accp区域数据配置文件
                allow-update { none; };
};

[root@localhost named]# cp -p /var/named/accp.com.zone /var/named/kgc.com.zone
##复制区域数据配置文件为kgc的数据配置文件
[root@localhost named]# systemctl restart named  ##重启解析服务
[root@localhost named]# systemctl restart nginx   ##重启nginx服务
登录后复制

10,用旧域名访问,查看网页跳转

Nginx Rewrite模块应用的场景有哪些

Nginx Rewrite模块应用的场景有哪些

11,旧域名后加上参数,查看跳转新域名时是否有参数

Nginx Rewrite模块应用的场景有哪些

Nginx Rewrite模块应用的场景有哪些

应用场景2——基于客户端ip访问跳转

公司业务版本上线,所有ip访问任何内容都显示一个固定维护页面,只有公司ip访问正常

1,修改nginx默认配置文件

[root@localhost ~]# cd /etc/nginx/conf.d/
[root@localhost conf.d]# vim default.conf 

server {
    listen    80;
    server_name www.accp.com;
    #charset koi8-r;
    access_log /var/log/nginx/www.accp.com-access.log main;
    #设置是否合法的ip标志
    set $rewrite true;     ##设置变量为真
    #判断是否为合法的ip
    if ($remote_addr = "192.168.142.120"){
        set $rewrite false;  ##匹配合法ip,将变量设置为假,正常跳转页面
    }
    #非法ip进行判断打上标记
    if ($rewrite = true){        ##匹配非法ip,跳转到main的网页
        rewrite (.+) /main.html;
    }
    #匹配标记进行跳转站点
    location = /main.html {       ##精确匹配
        root /usr/share/nginx/html;  ##站点路径
    }

    location / {
        root  /usr/share/nginx/html;
        index index.html index.htm;
    }
登录后复制

2,创建非法ip站点及main的网页页面

[root@localhost conf.d]# cd /usr/share/nginx/html/ ##切换到站点中
[root@localhost html]# vim main.html  ##编辑非法ip访问网页内容
<h1>this is test web</h1>
[root@localhost html]# systemctl restart nginx  ##重启nginx服务
登录后复制

3,访问测试网页

Nginx Rewrite模块应用的场景有哪些

Nginx Rewrite模块应用的场景有哪些

应用场景3——基于旧,新域名跳转并加目录

将域名http://bbs.accp.com 下面的发帖都跳转到http://www.accp.com/bbs 且域名跳转后保持参数不变

1,修改nginx默认配置文件

[root@localhost ~]# cd /etc/nginx/conf.d/
[root@localhost conf.d]# vim default.conf  ##修改默认配置文件
server {
    listen    80;
    server_name bbs.accp.com;  ##修改服务名称

    #charset koi8-r;
    access_log /var/log/nginx/www.accp.com-access.log main;
    location /post {     ##用location匹配post目录
        rewrite (.+) http://www.accp.com/bbs$1 permanent;  ##永久重定向跳转
    }
登录后复制

2,修改dns的区域数据配置文件(accp.com.zone)

[root@localhost conf.d]# cd /var/named/
[root@localhost named]# vim accp.com.zone  ##修改区域数据配置文件
$ttl 1d
@    in soa @ rname.invalid. (
                          0    ; serial
                          1d   ; refresh
                          1h   ; retry
                          1w   ; expire
                          3h )  ; minimum
        ns   @
        a    127.0.0.1
bbs in a    192.168.142.130
[root@localhost named]# systemctl restart named  ##重启解析服务
[root@localhost named]# systemctl restart nginx   ##重启nginx服务
[root@localhost named]# echo "nameserver 192.168.142.130" > /etc/resolv.conf 
##将解析服务器地址放到本地解析配置文件中
登录后复制

3,测试网页

Nginx Rewrite模块应用的场景有哪些

Nginx Rewrite模块应用的场景有哪些

应用场景4——基于参数匹配的跳转

浏览器访问:http://www.accp.com/100-(100|200)-100.html 跳转到http://www.accp.com 页面

1,修改nginx默认配置文件

[root@localhost ~]# cd /etc/nginx/conf.d/
[root@localhost conf.d]# vim default.conf 

server {
    listen    80;
    server_name www.accp.com;
    #charset koi8-r;
    access_log /var/log/nginx/www.accp.com-access.log main;
    if ($request_uri ~ ^/100-(100|200)-(\d+).html$){    
    ##匹配正则开头为100-(100|200)-一次多次的整数html为结尾的
        rewrite (.*) http://www.accp.com permanent;    ##永久重定向跳转到主页
    }
登录后复制

2,修改dns区域数据配置文件

  [root@localhost conf.d]# vim /var/named/accp.com.zone ##修改区域数据配置文件
  www in a    192.168.142.130  
  [root@localhost conf.d]# systemctl restart named ##重启解析服务 
  [root@localhost conf.d]# systemctl restart nginx   ##重启nginx服务
登录后复制

3,测试网页

Nginx Rewrite模块应用的场景有哪些

Nginx Rewrite模块应用的场景有哪些

应用场景5——基于目录下所有php文件跳转

访问http://www.accp.com/upload/1.php 跳转到首页

1,修改nginx默认配置文件

[root@localhost ~]# cd /etc/nginx/conf.d/
  [root@localhost conf.d]# vim default.conf  ##修改默认配置文件
  server {
      listen    80;
      server_name www.accp.com;
      #charset koi8-r;
      access_log /var/log/nginx/www.accp.com-access.log main;
      location ~* /upload/.*\.php$ {     ##匹配不分大小写,匹配upload后零次或多次以.php为结尾的
          rewrite (.+) http://www.accp.com permanent;  ##跳转到首页
      }
  [root@localhost conf.d]# systemctl restart nginx  ##重启nginx服务
登录后复制

2,测试网页

Nginx Rewrite模块应用的场景有哪些

Nginx Rewrite模块应用的场景有哪些

应用场景6——基于最普通url请求的跳转,访问一个具体的页面跳转到首页

1,修改nginx默认配置文件

[root@localhost ~]# cd /etc/nginx/conf.d/
  [root@localhost conf.d]# vim default.conf  ##修改nginx默认配置文件
  server {
      listen    80;
      server_name www.accp.com;
      #charset koi8-r;
      access_log /var/log/nginx/www.accp.com-access.log main;
      location ~* ^/abc/123.html {    ##匹配某一个特定的网页
          rewrite (.+) http://www.accp.com permanent; ##跳转到首页
      }
  [root@localhost conf.d]# systemctl restart nginx  ##重启nginx服务
登录后复制

2,测试网页

Nginx Rewrite模块应用的场景有哪些

Nginx Rewrite模块应用的场景有哪些

以上是Nginx Rewrite模块应用的场景有哪些的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

tomcat服务器怎么让外网访问 tomcat服务器怎么让外网访问 Apr 21, 2024 am 07:22 AM

要让 Tomcat 服务器对外网访问,需要:修改 Tomcat 配置文件,允许外部连接。添加防火墙规则,允许访问 Tomcat 服务器端口。创建 DNS 记录,将域名指向 Tomcat 服务器公有 IP。可选:使用反向代理提升安全性和性能。可选:设置 HTTPS 以提高安全性。

html文件怎么生成网址 html文件怎么生成网址 Apr 21, 2024 pm 12:57 PM

要将 HTML 文件转换为网址,需要使用网络服务器,包括以下步骤:获取网络服务器。设置网络服务器。上传 HTML 文件。创建域名。路由请求。

nodejs项目怎么部署到服务器 nodejs项目怎么部署到服务器 Apr 21, 2024 am 04:40 AM

Node.js 项目的服务器部署步骤:准备部署环境:获取服务器访问权限、安装 Node.js、设置 Git 存储库。构建应用程序:使用 npm run build 生成可部署代码和依赖项。上传代码到服务器:通过 Git 或文件传输协议。安装依赖项:SSH 登录服务器并使用 npm install 安装应用程序依赖项。启动应用程序:使用 node index.js 等命令启动应用程序,或使用 pm2 等进程管理器。配置反向代理(可选):使用 Nginx 或 Apache 等反向代理路由流量到应用程

nodejs可以外网访问么 nodejs可以外网访问么 Apr 21, 2024 am 04:43 AM

是的,Node.js 可以外网访问。您可以使用以下方法:使用 Cloud Functions 部署函数并公开访问。使用 Express 框架创建路由并定义端点。使用 Nginx 反向代理请求到 Node.js 应用程序。使用 Docker 容器运行 Node.js 应用程序并通过端口映射公开。

如何使用 PHP 部署和维护网站 如何使用 PHP 部署和维护网站 May 03, 2024 am 08:54 AM

要成功部署和维护PHP网站,需要执行以下步骤:选择Web服务器(如Apache或Nginx)安装PHP创建数据库并连接PHP上传代码到服务器设置域名和DNS监控网站维护步骤包括更新PHP和Web服务器、备份网站、监控错误日志和更新内容。

如何使用 Fail2Ban 保护服务器免受暴力攻击 如何使用 Fail2Ban 保护服务器免受暴力攻击 Apr 27, 2024 am 08:34 AM

Linux管理员的一个重要任务是保护服务器免受非法攻击或访问。默认情况下,Linux系统带有配置良好的防火墙,比如iptables、UncomplicatedFirewall(UFW),ConfigServerSecurityFirewall(CSF)等,可以防止多种攻击。任何连接到互联网的机器都是恶意攻击的潜在目标。有一个名为Fail2Ban的工具可用来缓解服务器上的非法访问。什么是Fail2Ban?Fail2Ban[1]是一款入侵防御软件,可以保护服务器免受暴力攻击。它是用Python编程语

和我一起来学习Linux安装Nginx 和我一起来学习Linux安装Nginx Apr 28, 2024 pm 03:10 PM

而今天将来一起带领大家在Linux环境安装Nginx,这里用的Linux系统是CentOS7.2.准备安装工具1.从Nginx官网下载Nginx。这里用的版本为:1.13.6.2.将下载下来的Nginx上传到Linux上,这里以/opt/nginx目录为例。运行“tar-zxvfnginx-1.13.6.tar.gz”进行解压。3.切换到/opt/nginx/nginx-1.13.6目录下,运行./configure进行初始化配置。如出现下面的提示,说明该机器没有安装PCRE,而Nginx需要依

keepalived+nginx搭建高可用几个注意点 keepalived+nginx搭建高可用几个注意点 Apr 23, 2024 pm 05:50 PM

在yum安装完keepalived之后,配置keepalived的配置文件注意点在master和backup的keepalived的配置文件中,网卡名字为当前机器的网卡名称VIP的选择为可用的一个ip,通常在做高可用,局域网环境比较多,所以这个vip是和两台机器同网段的一个内网ip。如果用在外网环境下,无所谓在不在一个网段,只要客户端能访问到。停掉nginx服务,启动keepalived服务,会看到keepalived拉动nginx服务启动若是无法启动失败,基本都是配置文件和脚本的问题,或者是防

See all articles