nginx反向代理批量实现https协议访问
时间:2014-03-24 23:47 来源:linux.it.net.cn 作者:IT网
为站点增加https访问,开始只配置了www域名下的https,发现css和js都无法正常加载。
原因分析:https页面,如果加载http协议的内容,会被认为页面不安全,尤其是IE,刷新一下页面就要弹出一次确认。
后来苦逼的把各个子域名都加入了https配置,nginx.conf里写各个子域名都写了一个443的server配置,每新增一个域名,还得copy一份,如果是修改一下站点的配置,还得改两次以上。
后来跟同事讨论,发现使用反向代理,可以快捷现实,配置如下:
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
sever{
listen 80;
sever_name www.defel.net;
root
/home/webroot/www/
;
index index.php index.html;
# ...
}
sever{
listen 80;
sever_name img.defel.net;
root
/home/webroot/img/
;
index index.php index.html;
# ...
}
sever{
listen 80;
sever_name static.defel.net;
root
/home/webroot/static/
;
index index.php index.html;
# ...
}
sever{
listen 80;
sever_name upload.defel.net;
root
/home/webroot/upload/
;
index index.php index.html;
# ...
}
server {
listen 443;
server_name www.defel.net img.defel.net static.defel.net upload.defel.net;
ssl on;
ssl_certificate
/usr/local/nginx/conf/defel
.net.crt;
ssl_certificate_key
/usr/local/nginx/conf/defel
.net.key;
location /{
proxy_pass http:
//127
.0.0.1:80;
proxy_redirect off;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $host;
proxy_set_header SSL
'1'
;
proxy_redirect http:
//
https:
//
;
}
}
这样配置好,访问:
会被反向代理至:
而不需要对各个域名都配置一个443的站点。
(责任编辑:IT)
为站点增加https访问,开始只配置了www域名下的https,发现css和js都无法正常加载。 后来苦逼的把各个子域名都加入了https配置,nginx.conf里写各个子域名都写了一个443的server配置,每新增一个域名,还得copy一份,如果是修改一下站点的配置,还得改两次以上。 后来跟同事讨论,发现使用反向代理,可以快捷现实,配置如下:
这样配置好,访问: 会被反向代理至: 而不需要对各个域名都配置一个443的站点。 |