在Eclipse中,有两个地方我试图配置,以便Fiddler可以拦截我发送的HTTP / HTTPS请求:
Windows > Preference > General > Network Connections
- 我尝试过Native / Direct / Manual -DproxySet=true -DproxyHost=127.0.0.1 -DproxyPort=8888
我没有触及Fiddler中的任何“网络”相关设置,我将其设置为监控所有进程。
我尝试使用Wireshark,我能够在不修改Eclipse的情况下拦截请求,但Wireshark中提供的信息太深入了,我不需要Wireshark提供的大部分细节。
编辑:这是我正在尝试的示例代码:
public static void doPOST() {
String post_url = "https://lookup.mxtelecom.com/USLookup";
HttpParams params = new BasicHttpParams();
HttpProtocolParams.setVersion( params, HttpVersion.HTTP_1_1 );
HttpProtocolParams.setContentCharset( params, "UTF-8" );
HttpProtocolParams.setUseExpectContinue( params, true );
SchemeRegistry supportedSchemes = new SchemeRegistry();
supportedSchemes.register( new Scheme( "https", SSLSocketFactory.getSocketFactory(), 443 ) );
supportedSchemes.register( new Scheme( "http", PlainSocketFactory.getSocketFactory(), 80 ) );
ClientConnectionManager ccm = new ThreadSafeClientConnManager( params, supportedSchemes );
HttpClient m_Client = new DefaultHttpClient( ccm, params );
HttpPost httpPost = new HttpPost( post_url );
List<NameValuePair> postParameters = new ArrayList<NameValuePair>();
postParameters.add( new BasicNameValuePair( "something", "useful" ) );
ResponseHandler<String> responseHandler = new ResponseHandler<String>() {
@Override
public String handleResponse( HttpResponse response ) throws ClientProtocolException, IOException {
if ( response.getEntity() != null ) {
return EntityUtils.toString( response.getEntity() );
}
return null;
}
};
try {
UrlEncodedFormEntity entity = new UrlEncodedFormEntity( postParameters, "UTF-8" );
httpPost.setEntity( entity );
results = m_Client.execute( httpPost, responseHandler );
} catch ( ClientProtocolException e ) {
e.printStackTrace();
} catch ( IOException e ) {
e.printStackTrace();
}
}
Eclipse Build id:20100218-1602 // 3.5.2.R35x
Fiddler2 v2.3.2.6
jdk1.6.0_21
如果您需要任何其他信息,请与我们联系。
答案 0 :(得分:16)
HttpClient
需要了解代理信息。可以使用几种方法:
请参阅HTTP组件documentation中的2.7:
“通过代理连接到目标主机是通过设置默认代理参数”
DefaultHttpClient httpclient = new DefaultHttpClient();
HttpHost proxy = new HttpHost("127.0.0.1", 8888);
httpclient.getParams().setParameter(ConnRoutePNames.DEFAULT_PROXY, proxy);
使用“标准JRE代理选择器获取代理信息”
DefaultHttpClient httpclient = new DefaultHttpClient();
ProxySelectorRoutePlanner routePlanner = new ProxySelectorRoutePlanner(
httpclient.getConnectionManager().getSchemeRegistry(), ProxySelector.getDefault());
httpclient.setRoutePlanner(routePlanner);
然后将以下内容添加为VM参数:
-Dhttp.proxyHost=127.0.0.1 -Dhttp.proxyPort=8888 -Dhttps.proxyHost=127.0.0.1 -Dhttps.proxyPort=8888
自定义RoutePlanner
实施(我没有探索此选项)
答案 1 :(得分:5)
您有很多可能在java中配置代理:
java -Dhttp.proxyHost=127.0.0.1 -Dhttp.proxyPort=8888 -Dhttps.proxyHost=127.0.0.1 -Dhttps.proxyPort=8888
通过系统属性:
// Get system properties
Properties sysProperties = System.getProperties();
// Specify proxy settings
sysProperties.put("https.proxyHost", "127.0.0.1");
sysProperties.put("https.proxyPort", "8888");
sysProperties.put("http.proxyHost", "127.0.0.1");
sysProperties.put("http.proxyPort", "8889");
此方法的“disavdantage”:一旦为协议设置了代理,该协议的所有连接都将使用代理
java.net.Proxy:自java 1.5起可用。允许您指定用于打开连接的代理配置
SocketAddress addr = new InetSocketAddress("127.0.0.1", 8888);
Proxy proxy = new Proxy(Proxy.Type.HTTP, addr);
URL url = new URL("http://stackoverflow.com/");
InputStream in = url.openConnection(proxy).getInputStream();
ProxySelector类:自Java 1.5起可用。允许您通过URI选择代理!它是一个抽象类,一个简单的实现,返回所有http和https连接的代理,如下所示:
public static class MyProxySelector extends ProxySelector {
private List<Proxy> proxy;
private List<Proxy> noProxy;
MyProxySelector() {
proxy = new ArrayList<Proxy>();
SocketAddress addr = new InetSocketAddress("127.0.0.1", 8888);
proxy.add(new Proxy(Proxy.Type.HTTP, addr));
noProxy = new ArrayList<Proxy>();
noProxy.add(Proxy.NO_PROXY);
}
public List<Proxy> select(URI uri) {
System.err.println("Connection to the proxy for uri :"+uri);
if (uri == null) {
throw new IllegalArgumentException("URI can't be null.");
}
String protocol = uri.getScheme();
if ("http".equalsIgnoreCase(protocol) || "https".equalsIgnoreCase(protocol)) {
//if http or https connection, return our proxy config
return proxy;
} else {
// Otherwise don't use a proxy
return noProxy;
}
}
@Override
public void connectFailed(URI uri, SocketAddress sa, IOException ioe) {
System.err.println("Connection to the proxy failed !");
//throw exception or do some stuff...
}
}
并将代理选择器设置为默认代理选择器
public static void main(String[] args){
ProxySelector.setDefault(new MyProxySelector());
//...
}
我更喜欢这种最后一种机制,因为你可以进行一些日志记录,看看Java正在做什么!
默认情况下,Fiddler仅捕获来自网络浏览器的流量!!更改它以捕获所有进程的流量:bottom toolbar http://julien.comexis.eu/fiddler.jpg
答案 2 :(得分:2)
第二种方法应该有效,但属性为http.proxyHost
和http.proxyPort
。
答案 3 :(得分:2)
此外,在Fiddler中,如果您需要从HTTPS连接捕获所有进程,则需要转到“工具”菜单 - “提琴选项” - “HTTPS” - 检查“解密HTTPS流量”#39;并从所有流程中选择&#39; ...
选择&#39;所有流程&#39;来自Fiddler的状态栏显然只是用于HTTP连接。
答案 4 :(得分:1)
可以使用代理主机和代理端口的JVM参数。同时,需要安装Fiddler证书以嗅探https连接。