mod_rewrite para string de consulta em um local ScriptAlias

1

Configuração: um Servidor QGis-2.18 (realmente um MapServer ) via FastCGI no Apache-2.4.18 no Ubuntu.

Se um determinado valor for definido na string de consulta para o manipulador cgi, eu gostaria de adicionar outro valor. Para esse fim, adicionei três linhas ao início de /etc/apache2/conf-enabled/qgis.conf :

RewriteEngine on
RewriteCond "%{QUERY_STRING}" "application/json" [NC]
RewriteRule "^/$" "/?OUTPUTFORMAT=GeoJSON" [PT,QSA]

ScriptAlias / /usr/lib/cgi-bin/qgis_mapserv.fcgi
<Location "/">
    SetHandler fcgid-script
    Require all granted
    PassEnv QGIS_PROJECT_FILE
</Location>

FcgidInitialEnv QGIS_LOG_FILE ${QGIS_LOG_FILE}
FcgidInitialEnv QGIS_SERVER_LOG_FILE ${QGIS_SERVER_LOG_FILE}
FcgidInitialEnv QGIS_DEBUG ${QGIS_DEBUG}
FcgidInitialEnv QGIS_SERVER_LOG_LEVEL ${QGIS_SERVER_LOG_LEVEL}
FcgidInitialEnv QGIS_PLUGINPATH "${QGIS_PLUGINPATH}"
FcgidInitialEnv PGSERVICEFILE ${PGSERVICEFILE}
FcgidInitialEnv HOME /var/www

Estou acessando o servidor assim:

http://myserver.invalid.tld:51081/
    ?SERVICE=WFS
    &VERSION=1.1.0
    &REQUEST=GetFeature
    &OUTPUTFORMAT=application/json
    &MAXFEATURES=1
    &SRSNAME=EPSG:4326
    &TYPENAME=feature_type_name
    &BBOX=8.5985658,56.447691,8.600106,56.448553

Eu esperava que o efeito fosse o mesmo que se eu tivesse adicionado manualmente &OUTPUTFORMAT=GeoJSON no final do meu URL, mas não vejo nenhuma diferença após reiniciar o apache. (Sim, eu corri sudo a2enmod rewrite .)

Não tenho certeza de como funciona a interação entre as regras de reescrita e um alias de script. Por isso, estou pensando que uma sombra é a outra? Infelizmente, também não tenho ideia de como depurar isso.

O servidor tem um host virtual ativado, que se parece com o OOTB:

# apache2ctl -S
AH00558: apache2: Could not reliably determine the server's fully qualified domain name, using 172.17.0.10. Set the 'ServerName' directive globally to suppress this message
VirtualHost configuration:
*:80                   172.17.0.10 (/etc/apache2/sites-enabled/000-default.conf:1)
ServerRoot: "/etc/apache2"
Main DocumentRoot: "/var/www/html"
Main ErrorLog: "/proc/self/fd/2"
Mutex default: dir="/var/lock/apache2" mechanism=fcntl
Mutex fcgid-pipe: using_defaults
Mutex watchdog-callback: using_defaults
Mutex rewrite-map: using_defaults
Mutex fcgid-proctbl: using_defaults
PidFile: "/var/run/apache2/apache2.pid"
Define: DUMP_VHOSTS
Define: DUMP_RUN_CFG
User: name="www-data" id=33
Group: name="www-data" id=33 

Veja /etc/apache2/sites-enabled/000-default.conf (comentários retirados):

<VirtualHost *:80>
    ServerAdmin webmaster@localhost
    DocumentRoot /var/www/html
    ErrorLog /proc/self/fd/2
    CustomLog /proc/self/fd/1 combined
</VirtualHost>

E finalmente apache2.conf (novamente, comentários retirados):

Mutex file:${APACHE_LOCK_DIR} default
PidFile ${APACHE_PID_FILE}
Timeout 300
KeepAlive On
MaxKeepAliveRequests 100
KeepAliveTimeout 5
User ${APACHE_RUN_USER}
Group ${APACHE_RUN_GROUP}
HostnameLookups Off
ErrorLog /proc/self/fd/2
LogLevel warn

IncludeOptional mods-enabled/*.load
IncludeOptional mods-enabled/*.conf
Include ports.conf

<Directory />
    Options FollowSymLinks
    AllowOverride None
    Require all denied
</Directory>

<Directory /usr/share>
    AllowOverride None
    Require all granted
</Directory>

<Directory /var/www/>
    Options Indexes FollowSymLinks
    AllowOverride None
    Require all granted
</Directory>

AccessFileName .htaccess

<FilesMatch "^\.ht">
    Require all denied
</FilesMatch>

LogFormat "%v:%p %h %l %u %t \"%r\" %>s %O \"%{Referer}i\" \"%{User-Agent}i\"" vhost_combined
LogFormat "%h %l %u %t \"%r\" %>s %O \"%{Referer}i\" \"%{User-Agent}i\"" combined
LogFormat "%h %l %u %t \"%r\" %>s %O" common
LogFormat "%{Referer}i -> %U" referer
LogFormat "%{User-agent}i" agent

IncludeOptional conf-enabled/*.conf
IncludeOptional sites-enabled/*.conf

(Para pontos de bônus, eu gostaria de substituir application/json na string de consulta por GeoJSON , mas se eu conseguisse o parâmetro anexado para começar, eu estaria perto do objetivo .)

    
por kthy 18.10.2017 / 13:28

1 resposta

0

I would have expected the effect to be the same as if I had manually appended &OUTPUTFORMAT=GeoJSON

Bem, isso talvez seja o "problema"; não é acrescentado . A string de consulta original na solicitação é anexada . A cadeia de consulta ( OUTPUTFORMAT=GeoJSON ) na cadeia de substituição está no início da cadeia de consulta. Então, dependendo de como você está lendo / analisando os parâmetros na string de consulta, sua nova configuração provavelmente está sendo sobrescrita.

Para acrescentar algo especificamente à string de consulta existente, você pode usar a variável QUERY_STRING server na substituição (em vez de usar o QSA flag). Por exemplo:

RewriteCond %{QUERY_STRING} application/json
RewriteRule ^/$ /?%{QUERY_STRING}&OUTPUTFORMAT=GeoJSON [PT]

Não é necessário envolver todos os argumentos entre aspas, a menos que contenham espaços. Use somente o sinalizador NC se você precisar especificamente de uma correspondência sem distinção entre maiúsculas e minúsculas.

Como alternativa, para substituir o parâmetro OUTPUTFORMAT=application/json URL na solicitação, você pode fazer algo assim:

RewriteCond %{QUERY_STRING} (.*)OUTPUTFORMAT=application/json(.*)
RewriteRule ^/$ /?%1OUTPUTFORMAT=GeoJSON%2 [PT]

%1 e %2 são referências anteriores aos grupos capturados no CondPattern anterior. ie. Tudo antes e após o parâmetro original da URL na string de consulta.

    
por 18.10.2017 / 14:40