Question nginx si l'instruction à l'intérieur de l'emplacement retourne 404


Le bloc suivant

location / {
    if ($http_origin ~* (https?://[^/]*\.example\.com(:[0-9]+)?)) {
        add_header 'Access-Control-Allow-Origin' "$http_origin";
    }
    try_files $uri $uri/ /index.php?$args;
}

… Provoque un 404 car le code ci-dessus n'atteint jamais le try_files directive, donc:

  1. Est-ce lié à la IfIsEvil de nginx?

  2. Si tel est le cas, existe-t-il un autre moyen de tester le http_origin en n'utilisant pas une instruction if?

J'ai essayé cela avec nginx> 1.4 (1.4.6, 1.7, 1.7.8).


11
2018-03-12 11:46


origine


1) C'est exactement de "si est le mal" exemples. 2) vous pouvez utiliser map Ou utiliser if en dehors de l'emplacement. - Alexey Ten
@AlexeyTen, pourriez-vous donner un exemple d'utilisation de if en dehors du bloc d'emplacement? - Eliran Malka


Réponses:


j'utiliserais map:

map $http_origin $cors_header {
    default "";
    "~^https?://[^/]+\.example\.com(:[0-9]+)?$" "$http_origin";
}

server {
    ...
    location / {
        add_header Access-Control-Allow-Origin $cors_header;
        try_files $uri $uri/ /index.php;
    }
    ...
 }

17
2018-03-12 11:55



Que se passe-t-il si les origines autorisées doivent être différentes pour chaque serveur? - Chris Martin
Utiliser plusieurs maps avec différentes variables - Alexey Ten