HttpUrlConnection z żądaniem postu i parametrem jako obiekt Json android

Hi Rozwijam małą aplikację dla systemu Android, w której chcę użyć żądania postu HttpUrlConnection z parametrami jako obiekt json. Ale to nie działa dla mnie, zrobiłem to w następujący sposób:

try 
{
    URL url;
    DataOutputStream printout;
    DataInputStream  input;
    url = new URL ("https://abc.com");
    HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
    urlConnection.setRequestMethod("POST");  
    urlConnection.setDoInput (true);
    urlConnection.setDoOutput (true);
    urlConnection.setUseCaches (false);

    urlConnection.setConnectTimeout(10000);  
    urlConnection.setReadTimeout(10000);

    urlConnection.setRequestProperty("Content-Type","application/json");   
    urlConnection.connect();  

    JSONObject jsonParam = new JSONObject();

      JSONArray arr = new JSONArray();
      arr.put("LNCf206KYa5b");
      arr.put("oWdC0hnm1jjJ");
      jsonParam.put("places", arr);
      jsonParam.put("action", "Do");

            printout = new DataOutputStream(urlConnection.getOutputStream ());
            printout.writeUTF(URLEncoder.encode(jsonParam.toString(),"UTF-8"));
            printout.flush ();
            printout.close ();

            int HttpResult =urlConnection.getResponseCode();  

        if(HttpResult ==HttpURLConnection.HTTP_OK){  
        BufferedReader br = new BufferedReader(new InputStreamReader(  
            urlConnection.getInputStream(),"utf-8"));  
        String line = null;  

           while ((line = br.readLine()) != null) {  
            sb.append(line + "\n");  
        }  
        br.close();  

           //System.out.println(""+sb.toString());  

        }else{  
             System.out.println(urlConnection.getResponseMessage());  
        }  
    } catch (MalformedURLException e) {  

        e.printStackTrace();  
    }  
    catch (IOException e) {  

        e.printStackTrace();  
    } catch (JSONException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }finally{  
        if(urlConnection!=null)  
           urlConnection.disconnect();  
    }  
}

Nie podaje żadnego kodu odpowiedzi ani żadnego wyjścia. Czy robię coś źle. Jak zaspokoić ten problem. Potrzebuję pomocy. Dziękuję Ci .

Otrzymałem następujący błąd systemowy

06-07 09:55:58.171: W/System.err(4624): java.io.IOException: Received authentication challenge is null
06-07 09:55:58.171: W/System.err(4624):     at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.processAuthHeader(HttpURLConnectionImpl.java:1153)
06-07 09:55:58.171: W/System.err(4624):     at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.processResponseHeaders(HttpURLConnectionImpl.java:1095)
06-07 09:55:58.171: W/System.err(4624):     at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.retrieveResponse(HttpURLConnectionImpl.java:1048)
06-07 09:55:58.171: W/System.err(4624):     at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.getResponseCode(HttpURLConnectionImpl.java:726)
06-07 09:55:58.179: W/System.err(4624):     at org.apache.harmony.luni.internal.net.www.protocol.https.HttpsURLConnectionImpl.getResponseCode(HttpsURLConnectionImpl.java:121)
06-07 09:55:58.179: W/System.err(4624):     at com.mobiotics.qcampaigns.data.operation.ProximityOperation.execute(ProximityOperation.java:187)
06-07 09:55:58.179: W/System.err(4624):     at com.foxykeep.datadroid.service.RequestService.onHandleIntent(RequestService.java:145)
06-07 09:55:58.179: W/System.err(4624):     at com.foxykeep.datadroid.service.MultiThreadedIntentService$IntentRunnable.run(MultiThreadedIntentService.java:170)

questionAnswers(2)

yourAnswerToTheQuestion