私は非常に単純な WEBrickProxy (WEBrick 1.3.1、Ruby 1.9.3) を持っており、curl で試してみたいと思っています。プロキシは次のとおりです。
require 'webrick'
require 'webrick/httpproxy'
server = WEBrick::HTTPProxyServer.new(:BindAddress => "localhost", :Port => 8888)
trap('INT') { server.shutdown }
server.start
そして、ここにcURLコマンドがあります
curl --proxy localhost:8888 http://www.google.de -v
ただし、curl コマンドは常に不正なリクエストを返します。
* About to connect() to proxy localhost port 8888 (#0)
* Trying ::1...
* connected
* Connected to localhost (::1) port 8888 (#0)
> GET http://www.google.de HTTP/1.1
> User-Agent: curl/7.24.0 (x86_64-apple-darwin12.0) libcurl/7.24.0 OpenSSL/0.9.8r zlib/1.2.5
> Host: www.google.de
> Accept: */*
> Proxy-Connection: Keep-Alive
>
< HTTP/1.1 400 Bad Request
< Content-Type: text/html; charset=ISO-8859-1
< Server: WEBrick/1.3.1 (Ruby/1.9.3/2012-10-12)
< Date: Mon, 18 Mar 2013 13:44:27 GMT
< Content-Length: 295
< Connection: close
<
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN">
<HTML>
<HEAD><TITLE>Bad Request</TITLE></HEAD>
<BODY>
<H1>Bad Request</H1>
bad URI `http://www.google.de'.
<HR>
<ADDRESS>
WEBrick/1.3.1 (Ruby/1.9.3/2012-10-12) at
23tuxmb.local:8888
</ADDRESS>
</BODY>
</HTML>
* Closing connection #0
curl --version
私の Mac OS X 10.8 に戻ります
curl 7.24.0 (x86_64-apple-darwin12.0) libcurl/7.24.0 OpenSSL/0.9.8r zlib/1.2.5
Protocols: dict file ftp ftps gopher http https imap imaps ldap ldaps pop3 pop3s rtsp smtp smtps telnet tftp
Features: AsynchDNS GSS-Negotiate IPv6 Largefile NTLM NTLM_WB SSL libz
エラーがどこにあるのかわかりません。数週間前にそのコードを試してみましたが、うまくいったことを覚えています。
奇妙なことに、そのプロキシ ( 内System Settings -> Network -> Advanced -> Proxies -> Web Proxy
) をグローバルに使用するように Mac を構成すると、すべてが機能します。Chrome またはその他のアプリケーションを使用したリクエストは、プロキシ経由でルーティングされます (これは、プロキシのターミナル ログ内に表示されます)。
誰でもこの問題を再現できますか? それはカールバグですか?それとも Webrick 関連の問題ですか?
編集
詳細: curl が接続を試みたときの ruby スクリプト自体の出力は次のとおりです。
[2013-03-18 17:16:32] ERROR bad URI `http://www.amazon.de'.
localhost - - [18/Mar/2013:17:16:32 CET] "GET http://www.amazon.de HTTP/1.1" 400 286
- -> http://www.amazon.de
どうも!