Thursday, October 24, 2013

Android HTTP Access - Tutorial

Performing HTTP operations with Android
This article describes how to access web resources via HTTP in Android. It is based on Eclipse 3.7, Java 1.6 and Android 4.0 (Ice Cream Sandwich).

1. Overview of HTTP access on Android

1.1. Available API's

Android contains the standard Java network java.net package which can be used to access network resources. Android also contains the Apache HttpClient library.
The base class for HTTP network access in the java.net package is the HttpURLConnection class.
The preferred way of accessing the Internet according to Google is the HttpURLConnection class, as Google is focusing their efforts on improving this implementation.

1.2. Required permissions

To access the Internet your application requires the android.permission.INTERNET permission.
To check the network state your application requires theandroid.permission.ACCESS_NETWORK_STATE permission.

2. Android StrictMode

Within an Android application you should avoid performing long running operations on the user interface thread. This includes file and network access.
StrictMode allows to setup policies in your application to avoid doing incorrect things. As of Android 3.0 (Honeycomb) StrictMode is configured to crash with a NetworkOnMainThreadExceptionexception, if network is accessed in the user interface thread.
While you should do network access in a background thread, this tutorial will avoid this to allow the user to learn network access independent from background processing.
If you are targeting Android 3.0 or higher, you can turn this check off via the following code at the beginning of your onCreate() method of your activity.
StrictMode.ThreadPolicy policy = new StrictMode.
ThreadPolicy.Builder().permitAll().build();
StrictMode.setThreadPolicy(policy);
It is not advised to turn this of but in this tutorial we use this setting to be able to explain network access independently from background processing.

3. HttpURLConnection

HttpURLConnection which is also available in standard Java, is a general-purpose, lightweight HTTP client suitable for most applications.
In the latest version HttpURLConnection supports the transparent response compression (via the header Accept-Encoding: gzip, Server Name Indication (extension of SSL and TLS) and a response cache.
The API is relatively straight forward. For example to retrieve the webpage www.vogella.com.
// Somewhere in your code this is called
// in a thread which is not the user interface
// thread

try {
URL url = new URL("http://www.vogella.com");
HttpURLConnection con = (HttpURLConnection) url
.openConnection();
readStream(con.getInputStream());
} catch (Exception e) {
e.printStackTrace();
}



private void readStream(InputStream in) {
BufferedReader reader = null;
try {
reader = new BufferedReader(new InputStreamReader(in));
String line = "";
while ((line = reader.readLine()) != null) {
System.out.println(line);
}
} catch (IOException e) {
e.printStackTrace();
} finally {
if (reader != null) {
try {
reader.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
The Javadoc of HttpURLConnection suggest to not reuse on HttpURLConnection. If you use it this way, HttpURLConnection has no threading issues, as it will not be shared between differentThreads.

4. Check the network availability

Obviously the network on an Android device is not always available. You can check the network is currently available via the following code.
public boolean isNetworkAvailable() {
ConnectivityManager cm = (ConnectivityManager)
getSystemService(Context.CONNECTIVITY_SERVICE);
NetworkInfo networkInfo = cm.getActiveNetworkInfo();
// if no network is available networkInfo will be null
// otherwise check if we are connected
if (networkInfo != null && networkInfo.isConnected()) {
return true;
}
return false;
}
This requires the ACCESS_NETWORK_STATE permission.

5. Proxy

This chapter is only relevant for you if you are testing with the Android simulator behind a proxy. You can set the proxy via the Settings class. For example you could add the following line to youronCreate method in your activity.
Settings.System.putString(getContentResolver(), Settings.System.HTTP_PROXY, "myproxy:8080"); 
To change the proxy settings you have to have the android.permission.WRITE_SETTINGSpermission in your AndroidManifest.xml file.

No comments:

Post a Comment