gpt4 book ai didi

nginx - keycloak无效参数: redirect_uri behind a reverse proxy

转载 作者:行者123 更新时间:2023-12-04 18:19:21 30 4
gpt4 key购买 nike

您如何正确地将NGINX配置为Keycloak前面的代理?

以doc的形式进行询问和回答,因为我现在不得不重复做一次,过了一会儿就忘记了细节。

这专门用于处理Keycloak位于反向代理(例如反向代理)后面的情况。 Nginx和NGINX正在终止SSL并推向Keycloak。尽管它产生相同的错误消息,但这与keycloak Invalid parameter: redirect_uri是不同的问题。

最佳答案

关键在于文档位于
https://www.keycloak.org/docs/latest/server_installation/index.html#identifying-client-ip-addresses

必须设置proxy-address-forwarding以及各种X-... header 。

如果您使用的是https://hub.docker.com/r/jboss/keycloak/中的Docker镜像,请设置环境。 arg -e PROXY_ADDRESS_FORWARDING=true

server {
server_name api.domain.com;

location /auth {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;

proxy_pass http://localhost:8080;
proxy_read_timeout 90;

}

location / {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;

proxy_pass http://localhost:8081;
proxy_read_timeout 90;
}



listen 443 ssl; # managed by Certbot
ssl_certificate /etc/letsencrypt/live/api.domain.com/fullchain.pem; # managed by Certbot
ssl_certificate_key /etc/letsencrypt/live/api.domain.com/privkey.pem; # managed by Certbot
include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot

}
server {
if ($host = api.domain.com) {
return 301 https://$host$request_uri;
} # managed by Certbot


server_name api.domain.com;
listen 80;
return 404; # managed by Certbot
}

如果您正在使用另一个代理,则其中的重要部分是要设置的 header :
proxy_set_header        Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;

Apache,ISTIO和其他人有自己的设置方式。

关于nginx - keycloak无效参数: redirect_uri behind a reverse proxy,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53564499/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com