【发布时间】:2017-07-08 04:03:21
【问题描述】:
我想暂时将所有流量从 example.com 重定向到维护页面并返回 503 代码。我创建了maintenance.html页面:
<!DOCTYPE html>
<html>
<head>
<title>We'll be back!</title>
<link href="css/main.css" rel="stylesheet" media="screen">
<link href="css/bootstrap.min.css" rel="stylesheet" media="screen">
</head>
<body style="background-color: #red">
<div>
<div id="header-row" class="row">
<img src="/images/header-logo.png" alt="loogo" class="img-responsive center-block">
</div>
</div>
<script src="http://code.jquery.com/jquery.js"></script>
<script src="/js/bootstrap.min.js"></script>
<script src="/js/main.js"></script>
</body>
</html>
我把html页面、css、js和images文件夹放到文档根文件夹下。然后我在 apache2.2 配置文件中添加了以下几行:
RewriteEngine On
#prevent from recursiv redirection
RewriteCond %{SCRIPT_FILENAME} !maintenance.html
RewriteCond %{REQUEST_URI} !(js|css|images)$
RewriteCond %{REQUEST_FILENAME} !.*\.p
RewriteCond %{REQUEST_FILENAME} !-f
#503 and redirect
RewriteRule ^.*$ /maintenance.html [R=503,L]
ErrorDocument 503 /maintenance.h
#do not cache
Header Set Cache-Control "max-age=0, no-store"
所有调用都被重定向到maintenance.html 页面,但没有显示图像。我试图通过添加来修复它:
RewriteCond %{REQUEST_FILENAME} !-d
但随后重定向停止工作。奇怪的是,添加 RewriteCond %{REQUEST_URI} !(js|css|images)$ 修复了缺少样式的问题,但图像仍然被重定向。我做错了什么?
编辑 1:
我检查了浏览器如何搜索 header-logo.png。地址是http://example.com/images/header-logo.png,所以我添加了用于测试以下规则:
RewriteCond %{REQUEST_URI} !^/images/header-logo\.png$
但这也没有帮助....
【问题讨论】:
标签: apache .htaccess maintenance