当位于 Nginx 代理后面时,Keycloak Docker 实例中的 X-Frame-Options 拒绝加载

pip*_*yan 3 nginx docker keycloak

我有一个与官方提供的非常相似的 docker-compose 文件

version: '3'

volumes:
mysql_data:
    driver: local

services:
mysql:
    image: mysql:5.7
    volumes:
        - mysql_data:/var/lib/mysql
    environment:
        MYSQL_ROOT_PASSWORD: root
        MYSQL_DATABASE: keycloak
        MYSQL_USER: keycloak
        MYSQL_PASSWORD: mypassword
keycloak:
    image: jboss/keycloak
    environment:
        DB_VENDOR: MYSQL
        DB_ADDR: mysql
        DB_DATABASE: keycloak
        DB_USER: keycloak
        DB_PASSWORD: mypass
        KEYCLOAK_USER: admin
        KEYCLOAK_PASSWORD: mypass
        # It didn't look like this actually got set. 
        PROXY_ADDRESS_FORWARDING: "true"
    ports:
        - 10000:8080
    depends_on:
        - mysql
Run Code Online (Sandbox Code Playgroud)

我还有 nginx 配置文件用作 keycloak 的反向代理

## Redirects all HTTP traffic to the HTTPS host
server {
    listen 80;
    listen [::]:80;
    server_name keycloak keycloak.fqdn.com keycloak.fq.fqdn.com; 
    server_tokens off;
    return 301 https://keycloak.fqdn.com$request_uri;
}

## HTTPS host
server {
    listen 443 ssl http2;
    listen [::]:443 ssl http2;
    server_name keycloak.fqdn.com; 
    server_tokens off; 
    autoindex off;    

    include conf.d/site-common-config/ssl.conf;

    access_log  /var/log/nginx/keycloak-access.log combined;
    error_log   /var/log/nginx/keycloak-error.log warn;

    location / {
        gzip                    on;
        proxy_http_version 1.1;

        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://127.0.0.1:10000;
    }
}
Run Code Online (Sandbox Code Playgroud)

我还确认(据我所知)正在/auth/realms/master/.well-known/openid-configuration返回正确的值。我一直遵循此处的指南,并更新了相应的 xml 文件,并运行了重新加载命令以确保设置proxy-address-forwarding为 true。但是我收到了 javascript 错误

Load denied by X-Frame-Options: https://keycloak.fqdn.com/auth/realms/master/protocol/openid-connect/login-status-iframe.html?version=4.3.0.final does not permit framing.
Run Code Online (Sandbox Code Playgroud)

到目前为止,我无法在文档中找到任何内容来解决此问题,因此我们将不胜感激。

小智 5

如果我在 nginx/openresty 配置中添加以下标头,它就可以工作:

\n\n
location / {\n     \xe2\x80\xa6\n     add_header X-Frame-Options "SAMEORIGIN";\n     \xe2\x80\xa6\n}\n
Run Code Online (Sandbox Code Playgroud)\n\n

如果您想使用 kcadm.sh 更改领域中的值(因为 gui 无法工作),您可以使用以下命令导出、编辑和导入领域

\n\n
sudo -u keycloak /opt/keycloak/bin/kcadm.sh config credentials --realm master --user admin --server http://localhost:8080/auth\nsudo -u keycloak /opt/keycloak/bin/kcadm.sh get realms/master > realm.json\n# edit realm.json\nsudo -u keycloak /opt/keycloak/bin/kcadm.sh update realms/master -f realm.json\n
Run Code Online (Sandbox Code Playgroud)\n