HttpURLConnection getInputStream FileNotFoundException

Hello Android/Java coders!

So I recently got some weird errors when doing HTTP requests in my Android game Hamster Climb. I was trying to get the input stream from a HttpURLConnection but kept getting a FileNotFoundException even though the URL worked perfectly in my desktop browser. Here’s an example, without error catching stuff, of how the code could look like:

String user = getUser();
String url = "" + user;
URL u = new URL(url);
HttpURLConnection c = (HttpURLConnection) u.openConnection();

InputStream is = c.getInputStream();

The problem was that at the last line the call to getInputStream generated a FileNotFoundException. I printed the URL that was used and tried it in the browser. Worked prefectly.

I managed to solve it though. The problem was that even though creating a URL object with the built URL string works, the URL might be broken. For example, if user is “Some guy” the url will contain a space which is not valid. Browsers solve this by automatically replacing the space with %20 which is what my browser did.

To solve this in code you use the URLEncoder class’ static method encode. This method takes a string and encodes it to a string that is ok to put in a URL. So replacing

String url = "" + user;


String url = "" + URLEncoder.encode(user, "UTF-8");

solves the problem when user contains illegal URL characters.

Hope this helps someone out there getting weird errors. 🙂


10 thoughts on “HttpURLConnection getInputStream FileNotFoundException

  1. I had the same exact exception happening at my end.
    Though the bug I found was a null value was being set for a request-header property of HttpURLConnection.
    Maybe this helps someone.

  2. @rishabh,

    which request-header property?

    I am also getting this exception, but I have no characters in my URL string that would need encoding. can you tell me which property you had that was null?


    1. Hey Nate,
      In my case, the K-V pair for a request property was “site-id” : “”
      So if by mistake a null value was being passed, the server was not able to make a connection, and was throwing a FNFE.
      The best practice states that:
      * Check your request params, for valid K-V pairs.
      * Check for a 200 OK response, before you perform a getInputStream on the connection object.
      if (connection.getResponseCode() == HttpURLConnection.HTTP_OK) {
      // valid response, retrieve your input stream
      BufferedReader reader = new BufferedReader(new InputStreamReader(
      connection.getInputStream(), “UTF-8”));
      } else {
      // something bad happened, debug from your server .

Leave a Reply

Fill in your details below or click an icon to log in: Logo

You are commenting using your account. Log Out /  Change )

Google+ photo

You are commenting using your Google+ account. Log Out /  Change )

Twitter picture

You are commenting using your Twitter account. Log Out /  Change )

Facebook photo

You are commenting using your Facebook account. Log Out /  Change )


Connecting to %s