Назад | Перейти на главную страницу

Правило mod_rewrite для строки запроса в расположении ScriptAlias

Настройка: a Сервер QGis-2.18 (действительно встроенный MapServer) через FastCGI в Apache-2.4.18 на Ubuntu.

Если в строке запроса для обработчика cgi установлено определенное значение, я хотел бы добавить другое значение. С этой целью я добавил три строки вверху /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

Я обращаюсь к серверу так:

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

Я ожидал, что эффект будет таким же, как если бы я вручную добавил &OUTPUTFORMAT=GeoJSON в конце моего URL, но Я вообще не вижу разницы после перезапуска apache. (Да, я бежал sudo a2enmod rewrite.)

Я не уверен, как работает взаимодействие между правилами перезаписи и псевдонимом скрипта, поэтому я думаю, что одно затмевает другое? К сожалению, я тоже не знаю, как это отладить.

На сервере включен один виртуальный хост, который для меня выглядит как конфигурация 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 

Вот /etc/apache2/sites-enabled/000-default.conf (комментарии удалены):

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

И наконец apache2.conf (опять же, комментарии удалены):

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

(Для бонусных баллов я бы хотел заменить application/json в строке запроса с GeoJSON, но если бы я мог добавить параметр для начала, я был бы близок к цели.)

Я ожидал, что эффект будет таким же, как если бы я вручную добавил &OUTPUTFORMAT=GeoJSON

Что ж, может быть, в этом «проблема»; это не добавлен. Исходная строка запроса по запросу: добавлен. Строка запроса (OUTPUTFORMAT=GeoJSON) в строке подстановки находится в начале строки запроса. Итак, в зависимости от того, как вы читаете / анализируете параметры в строке запроса, ваша новая настройка, вероятно, перезаписывается.

Чтобы конкретно добавить что-то в существующую строку запроса, вы можете использовать QUERY_STRING серверная переменная в замена (вместо использования QSA флаг). Например:

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

Не нужно заключать все аргументы в кавычки, если они не содержат пробелов. Используйте только NC отметьте, если вам требуется совпадение без учета регистра.

В качестве альтернативы заменить то OUTPUTFORMAT=application/json Параметр URL в запросе, то вы можете сделать что-то вроде этого:

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

%1 и %2 являются обратными ссылками на захваченные группы в предыдущем CondPattern. т.е. Все перед и после исходный параметр URL в строке запроса.