Apache 域名跳转配置

域名跳转

  就是实现URL的跳转和隐藏真实地址,基于Perl语言的正则表达式规范。平时帮助我们实现拟静态,拟目录,域名跳转,防止盗链等 。

参数格式

参数:

Apache mod_rewrite 规则重写

     1) R[=code](force redirect) 强制外部重定向
               说明:强制在替代字符串加上http://thishost[:thisport]/前缀重定向到外部的URL.如果code不指定,将用缺省的302 HTTP状态码。

     2) F(force URL to be forbidden)禁用URL,返回403HTTP状态码。

     3) G(force URL to be gone) 强制URL为GONE,返回410HTTP状态码。

     4) P(force proxy) 强制使用代理转发。

     5) L(last rule) 表明当前规则是最后一条规则,停止分析以后规则的重写。

     6) N(next round) 重新从第一条规则开始运行重写过程。

     7) C(chained with next rule) 与下一条规则关联

     8) T=MIME-type(force MIME type) 强制MIME类型

     9) NS (used only if no internal sub-request) 只用于不是内部子请求

     10) NC(no case) 不区分大小写

     11) QSA(query string append) 追加请求字符串

     12) NE(no URI escaping of output) 不在输出转义特殊字符
             说明:RewriteRule /foo/(.*) /bar?arg=P1%3d$1 [R,NE] 将能正确的将/foo/zoo转换成/bar?arg=P1=zoo

     13) PT(pass through to next handler) 传递给下一个处理
             说明:RewriteRule ^/abc(.*) /def$1 [PT] # 将会交给/def规则处理Alias /def /ghi

     14) S=num(skip next rule(s)) 跳过num条规则

     15) E=VAR:VAL(set environment variable) 设置环境变量

     16) OR 代表或者

注:如果规则匹配则正常处理,8)以后的标志无效,如果不匹配,那么下面所有关联的规则都跳过。
格式:

# 调用mod_rewrite.c模块
 <IfModule mod_rewrite.c>

    # 打开rewirte功能
    RewriteEngine on 

    # 声明Client请求的主机中前缀不是www.client.cn
    RewriteCond %(HTTP_HOST) ^www.client.com$

    # 含义是如果Client请求的主机中的前缀符合上述条件,则直接跳转。
    AuthType Basic ^(.*)$ http://www.server.com/$1 [R=301,L]

</IfModule>

实例配置

1、查找是否有rewrite模块,域名跳转模块

命令:apache2/bin/apachectl -M | grep rewrit

rewrite_module    (shared)

如果不存在:

# 编辑主配置文件,解注释
vim httpd.conf

LoadModule rewrite_module modules/mod_rewrite.so

注:如果没有该模块,则需要通过apxs工具安装模块。

2、修改虚拟主机配置文件

vim httpd-vhosts.conf

# 1对1域名跳转
<VirtualHost *:80>
    DocumentRoot "/usr/local/html"
    ServerName www.server.com
    ServerAlias www.aaa.com
<IfModule mod_rewrite.c>
    RewriteEngine on
    RewriteCond %{HTTP_HOST} ^www.aaa.com$
    RewriteRule ^/(.*)$ http://www.server.com/$1 [R=301,L]
</IfModule>
<Directory /usr/local/html>
    require all granted
</Directory>
</VirtualHost>

# 1对多域名跳转
<VirtualHost *:80>
    DocumentRoot "/usr/local/html"
    ServerName www.server.com
    ServerAlias www.aaa.com
    ServerAlias www.bbb.com
<IfModule mod_rewrite.c>
    RewriteEngine on
    RewriteCond %{HTTP_HOST} ^www.aaa.com$ [OR]
    RewriteCond %{HTTP_HOST} ^www.bbb.com$
    RewriteRule ^/(.*)$ http://www.server.com/$1 [R=301,L]
</IfModule>
<Directory /usr/local/html>
    require all granted
</Directory>
</VirtualHost>

配置文件

注:跳转状态码
    301代表永久重定向
    302临时重定向

注:$1代表地址后跟的网络文件。

注:访问一个“/”可以输入以下格式。
 RewriteCond %(HTTP_HOST)  456.com
 RewriteRule /(.*)$ HTTP://123.com/$1 [R=301,L] 

3、重新读取配置文件

apache2/bin/apachectl graceful

原文地址:https://www.cnblogs.com/xiangsikai/p/8366153.html

时间: 2024-11-09 01:02:06

Apache 域名跳转配置的相关文章

apache域名跳转

①编辑虚拟主机配置文件/usr/local/apache2.4/conf/extra/httpd-vhosts.conf如下 <VirtualHost *:80>     DocumentRoot "/data/wwwroot/111.com"     ServerName 111.com     ServerAlias www.example.com  2111.com.cn     ErrorLog "logs/111.com-error_log"

Apache用户认证、域名跳转、访问日志格式

11.18 Apache用户认证 注意: 本章使用浏览器进行检测的前提是在物理机hosts文件添加虚拟机IP和虚拟主机域名. 配置用户认证 编辑虚拟主机配置文件"httpd-vhosts.conf".[[email protected] ~]# vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf--<VirtualHost *:80>DocumentRoot "/data/wwwroot/111.com&qu

Apache配置域名跳转、日志切割、静态缓存、防盗链、访问控制

·/usr/local/apache2/bin/apachectl  -M:查看安装了哪些模块 ·/usr/local/apache/bin/apachectl   -V:查看使用的模式 ·/usr/local/apache2/bin/apachectl  -t:检查语法错误 ·/usr/local/apache2/bin/apachectl  -l:查看安装的库文件 ·/usr/local/apache2/bin/apachectl graceful:重新加载配置 ·/usr/local/ap

apache配置-域名跳转、日志切割、静态缓存、防盗链

·/usr/local/apache2/bin/apachectl -M:查看安装了哪些模块     ·/usr/local/apache2/bin/apachectl -t:检查语法错误 ·/usr/local/apache2/bin/apachectl -l:查看安装的库文件 ·/usr/local/apache2/bin/apachectl graceful:重新加载配置·/usr/local/apache2/htcocs         主页存放目录 ·/usr/local/apache

Apache配置用户认证、域名跳转、日志轮询、静态文件缓存、防盗链

使用版本为httpd-2.2.29 源码编译安装环境. 1.配置网站用户认证 编辑虚拟机主机配置文件 /usr/local/apache2/conf/extra/httpd-vhosts.conf,在虚拟主机配置文件段内加入绿色标示代码: <VirtualHost *:80> DocumentRoot "/data/www" ServerName www.123.com ServerAlias www.a.com www.b.com     <Directory *&

Apache(httpd)配置--用户认证,域名跳转和访问日志配置

一.用户认证 用户认证功能就是在用户访问网站的时候,需要输入用户名密码才能进行访问.一些比较好总要的站点和网站后台都会加上用户认证,以保证安全.实例:下面对zlinux.com站点来做一个全站的用户认证: 步骤1:编辑虚拟主机配置文件 [[email protected] ~]# vim /usr/local/apache2/conf/extra/httpd-vhosts.conf //在linuxtest.com虚拟主机下编辑添加以下内容 <VirtualHost *:80> Documen

apache 配置用户认证 域名跳转 日志 静态缓存文件 防盗链接

配置文件:/usr/local/apache2/conf/extra/httpd-vhosts.conf <VirtualHost *:80> ServerAdmin [email protected] DocumentRoot "/data/www" ServerName www.1.com ServerAlias www.a.com www.b.com #配置用户认证 <Directory /data/www> AllowOverride AuthConfi

Apache 配置域名跳转

域名跳转需要在虚拟主机配置中添加别名和一个 rewrite 模块,如下,配置当访问 www.aaa.com 时跳转到 www.test.com [[email protected] ~]# vim /usr/local/apache2/conf/extra/httpd-vhosts.conf <VirtualHost *:80> DocumentRoot "/data/www" ServerName www.test.com ServerAlias www.aaa.com

apache域名301跳转和访问控制的优先级

apache域名301跳转和访问控制的优先级 实验背景:apache虚拟主机有两个域名 111.com 222.com 其中222.com 访问的时候跳转到111.com,并且给该虚拟主机做了访问控制,只允许127.0.0.1访问.问题:当访问222.com时,它是先跳转到111.com,还是直接403呢? 打开apache中虚拟主机配置文件: vim /usr/local/apache2/conf/extra/httpd-vhosts.conf,可以看到当前配置如下(没做访问控制措施): 我们