Search code examples
androidjsonemulationioexceptionhttpconnection

Android HttpUrlConnection Url doesn't work on emulator


I am trying to get json object as string from this url http://digitalcollections.tcd.ie/home/getMeta.php?pid=MS4418_021. It doesn't work I get an error after downloadUrl function.

java.io.IOException: unexpected end of stream on Connection{digitalcollections.tcd.ie:80, proxy=DIRECT@ hostAddress=134.226.115.12 cipherSuite=none protocol=http/1.1} (recycle count=0)

Although it does work for this androidhive url http://api.androidhive.info/volley/person_object.json. I am new to httpconnection below is my download url function. Error seems to show in this line HttpURLConnection conn = (HttpURLConnection) url.openConnection(); In the debugger after that line conn.getInputStream() shows the IO exception and the cause java.io.EOFException: \n not found: size=0 content=...

 // Given a string representation of a URL, sets up a connection and gets
 // an input stream.
 private InputStream downloadUrl(String urlString) throws IOException {
        URL url = new URL(urlString);
        HttpURLConnection conn = (HttpURLConnection) url.openConnection();
        conn.setReadTimeout(20000 /* milliseconds */);
        conn.setConnectTimeout(30000 /* milliseconds */);
        conn.setRequestMethod("GET");
        //conn.setDoInput(true);        
        // Starts the query
        conn.connect();
        InputStream stream = conn.getInputStream();
        return stream;
    }

Other functions.

 // Uses AsyncTask to create a task away from the main UI thread. This task takes a
    // URL string and uses it to create an HttpUrlConnection. Once the connection
    // has been established, the AsyncTask downloads the contents of the webpage as
    // an InputStream. Finally, the InputStream is converted into a string, which is
    // displayed in the UI by the AsyncTask's onPostExecute method.
    private class DownloadXMLTask extends AsyncTask<String, Void, List<Entry>> {
        private String urlFront = "";
        @Override
        protected List<Entry> doInBackground(String... urls) {
            // params comes from the execute() call: params[0] is the url.
            try {
                    return loadJsonFromNetwork(urls[0]);
                } catch (IOException e) {
                    Log.d(TAG, "Unable to retrieve web page. URL may be invalid.");
                    return null;
                } catch (JSONException e) {
                    Log.d(TAG, "XMLPULLPARSER ERROR IN download json task function");
                    return null;
                }
            }

        }
        // onPostExecute displays the results of the AsyncTask.
        @Override
        protected void onPostExecute(List<Entry> result) {
            //post execution stuff
        }
    }

Loading json and parser, the parser might not work haven't tested it yet.

 private List<Entry> loadJsonFromNetwork(String urlString) throws IOException, JSONException {
        InputStream stream = null;
        int len = 20000; //max amount of characters to display in string
        List<Entry> entries = new ArrayList<Entry>();

        try {
            stream = downloadUrl(urlString);  //IOException
            String jsonStr = readit(stream,len);
            if(jsonStr.equals(null)){
                Log.d(TAG, "ERROR json string returned null");
                return entries;
            }
            JSONObject jsonObj = new JSONObject(jsonStr);

            //Not sure if the json parser works yet haven't got that far 
            // Getting JSON Array node
            identifier = jsonObj.getJSONArray("identifier");

            // looping through All Contacts
            for (int i = 0; i < identifier.length(); i++) {
                JSONObject c = identifier.getJSONObject(i);

                String id = c.getString("type");
                if(id.equals("DRIS_FOLDER")) {
                    String folder = c.getString("$");
                    entries.add(new Entry(null,null,null,folder));
                }
            }

            // Makes sure that the InputStream is closed after the app is
            // finished using it.
          //This is where IOexception is called and stream is null
        } catch (IOException e) {
            Log.d(TAG, "Unable to retrieve json web page. URL may be invalid."+ e.toString());
            return entries;
        }
        finally {
            if (stream != null) {
                stream.close();
            }
        }
        return entries;
    }

I am running this on a Nexus_5_API_23 emulator.

Thanks in advance.

UPDATE:

Doesn't work on Nexus_5_API_23 emulator?? Although it works on a Samsung GT-ST7500 external phone. Want it to work for the emulator.


Solution

  • The problem was my antivirus/firewall on my computer. It was blocking my connection and that's why it was working on a external phone and not emulator. I disabled my antivirus/firewall and it worked. There is a list of network limitations here http://developer.android.com/tools/devices/emulator.html#networkinglimitations