BufferedReader на Android отключает мой HTTP-пост? - PullRequest
1 голос
/ 08 сентября 2011

Используя базовый пример Http Post,

try {
    // Construct data
    String data = URLEncoder.encode("param", "UTF-8") + "=" + URLEncoder.encode(param, "UTF-8");
    data += "&" + URLEncoder.encode("param", "UTF-8") + "=" + URLEncoder.encode(param, "UTF-8");
    data += "&" + URLEncoder.encode("param", "UTF-8") + "=" + URLEncoder.encode(param, "UTF-8");
    data += "&" + URLEncoder.encode("param", "UTF-8") + "=" + URLEncoder.encode(param, "UTF-8");

    // Send data
    URL url = new URL("URL THAT IM SEARCHING");
    URLConnection conn = url.openConnection();
    conn.setDoOutput(true);
    OutputStreamWriter wr = new OutputStreamWriter(conn.getOutputStream());
    wr.write(data);
    wr.flush();

    // Get the response
    BufferedReader rd = new BufferedReader(new InputStreamReader(conn.getInputStream()));
    json = rd.readLine();
    Log.d("TAG",json);
    wr.close();
    rd.close();
} catch (Exception e) { }

Мой ответ сокращен в Android по сравнению с ответом, который я получу, запустив его вне Android или даже в моем браузере.

Размер максимального отклика в Android составляет ~ 4070 байт против его фактических 14 000 +.

Я попытался установить размер буфера в 14200, и ответ остался прежним.

Редактируйте новый код ниже (переключился на https и попробовал предлагаемое решение), все еще получая ~ 4070 пока ответа

String getUrl = ("https:.asdadasd/"+trimmed+"?latitude="+lat+"&longitude="+lng+"&distance="+rad);
        Log.d("TAG","URL USED FOR SEARCHING: "+getUrl);
        HttpClient client = new MyHttpClient(getApplicationContext());
        HttpGet get = new HttpGet(getUrl);
        HttpResponse responseGet = null;
        try {
        responseGet = client.execute(get);
        HttpEntity resEntityGet = responseGet.getEntity();    
        InputStream instream = resEntityGet.getContent();

        String result= convertBrToString(instream);
        json = result;
        instream.close();
        } catch (ParseException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }  
        Log.d("TAG", json);

        }
  public String convertBrToString(InputStream in) 
  {

          BufferedReader br;
          StringBuffer outString = new StringBuffer();
          br = new BufferedReader(new InputStreamReader(in)); 
          try {
              String read;
              read = br.readLine();
          while(read != null)
          {
              outString.append(read);
              read =br.readLine();
          }
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
          return outString.toString();     
  }

1 Ответ

0 голосов
/ 10 сентября 2011

Оказывается, мне никогда не приходилось делать преобразование! простой

    ResponseHandler<String> responseHandler=new BasicResponseHandler();
            String responseBody = client.execute(get, responseHandler);

Сделал свое дело, но проблема в том, что Log будет печатать только 4096 байт, и что мой анализатор json получал длину неверного массива!

Спасибо всем за вашу поддержку, и не забудьте перепроверить ваш код!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...