
次のようにURLを書き換えたい:
https://documentation.domain.com/login
からhttps://app.domain.com/login
https://api.domain.com/login
、https://app.domain.com/login
任意のサブドメインからURL {anything}.domain.com/login へhttps://app.domain.com/login
https://app.domain.com/sdks
https://documentation.domain.com/sdks
(すべてのクエリパラメータが保持されます)(すべてのクエリパラメータが保持されます) 、URLが{anything}.domain.com/sdksの任意
https://api.domain.com/sdks
の サブドメインからhttps://documentation.domain.com/sdks
https://documentation.domain.com/sdks
https://app.domain.com/restApi
https://documentation.domain.com/restApi
(すべてのクエリパラメータが保持されます)(すべてのクエリパラメータが保持されます) 、URLが{anything}.domain.com/restApiの任意
https://api.domain.com/restApi
の サブドメインからhttps://documentation.domain.com/restApi
https://documentation.domain.com/restApi
現在私が持っているものは次のとおりです:
server {
listen 443 ssl http2 default_server;
listen [::]:443 ssl http2 default_server;
ssl_certificate /home/company/server/ssl/domain_cloudflare.pem;
ssl_certificate_key /home/company/server/ssl/domain_cloudflare_privatekey.key;
server_name www.*.domain.com *.domain.com;
client_body_buffer_size 32k;
client_header_buffer_size 8k;
large_client_header_buffers 4 16k;
location / {
# First attempt to serve request as file, then
# as directory, then fall back to displaying a 404.
proxy_pass https://localhost:8443;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
}
location /login {
# First attempt to serve request as file, then
# as directory, then fall back to displaying a 404.
proxy_pass https://localhost:8443/login;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
return 302 https://app.domain.com/login;
}
location /restApi {
# First attempt to serve request as file, then
# as directory, then fall back to displaying a 404.
proxy_pass https://localhost:8443/restApi;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
return 302 https://app.domain.com/restApi;
}
location /sdks {
# First attempt to serve request as file, then
# as directory, then fall back to displaying a 404.
proxy_pass https://localhost:8443/sdks;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
return 302 https://app.domain.com/sdks;
}
location /api {
# First attempt to serve request as file, then
# as directory, then fall back to displaying a 404.
proxy_pass https://localhost:8443/api;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
return 302 https://api.domain.com/api;
}
}
Cloudflare SSL を Full Strict に設定しました。Fulll/Flexible に変更しても何も変わりません。この設定はほぼ機能します。これは機能しますが、ERR_TOO_MANY_REDIRECTS が発生します。これを修正するにはどうすればよいですか? どこが間違っているのでしょうか? 助けてください
編集:
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
ssl_certificate /home/company/domain/ssl/domain_cloudflare.pem;
ssl_certificate_key /home/company/domain/ssl/domain_cloudflare_privatekey.key;
server_name app.domain.com;
client_body_buffer_size 32k;
client_header_buffer_size 8k;
large_client_header_buffers 4 16k;
location / {
proxy_pass https://localhost:8443/login;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Host $http_host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-Proto https;
# return 302 https://app.domain.com/login;
}
}
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
ssl_certificate /home/company/domain/ssl/domain_cloudflare.pem;
ssl_certificate_key /home/company/domain/ssl/domain_cloudflare_privatekey.key;
server_name documentation.domain.com;
client_body_buffer_size 32k;
client_header_buffer_size 8k;
large_client_header_buffers 4 16k;
location /sdks {
proxy_pass https://localhost:8443/sdks;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Host $http_host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-Proto https;
# return 302 https://documentation.domain.com/sdks;
}
location /restApi {
proxy_pass https://localhost:8443/restApi;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Host $http_host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-Proto https;
# return 302 https://documentation.domain.com/restApi;
}
}
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
ssl_certificate /home/company/domain/ssl/domain_cloudflare.pem;
ssl_certificate_key /home/company/domain/ssl/domain_cloudflare_privatekey.key;
server_name api.domain.com;
client_body_buffer_size 32k;
client_header_buffer_size 8k;
large_client_header_buffers 4 16k;
location /api {
proxy_pass https://localhost:8443/;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Host $http_host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-Proto https;
# return 302 https://api.domain.com/;
}
}