假设我有一个名为example.com的域,以及下面的'n‘个子域名,所有的子域都有'A’记录到相同的IP地址(假设服务器A)。
a.example.com,b.example.com,c.example.com ...z.example.com
还有另一个子域'email.example.com‘,其CNAME设置为’mailgen.org‘。
现在,我有了具有以下nginx配置的服务器A,其中我希望将所有HTTP请求转发到HTTPS。
server {
listen 80;
return 301 https://$host$request_uri;
}以及处理各个子域请求的一组代码块到443。
server {
listen 443 ssl;
server_name a.example.com;
//SSL Details
location / {
root /var/www/a/;
}除了指向mailgun.org的email.example.com之外,其余的子域也是如此。
现在,http://email.example.com它们将被重定向到http://mailgun.com。(在DNS级别)
http://example.com它们将被重定向至https://example.com。(在服务器级别)。
http://a.example.com它们将被重定向至https://a.example.com。(在服务器级别)
问题:访问http://example.com后,当有人试图访问http://email.example.com时,浏览器会将他们重定向到https://email.example.com。因为我无法控制https,所以我可以处理email.example.com的mailgun.org请求
有没有办法设置nginx config,除了email.example.com之外,每个对HTTP的请求都会被重定向到HTTPS?
发布于 2017-01-25 21:59:44
好了,我找到问题了。
我更改了example.com的nginx配置,使其不包含子域。
也就是说,更改了以下行
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always;如下所示。
add_header Strict-Transport-Security "max-age=31536000;" always;因此,浏览器现在不会向子域添加标题。
https://stackoverflow.com/questions/41824748
复制相似问题