我在一个小型虚拟专用服务器上玩lighttpd。我指向服务器的两个域。我在Ubuntu 8.10上使用最新版本的lighttpd和mod_evhost。
我正在尝试设置一条规则,以便当有人请求 domain.com 或 www.domain.com 时,他们会从获得服务/webroot/domain.com/www /
同样,如果有人请求 sub.domain.com ,则会从 /webroot/domain.com/sub/
如果有人要求 fake.domain.com (其中 /webroot/domain.com/fake / 不存在)我希望他们从< EM> /webroot/domain.com/www /
第三个要求并不那么重要,我可以处理请求从 /webroot/server.com/www/ 的服务器文档根目录服务的不存在的子域名的人员如果他们要求 fake.domain.com
我在下面列出了lighttpd.conf文件的相关部分:
server.document-root = "/webroot/server.com/www/"
// regex to match sub.domain.com
$HTTP["host"] =~ "\b[a-zA-Z]\w*\.\b[a-zA-Z]\w*\.\b[a-zA-Z]\w*" {
evhost.path-pattern = "/webroot/%0/%3/"
}
// regex to match domain.com
$HTTP["host"] =~ "\b[a-zA-Z]\w*\.\b[a-zA-Z]\w*" {
evhost.path-pattern = "/webroot/%0/www/"
}
那我哪里错了?目前, *。domain.com 和 domain.com 的所有请求均来自 /webroot/domain.com/www/
我很感激你们可以提供任何帮助,如果我留下任何相关信息,请告诉我!
干杯, 罗布
答案 0 :(得分:5)
你的正则表达似乎有点过头了。
以下是我要使用的内容:
// regex to match sub.domain.com
$HTTP["host"] =~ "^[^.]+\.[^.]+\.[^.]+$" {
evhost.path-pattern = "/webroot/%0/%3/"
}
// regex to match domain.com
$HTTP["host"] =~ "^[^.]+\.[^.]+$" {
evhost.path-pattern = "/webroot/%0/www/"
}
其中:
[^.]+ matches anything but a dot, 1..n times
要仅匹配回退到“www”的有效子域,您可以使用:
// default: route everything to "www"
$HTTP["host"] =~ "([^.]+\.)?domain\.com$" {
evhost.path-pattern = "/webroot/%0/www/"
}
// specific regex overwrites "path-pattern" for valid sub-domains only
$HTTP["host"] =~ "^(valid1|valid2|sub)\.domain\.com$" {
evhost.path-pattern = "/webroot/%0/%3/"
}
答案 1 :(得分:1)
对于您的第一个,匹配 domain.com 和 www.domain.com :^\b([wW]{3}\.)?[\w\d]*\.com\b$
,对于第二个,我不确定是否正则表达式可以确定子域/页面是否存在,因为它用于识别感兴趣的文本字符串。希望这会对你有所帮助。