Невозможно протестировать загрузку файлов на основе HTTP PUT через Squid Proxy.

Я могу загрузить файл на свой веб-сервер Apache, используя Curl:

echo "[$(date)] file contents." | curl -T - http://WEB-SERVER/upload/sample.put 

Однако, если я поставлю прокси-сервер Squid между ними, я не смогу:

echo "[$(date)] file contents." | curl -x http://SQUID-PROXY:3128 -T - http://WEB-SERVER/upload/sample.put 

Curl сообщает о следующей ошибке:

Примечание. Этот ответ об ошибке был в формате HTML, но я удалил теги для удобства чтения.

ERROR: The requested URL could not be retrieved

ERROR
The requested URL could not be retrieved

While trying to retrieve the URL:
http://WEB-SERVER/upload/sample.put

The following error was encountered:
Unsupported Request Method and Protocol

Squid does not support all request methods for all access protocols.
For example, you can not POST a Gopher request.
Your cache administrator is root. 

Мой squid.conf, похоже, не имеет какого-либо ACL/правила, которое должно запрещать на основе IP-адресов src или dst, или protocol, или HTTP method... поскольку я могу легко выполнить HTTP POST между теми же клиент и веб-сервер с одним и тем же прокси-сервером между ними.

В случае неудачного случая HTTP PUT, чтобы увидеть фактический трафик запросов и ответов, я поместил процесс netcat между Curl и Squid, и вот что я увидел:

Запрос:

PUT http://WEB-SERVER/upload/sample.put HTTP/1.1
User-Agent: curl/7.15.5 (i686-redhat-linux-gnu) libcurl/7.15.5 OpenSSL/0.9.8b zlib/1.2.3 libidn/0.6.5
Host: WEB-SERVER
Pragma: no-cache
Accept: */*
Proxy-Connection: Keep-Alive
Transfer-Encoding: chunked
Expect: 100-continue

Ответ:

HTTP/1.0 501 Not Implemented
Server: squid/2.6.STABLE21
Date: Sun, 13 May 2012 02:11:39 GMT
Content-Type: text/html
Content-Length: 1078
Expires: Sun, 13 May 2012 02:11:39 GMT
X-Squid-Error: ERR_UNSUP_REQ 0
X-Cache: MISS from SQUID-PROXY-FQDN
X-Cache-Lookup: NONE from SQUID-PROXY-FQDN:3128
Via: 1.0 SQUID-PROXY-FQDN:3128 (squid/2.6.STABLE21)
Proxy-Connection: close

<SNIPPED the HTML error response already shown earlier above>

Примечание. Я анонимизировал IP-адреса и имена серверов для удобства чтения.


person Harry    schedule 13.05.2012    source источник
comment
Я думаю, проблема в заголовке Expect. Вы можете удалить его? Поскольку метод PUT поддерживается Squid.   -  person Diego Woitasen    schedule 13.05.2012
comment
Я пробовал (с опцией -H "Expect:"), но все тот же ответ.   -  person Harry    schedule 13.05.2012


Ответы (1)


Спасибо Амосу Джеффрису за ответ на этот вопрос на форум пользователей squid. Проблема в основном в том, что Squid до версии 3.1 не реализует HTTP 1.1 и, таким образом, отклоняет кодирование передачи по частям.

person Harry    schedule 16.05.2012