Skip to main content

Android web service access using Async Task



Android web service access using Async Task
In Android we can use Async Tasks to perform background activities without interrupting main gui thread. So it is ideal for the tasks like web service accessing in Android. In this post I'm going to demonstrate a very simple application which uses Async Task to access soap based web service. Here I access .NET web service Currency Converter provided by http://www.webservicex.net/

To create this application you need to have ksoap2 libaray. (You can download latest version of ksoap2 from here : 
http://code.google.com/p/ksoap2-android/wiki/HowToUse?tm=2 click the url under "with a direct download url of ").


Here is the quick demo of the application.



https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhAU6Wn-rzr8grL9a5xph3nBlgPmjF2LMwkV7T069lcOM9dRPnUzEiD7maYsQjBxKQR1ECdEASY0kKEdoOTH-91NTUqvOgOYhNlV24GJiNvbTf9UfzZemQxkdoqORSwbiUAGiTbwQHGiW-I/s320/android+web+service+access+using+async+task.png

Code for the main activity:


In line 68 I have set "envelope.dotNet = true;" because I'm accessing .NET web service. You can comment that line if you are accessing other web service.
?




























































































package com.soap.client;

import org.ksoap2.SoapEnvelope;
import org.ksoap2.serialization.PropertyInfo;
import org.ksoap2.serialization.SoapObject;
import org.ksoap2.serialization.SoapPrimitive;
import org.ksoap2.serialization.SoapSerializationEnvelope;
import org.ksoap2.transport.HttpTransportSE;
import android.os.AsyncTask;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.widget.TextView;
import android.widget.Toast;

public class MainActivity extends Activity {
 private TextView textView;

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  textView = (TextView) findViewById(R.id.textView1);
  this.accessWebService(textView);
 }

 @Override
 public boolean onCreateOptionsMenu(Menu menu) {
  // Inflate the menu; this adds items to the action bar if it is present.
  getMenuInflater().inflate(R.menu.main, menu);
  return true;
 }
  
 //starting asynchronus task
 private class SoapAccessTask extends AsyncTask<String, Void, String> {
      
     @Override
     protected void onPreExecute() {
          //if you want, start progress dialog here
     }
          
     @Override
     protected String doInBackground(String... urls) {
         String webResponse = "";
        try{
          final String NAMESPACE = "http://www.webserviceX.NET/";
          final String URL = "http://www.webservicex.net/CurrencyConvertor.asmx";
          final String SOAP_ACTION = "http://www.webserviceX.NET/ConversionRate";
          final String METHOD_NAME = "ConversionRate";
           
          SoapObject request = new SoapObject(NAMESPACE, METHOD_NAME);
          PropertyInfo fromProp =new PropertyInfo();
          fromProp.setName("FromCurrency");
          //gets the first element from urls array
          fromProp.setValue(urls[0]);
          fromProp.setType(String.class);
          request.addProperty(fromProp);
             
          PropertyInfo toProp =new PropertyInfo();
          toProp.setName("ToCurrency");
          //second element of the urls array
          toProp.setValue(urls[1]);
          toProp.setType(String.class);
          request.addProperty(toProp);
            
          SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(SoapEnvelope.VER11);
          envelope.dotNet = true;
          envelope.setOutputSoapObject(request);
          HttpTransportSE androidHttpTransport = new HttpTransportSE(URL);
           
          androidHttpTransport.call(SOAP_ACTION, envelope);
          SoapPrimitive response = (SoapPrimitive)envelope.getResponse();
          webResponse = response.toString();
       }
       catch(Exception e){
          Toast.makeText(getApplicationContext(),"Cannot access the web service"+e.toString(), Toast.LENGTH_LONG).show();
        }
         return webResponse;
    }
   
    @Override
    protected void onPostExecute(String result) {
            //if you started progress dialog dismiss it here
            textView.setText(result);
            Toast.makeText(getApplicationContext(),"Completed...", Toast.LENGTH_LONG).show();
         }
     }
  
   public void accessWebService(View view) {
   SoapAccessTask task = new SoapAccessTask();
      //passes values for the urls string array
      task.execute(new String[] { "USD","LKR"});
     } 
}
Code for the layout





















<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".MainActivity" >

    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="89dp"
        android:text=""
        android:textAppearance="?android:attr/textAppearanceMedium" />

</RelativeLayout>

You have to add INTERNET permission to AndroidManifest.xml
























<?xml version="1.0" encoding="utf-8"?>
    package="com.soap.client"
    android:versionCode="1"
    android:versionName="1.0" >
    <uses-sdk
        android:minSdkVersion="17"
        android:targetSdkVersion="17" />
    <uses-permission android:name="android.permission.INTERNET"/>
    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="com.soap.client.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>
</manifest>

Comments

Popular posts from this blog

Bitmap scalling and cropping from center

How to Bitmap scalling and cropping from center? public class ScalingUtilities {     /**      * Utility function for decoding an image resource. The decoded bitmap will      * be optimized for further scaling to the requested destination dimensions      * and scaling logic.      *      * @param res      *            The resources object containing the image data      * @param resId      *            The resource id of the image data      * @param dstWidth      *            Width of destination area      * @param dstHeight      *     ...

Custom camera using SurfaceView android with autofocus & auto lights & more

Custom camera using SurfaceView android with autofocus & auto lights & much more /**  * @author Tatyabhau Chavan  *  */ public class Preview extends SurfaceView implements SurfaceHolder.Callback {     private SurfaceHolder mHolder;     private Camera mCamera;     public Camera.Parameters mParameters;     private byte[] mBuffer;     private Activity mActivity;     // this constructor used when requested as an XML resource     public Preview(Context context, AttributeSet attrs) {         super(context, attrs);         init();     }     public Preview(Context context) {         super(context);         init();     }     public Camera getCamera() {        ...

Get Android phone call history/log programmatically

Get Android phone call history/log programmatically To get call history programmatically first add read conact permission in Manifest file : <uses-permission android:name="android.permission.READ_CONTACTS" /> Create xml file. Add the below code in xml file : <Linearlayout android:layout_height="fill_parent"  android:layout_width="fill_parent" android:orientation="vertical"> <Textview android:id="@+id/call" android:layout_height="fill_parent" android:layout_width="fill_parent"> </Textview> </Linearlayout> Now call the getCallDetails() method in java class : private void getCallDetails() { StringBuffer sb = new StringBuffer(); Cursor managedCursor = managedQuery( CallLog.Calls.CONTENT_URI,null, null,null, null); int number = managedCursor.getColumnIndex( CallLog.Calls.NUMBER ); int type = managedCursor.getColumnIndex( CallLog.Calls.TYPE ); int date = managedCur...