About Me

Agus Haryanto,
Android Trainner,
GoogleMaps (JavaScript) Trainer
JQuery and JQuery Mobile Trainer
Java, Java Script and PHP Trainer
Freelance Developer Android
Freelance Developer Blackberry
Freelance Developer Web (GIS Googlemaps)
Freelance Developer SMS Gateway

jika ingin contact saya bisa emali ke agus.superwriter@gmail.com

ym: agus_h23

Pin BB : 2AD38B33

Facebook : Agus Haryanto


Article

Tutorial Android Komunikasi dengan Server menggunakan Http

Ada orang yang bilang pakai android tanpa koneksi internet bagaikan minum teh tanpa gula. Anda pasti pernah merasakan betapa nyamannya browsing diandroid, main game diandroid. Download aplikasi dimarket. Untuk cari rumah makan aja buka aplikasi android lalu cari deh rumah makan terdekat dengan lokasi kita. Selain itu kita juga bisa facebook atau twitter tanpa buka browser, tapi melalui aplikasi.

Lho kok bisa berarti aplikasi android itu connect ke servernya facebook dan twitter dong.

Ada beberapa pertanyaan menarik dari beberapa pembaca, yang sepertinya ingin membangun aplikasi android yang menggunakan data dari server.

Ada lagi yang bertanya. Untuk data itu sebaiknya disimpan didatabase local atau server ?

Kalau aplikasi itu hanya digunakan untuk mencatat dan melihat data pribadi (yang diisikan oleh hanya user tersebut) lebih baik datanya disimpan dilocal database. Contohnya Aplikasi AHFinancial Record yang saya buat.

Tetapi apabila datanya digunakan oleh banyak orang, kita input, orang lain juga bisa lihat maka data harus disimpan diserver. Contohnya Aplikasi facebook tadi. Kalau kita update status. Nah teman-teman kita bisa lihat.

Kembali kemateri pokok, bagaimana android berkomunikasi dengan server ?

Untuk berkomunikasi dengan server ada beberapa cara yang dapat kita tempuh yaitu melalui Http connection atau Native Socket Connection.

Pada materi kali ini kita fokus menggunakan Http Connection untuk menghubungkan aplikasi android kita dengan server.

Kalau kita gunakan Http Connection artinya kita harus mempunyai web server. Dalam hal ini umunya Apache, bagi yang sudah pernah belajar php dan mysql harusnya sudah mengenalnya.

Bagi yang belum terinstall apache pada computer atau notebooknya, bisa install XAMPP untuk windows atau LAMP untuk linux  disini akan langsung terinstall Apache, PHP dan MySQL.

Untuk Windows biasanya directory root ada di directory htdoc

Untuk Linux biasanya di /var/www

Kalau kita search di internet untuk format data standar antara aplikasi android dan server biasnya menggunakan XML, JSON

Tapi kita  tidak akan bahas itu saat ini. Goal kita pada tutorial kali ini adalah kita bisa mengirim data ke server lalu server menerima dan memprosesnya kemudian server mengirmkan data ke Aplikasi kita dan Aplikasi kita dapat menerimanya

Untuk mari kita buat Aplikasi untuk Login ke server, disini kita harus menginputkan user dan password. Untuk itu mari kita buat file login.php

<?php
    $user = $_GET['user'];//get nilai user from client
	$password = $_GET['password'];//get nilai pass from client
	$sret = '';

	if ($user=='agus' && $password=='android'){
		$sret = 'Login Success';
	}else{
		$sret = 'Login Fail, User dan Password Salah';
	}
	echo $sret;

?>

Dari Script PHP diatas berarti data yang kirim dari Client harus menggunakan method GET. disini akan de cek nilai user dan password, apabila nilai user adalah agus dan password adalah android maka server maka mengirimkan jawaban “Login Sucess”. Apabila nilai user dan passwordnya tidak agus dan android maka server akan amengirimkan jawaban “Login Fail, User dan Password salah.

Seperti kita ketahui dalam modus Http ini ada 2 method yang bisa digunakan yaitu get dan post

Sekarang mari kita buat projectnya

1. Buat New Project, isi keterangan yang dibutuhkan sesuai dengan gambar dibawah ini

Pada saat project pertama kali dibuat ada 3 file penting yang langsung dibuat, yaitu

  • main.xml
  • string.xml
  • MainActivity.java

2. edit file main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >

<TextView
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="Komunikasi Ke Server menggunakan Http"
    />
<TextView android:text="User :" android:id="@+id/TextView01" android:layout_width="wrap_content" android:layout_height="wrap_content"></TextView>
<EditText android:text="" android:id="@+id/txtUser" android:layout_width="fill_parent" android:layout_height="wrap_content" ></EditText>
<TextView android:text="Password :" android:id="@+id/TextView02" android:layout_width="wrap_content" android:layout_height="wrap_content"></TextView>
<EditText android:text="" android:id="@+id/txtPassword" android:layout_width="fill_parent" android:layout_height="wrap_content" ></EditText>
<Button android:text="Login" android:id="@+id/btnLogin" android:layout_width="fill_parent" android:layout_height="wrap_content"></Button>
<TextView android:text="Status:" android:id="@+id/TextView03" android:layout_width="wrap_content" android:layout_height="wrap_content" ></TextView>
<EditText android:text="" android:id="@+id/txtStatus" android:layout_width="fill_parent" android:layout_height="wrap_content" android:editable="false"></EditText>
</LinearLayout>

Pada main.xml ini kita membuat

  • 2 buah EditText untuk Input User dan Password
  • 1 buah Button “Login” sebagai trigger untuk Mengirim data
  • 1 buah EditText untuk Menampilkan hasil kembalian dari server

3. . Edit file MainActivity.java

MainActivity.java adalah pemain utama, yang akan djalankan pada saat applikasi dijalankan. Pada class ini, kita buat untuk dapat membaca data yang diinputkan user dalam hal ini inputan user dan password, kemudan mengirimkannya  ke server pada saat kita klik button login dan menampilkan data yang diterima server.

package com.agus.android.http;

/**
 * Class MainActivity
 * @version 1.0 Apr 04, 2011
 * @author Agus Haryanto (agus.superwriter@gmail.com)
 * @website http://agusharyanto.net
 */

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;

import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.DefaultHttpClient;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;

public class MainActivity extends Activity {
	private EditText txtUser;
	private EditText txtPassword;
	private EditText txtStatus;
	private Button btnLogin;
	private String url = "http://agusharyanto.net/android/login.php";
	/**
	 * Method yang dipanggil pada saat aplikaasi dijalankan
	 * */
	@Override
	public void onCreate(Bundle savedInstanceState) {

		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		txtUser = (EditText) findViewById(R.id.txtUser);
		txtPassword = (EditText) findViewById(R.id.txtPassword);
		txtStatus = (EditText) findViewById(R.id.txtStatus);
		btnLogin = (Button) findViewById(R.id.btnLogin);
		//daftarkan even onClick pada btnLogin
		 btnLogin.setOnClickListener(new Button.OnClickListener(){
	            public void onClick(View v){
                        url="http://agusharyanto.net/android/login.php";
	            	url +="?user="+txtUser.getText().toString()+"&password="+txtPassword.getText().toString();
	                getRequest(txtStatus,url);
	            }
	        });

	}

	/**
	 * Method untuk Mengirimkan data kes erver
	 * event by button login diklik
	 *
	 * @param view
	 */
	public void getRequest(EditText txtResult, String SUrl){
       Log.d("getRequest",Url);
        HttpClient client = new DefaultHttpClient();
        HttpGet request = new HttpGet(SUrl);
        try{
            HttpResponse response = client.execute(request);
            txtResult.setText(request(response));
        }catch(Exception ex){
            txtResult.setText("Failed Connect to server!");
        }

    }
	/**
	 * Method untuk Menerima data dari server
	 * @param response
	 * @return
	 */
	public static String request(HttpResponse response){
        String result = "";
        try{
            InputStream in = response.getEntity().getContent();
            BufferedReader reader = new BufferedReader(new InputStreamReader(in));
            StringBuilder str = new StringBuilder();
            String line = null;
            while((line = reader.readLine()) != null){
                str.append(line + "\n");
            }
            in.close();
            result = str.toString();
        }catch(Exception ex){
            result = "Error";
        }
        return result;
    }

}

Pada contoh diatas apabila kita menyimpan file login.php di computer atatu notebook kita pada directory htdoc/android

Maka gantilah

private String url = “http://agusharyanto.net/android/login.php”;

dapat diganti dengan

private String url = “http://10.0.2.2/android/login.php”;

atau ganti dengan url server tempat kita menyimpan file login.php

4. Edit File  AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="com.agus.android.http"
      android:versionCode="1"
      android:versionName="1.0">
    <application android:icon="@drawable/icon" android:label="@string/app_name">
        <activity android:name=".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>
     <uses-permission android:name="android.permission.INTERNET">
   </uses-permission>
    <uses-sdk android:minSdkVersion="7" />
</manifest>

Karena disini kita berkomunikasi dengan server (biasanya menggunakan jalur internet) maka kita harus menambahkan

<uses-permission android:name=“android.permission.INTERNET”> </uses-permission>
5. Semua code telah selesai dibuat, saatnya kita Run Project.

Isi User dengan agus dan password dengan android lalu klik button Login, Server akan menerima data inputan kita dan menjawab permintaan kita dengan mengirimkan data “Kearena User dan Passwordnya benar maka Server akan menjawab dengan “Login Success


Kita coba lagi dengan mengisi User dengan joko lalu password dengan abcd, lalu klik button login  “Karena User dan Passwordnya salah” maka server akan menjawab “Login Fail, User dan Password Salah“.

Satu lagi senjata kita untuk membangun aplikasi yang hebat telah bertambah. Pada artikel ini memang saya fokuskan untuk dasar komunikasi ke server dengan menggunakan Http dengan method Get. Logikanya kalau kita bisa sukses mengakses file PHP yang ada diserver, berarti kita bisa juga mengakses database MySQL tentunya melalui file PHP. Wah kalau dah bisa akses database diserver, kita punya kemampuan untuk buat aplikasi yang berkelas nih.

Jika baru mulai belajar android dianjurkan untuk membaca tutorial

Aplikasi Android Sederhana - Menghitung Luas Persegi Panjang

Semoga Bermanfaat

Agus Haryanto

Sumber : http://developer.android.com

Share

114 comments to Tutorial Android Komunikasi dengan Server menggunakan Http

  • Mansur

    koq saya pake ip android (emulator)…10.0.2.2 (private String url = “http://10.0.2.2/android/login.php”;)
    tetep ga bisa ya terhubung ke server (localhost)xampp..mesti tulisannya Failed to conncet server

  • Mansur

    private String url = “http://10.0.2.2/android/login.php”;
    tetep ga bisa konek ke server xampp (localhost)…kenapa ya gan????mohon pencerahan

  • eksan

    sama seperti mas @hezbi udah di gonta-ganti 10.0.2.2, 127.0.0.1, localhost sampai ke website langsung tetep jawabannya selalu selalu failed connect to server.
    padahal contoh program lain untuk menampilkan berita bisa tampil baik dari http://10.0.2.2 maupun dari website. bedanya di contoh itu memang menggunakan AsyncTask.

    tapi setelah pakai cara http://agusharyanto.net/wordpress/?p=739 ternyata sukses.
    saya menggunakan target-sdk=19

  • Terimakasih mas agus, mau tanya mas jika aplikasi yang akan kita buat sitemnya online dan ofline itu gimana ya mas? apa harus menggunakan 2 database?

  • nila

    pak, saya sudah coba, tapi HttpClient sudah gak bisa di gunakan, jadi saya memakai bantuan library, tapi masih belum bisa konek pak, pak agus bisa bantu ? soalnya untuk tugas akhir

  • terima kasih banyak om.. ini sangat membantu…..!!!!

  • Makasih Gan, membantu Saya dalam pembelajaran Apk Android

  • Dewi NurD

    pak, mau nanya. misal saya pakenya xammp. urlnya saya tuliskan http://localhost/namafolder/.. bisa gak?
    kemudian di androidmanifest itu kan harus diedit menjadi “android.permission.INTERNET”. nah ini kan saya gak konek internet, cuma dari android mau update data di mysql nya Xampp

    lalu bagaimana solusinya? terimakasih

  • Agus Haryanto

    @Dewi NurD, bisa ganti IPnya dengan 10.0.2.2
    coba baca juga rtikel tentang Login dengan Volley di Blog ini.

  • mohammad risky

    mas, misal mau di online kan gmn ?

  • Siska

    Saya sudah coba programmnya tapi tidak bisa dijalankan soalnya pada file MainActivity.java -nya, pada bagian string kebawah/ program untuk menerima dan mengirimkan data ke server itu error. itu masalahnya dimana ya ? terimakasih

  • indra

    Permisi pak, apakah ada tutorial pembuatan aplikasi chatting enkripsi?

  • kalo server saya pake SSL / HTTPS ko engga bisa connect ya?
    solusinya gimana ya om?

  • Egi

    paak, saya sudah coba,saya menggunakan http://10.0.2.2:81/android/login.php, menggunakan 81 karna port yang saya pakai 81, pas saya running ketika di input username dan password di status akan tampil FAILED CONNECT TO SERVER, saya sudah coba alamat ini http://10.0.2.2:81/android/login.php di url emulator bisa, tetapi pas di inpud di aplikasinya tidak , mohon bantuannya ..

Leave a Reply

 

 

 

You can use these HTML tags

<a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>

Spam protection by WP Captcha-Free