2

httplibFiddler をリバース プロキシに変換せずに、Fiddler のプロキシを介して Python で作成された HTTPS 要求をトンネリングする方法はありますか?

この例を使用してみました(ここから):

import httplib
c = httplib.HTTPSConnection('localhost',8118)
c.set_tunnel('twitter.com',443)
c.request('GET','/')
r1 = c.getresponse()
print r1.status,r1.reason
data1 = r1.read()
print len(data1)

しかし、それは返します:

<HTML><HEAD><META http-equiv="Content-Type" content="text/html; charset=UTF-8"><TITLE>Fiddler Echo Service</TITLE></HEAD><BODY STYLE="font-family: arial,sans-serif;"><H1>Fiddler Echo Service</H1><BR /><PRE>GET / HTTP/1.1
Host: localhost:8080
Accept-Encoding: identity

</PRE><BR><HR><UL><LI>To configure Fiddler as a reverse proxy instead of seeing this page, see <A HREF='http://fiddler2.com/r/?REVERSEPROXY'>Reverse Proxy Setup</A><LI>You can download the <a href="FiddlerRoot.cer">FiddlerRoot certificate</A></UL></BODY></HTML>

編集:このコードは機能します。この問題は、Internet Explorer のプロキシ設定に関連していました。これらの設定でプロキシを設定しないでください。そうしないと、上記のコードが機能しません。

4

1 に答える 1

3

Burpプロキシを介してurllib2(urllib2を使用したプロキシ)を試してみましたが、機能しました。

import urllib2
proxy = urllib2.ProxyHandler({'https': '127.0.0.1:8081'})
opener = urllib2.build_opener(proxy)
urllib2.install_opener(opener)
print urllib2.urlopen('https://www.google.com').read()

あなたのコードはBurpSuiteプロキシでうまく機能しているようです。

于 2012-08-20T14:28:18.487 に答える