6

SOCKSプロキシのリストを並べ替えて、接続時間と読み取り時間が1000ミリ秒未満のプロキシを特定しようとしています。これが私のコードです。

for(Proxy p : proxies) {
            try {
            URLConnection testConnection = testUrl.openConnection(p);
            testConnection.setConnectTimeout(TIMEOUT_VALUE);
            testConnection.setReadTimeout(TIMEOUT_VALUE);
            success.add(p);
            } catch(SocketTimeoutException ste) {
                System.out.println("Proxy " + p.address().toString() + " timed out.");
            }
        }

TIMEOUT_VALUE = 1;しかし、私が何をしていても、それらのすべてがテストに合格します。助けてくれてありがとう。

4

2 に答える 2

13

私はあなたの問題はあなたが接続から何も読まないことだと思います。設定TIMEOUT_VALUEが低すぎると、例外が発生します。すべての回答を読んだ場合でも、1行だけを読んだ場合でも、結果の時間に影響はありませんでした。これは、1つのパケットで完全な回答を得たためだと思います。

これが私が使用した測定値です(プロキシなし):

    int TIMEOUT_VALUE = 1000;
    try {
        URL testUrl = new URL("http://google.com");
        StringBuilder answer = new StringBuilder(100000);

        long start = System.nanoTime();

        URLConnection testConnection = testUrl.openConnection();
        testConnection.setConnectTimeout(TIMEOUT_VALUE);
        testConnection.setReadTimeout(TIMEOUT_VALUE);
        BufferedReader in = new BufferedReader(new InputStreamReader(testConnection.getInputStream()));
        String inputLine;

        while ((inputLine = in.readLine()) != null) {
            answer.append(inputLine);
            answer.append("\n");
        }
        in.close();

        long elapsed = System.nanoTime() - start;
        System.out.println("Elapsed (ms): " + elapsed / 1000000);
        System.out.println("Answer:");
        System.out.println(answer);
    } catch (SocketTimeoutException e) {
        System.out.println("More than " + TIMEOUT_VALUE + " elapsed.");
    }
于 2011-06-30T09:33:25.640 に答える
0

私が使う

    System.getProperties().put("proxySet", "true");
    System.getProperties().put("http.proxyHost", "192.168.10.121");
    System.getProperties().put("http.proxyPort", "8080");
    //System.getProperties().put("http.nonProxyHosts", "8080");
于 2014-08-27T21:34:31.443 に答える