为什么Android不发送我的第二个SSL请求?

时间:2012-06-30 19:07:44

标签: android ssl android-emulator

我的Android应用正在使用SSL和GET请求与网络服务器通信。切换到API 10(Gingerbread)后,SSL连接正常工作 - 但仅在应用程序启动后第一次...

第一个请求由主活动发送 - 在获得响应后,另一个活动启动并发送多个请求。而且没有人得到回答。在这两种情况下,请求都是使用在新的AsyncTask中启动的litte WebService类发送的。缩小此类之后,它实际包含的唯一内容是URL(-String)。每个活动都会启动自己的此类实例。

以下是应该执行GET请求的方法。很容易看到我包括一些代码以避免保持活着 - 不是我不喜欢它,但是在其他答案中已经建议这样做以避免多个连接的问题。嗯,它在我的情况下不起作用。

public String webGet(String methodName, Map<String, String> params) {
    String getUrl = webServiceUrl + methodName;
    index++;
    final int connectionID = index;

    int i = 0;
    for (Map.Entry<String, String> param : params.entrySet()) {
        if (i == 0) {
            getUrl += "?";
        } else {
            getUrl += "&";
        }

        try {
            getUrl += param.getKey() + "=" + URLEncoder.encode(param.getValue(), "UTF-8");
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        }

        i++;
    }

    String response;
    Log.e("WebGetURL", "["+connectionID+"] " + getUrl);
    URL url;
    try {
        url = new URL(getUrl);
    } catch (MalformedURLException e) {
        Log.e("WebService", "Malformed URL: " + getUrl);
        return null;
    }
    HttpURLConnection urlConnection;
    try {
        Log.e("WebGetResponse", "["+connectionID+"] openConnection()");
        System.setProperty("http.keepAlive", "false");
        if (webServiceSsl) {
            Log.e("WebService", "Using HTTPS");
            urlConnection = (HttpsURLConnection) url.openConnection();
        } else {
            urlConnection = (HttpURLConnection) url.openConnection();
        }
        urlConnection.setUseCaches(false); 
        urlConnection.setRequestProperty("Connection","Keep-Alive"); 
        urlConnection.setDoOutput(false); 
        urlConnection.setDoInput(true); 
        urlConnection.setRequestMethod("GET");
    } catch (IOException e) {
        Log.e("WebService", "I/O exception opening connection: " + e.getMessage());
        e.printStackTrace();
        return null;
    }

    urlConnection.setConnectTimeout(5000);
    urlConnection.setReadTimeout(10000);
    urlConnection.setRequestProperty("Connection", "close");

    try {
        urlConnection.connect();
        Log.e("WebGetResponse", "["+connectionID+"] getInputStream()");
        // This is the last thing I hear from my thread
        BufferedInputStream bin = new BufferedInputStream(urlConnection.getInputStream());
        Log.e("WebGetResponse", "["+connectionID+"] gotInputStream()");
        byte[] contents = new byte[1024];

        int bytesRead=0;
        StringBuilder strFileContents = new StringBuilder();
        Log.e("WebGetResponse", "["+connectionID+"] Waiting for data");
        while((bytesRead = bin.read(contents)) != -1) {
            String add = new String(contents, 0, bytesRead);
            strFileContents.append(add);
        }
        bin.close();
        response = strFileContents.toString();
    } catch (IOException e) {
        Log.e("WebService", "I/O exception reading stream: " + e.getMessage());
        e.printStackTrace();
        return null;
    } finally {
        urlConnection.disconnect();
    }

    Log.e("WebGetResponse", "["+connectionID+"] " + response);
    return response;
}

我一直在尝试搜索 - 我没有遇到问题。实际上我当前无法在非https服务器上测试该类,所以我不知道HTTP中是否也出现问题。但是,握手似乎有效,因为第一个请求运行良好。

以下是应该启动请求的代码(最终参数是要发送的GET内容):

    class ServerDataThread extends AsyncTask<Integer, Integer, String[]> {

        @Override
        protected String[] doInBackground(Integer... attempts) {
            sendActive++;
            int count = attempts.length;
            String[] responses = new String[count];
            for (int i = 0; i < count; i++) {
                responses[i] = server.webGet("collector.php", params);
            }
            return responses;
        }

        protected void onPostExecute(String[] responses) {
            sendActive--;
            for (int i = 0; i < responses.length; i++) {
                if (responses[i] == null) {
                    continue;
                }
                onResponseData(responses[i]);
            }
        }
    }
    new ServerDataThread().execute(0); 

有人可以帮我提示我做错了什么吗?非常感谢你!

BurninLeo

0 个答案:

没有答案