[Silex Framework] Make REST Web Service (2)
May 16, 2016 1 Comment
Melanjutkan postingan sebelumnya pada tautan https://sabitlabscode.wordpress.com/2016/05/07/silex-framework-make-rest-web-service-1/, kali ini saya akan memaparkan bagaimana membuat API untuk POST, PUT dan DELETE method (pada postingan sebelumnya telah dibahas API untuk GET method).
Apa sih beda antara GET, POST, PUT dan DELETE method ?
Penjelasan lengkapnya ada di https://www.w3.org/Protocols/rfc2616/rfc2616-sec9.html. Kalo males baca disana, singkatnya GET digunakan untuk operasi yang tidak merubah database/sistem, biasanya cuma nampilin data(view data detail, melihat list data, search, dll). Kalo POST digunakan untuk operasi yang merubah data (misal insert data baru ke dalam database server). Sedangkan PUT mirip dengan POST, tetapi PUT biasanya menyimpan informasi spesifik dari suatu data (misal kita ingin membuat operasi update data, kita biasanya punya info “id” data yang akan di update). Sedangkan DELETE dari namanya udah kelihatan biasa digunakan untuk operasi melakukan delete data, pada umumnya dia merubah data tetapi tidak melempar parameter ke dalam fungsi seperti POST dan PUT.
Sebelum melanjutkan project ini, siapa tahu nanti ada yang ga sukses mengikuti tutorial disni, anda dapat download code akhir dari project ini pada tautan berikut https://github.com/sabithuraira/tutor_silex. Sebelum lanjut perlu saya beritahukan bahwa nama tabel yang sebelumnya “menu_makanan” saya rubah menjadi “food_list”. Kemudian nama field pada tabel yang sebelumnya “nama” dan “harga”, saya rubah menjadi “name” dan “price”. Kok di rubah? biar orang yg ga ngerti bahasa Indonesia juga ngerti baca code dari github tadi.
Okey, sekarang mari kita lanjutkan…
Kita akan membuat sebuah perintah untuk insert data baru, masukkan code berikut :
//kita menggunakan POST $app->post('/insert', function (Silex\Application $app, Request $request) { //mendefinisikan data "food_list" yang akan ditambahkan $data=array( 'name' => $request->get('name'), 'price' => $request->get('price'), ); //perintah insert data baru ke dalam tabel "food_list" dengan data yang //sudah dideklarasikan $app['db']->insert('food_list', $data); return $app->json("Success save data"); });
Pada code di atas terdapat petikan code “$request->get(‘name’)” maksud dari kode tersebut adalah bahwa fungsi akan mengambil sebuah nilai yang dilempar oleh client service dengan nama “name”. Misal kalo suatu saat anda membuat sebuah aplikasi android untuk insert data melalui API ini, maka aplikasi android anda harus melempar nilai bernama “name” dan “price”. Server akan menangkap kedua nilai tersebut untuk diolah kemudian.
Setelah proses insert data, sekarang kita akan membuat proses update data. Masukkan kode berikut :
$app->put('/update/{id}', function (Silex\Application $app, Request $request,$id) { //definisi data, sama dengan pada proses insert //nilai-nilai dari data diambil dari variabel yg dikirimkan oleh //aplikasi client (dari aplikasi android pada penjelasan di atas) $data=array( 'name' => $request->get('name'), 'price' => $request->get('price'), ); //perintah untuk melakukan update data pada tabel food_list, //dengan data yg sudah di masukkan dan yg di update data dengan id tertentu $app['db']->update('food_list', $data,array('id'=>$id)); return $app->json("Success update data"); });
Code di atas adalah kode untuk melakukan update data melalui API, sebenarnya mirip dengan proses insert hanya saja kali ini kita memiliki informasi id dari data yang ingin diupdate.
Kemudian untuk proses delete data, masukkan kode berikut :
$app->delete(‘/delete/{id}’, function (Silex\Application $app, Request $request,$id) {
//perintah untuk menghapus data pada tabel “food_list” dengan id tertentu
$app[‘db’]->delete(‘food_list’, array(‘id’=>$id));
return $app->json(“Success delete data”);
});
Kode di atas lebih simpel karena hanya melempar suatu id kemudian menghapus data dengan id tersebut.
Dengan membuat fungsi untuk menghapus, maka kita sudah membuat contoh penerapan perintah dasar pada Rest API yaitu GET, POST, PUT dan DELETE. Kita juga sudah melihat contoh sederhana untuk melakukan operasi CRUD pada sebuah tabel. Sekarang masalahnya mungkin temen-temen merasa tidak bisa melakukan testing langsung output dari aplikasi yang kita buat. Ya, untuk dapat melihat secara langsung output dari aplikasi yang telah kita buat kita harus membuat langsung aplikasi client untuk mengkonsumsi REST API yang kita buat. Anda bisa membuat dengan aplikasi apapun, desktop app, mobile app, web app.. anda juga bebas menggunakan bahasa pemrograman apapun mau pake PHP, Java, C#, dll..
Gimana cara buat aplikasi client nya? Memang anda harus belajar lebih lanjut untuk memahami bagaimana cara membuat aplikasi clientnya. Pada postingan selanjutnya saya akan memaparkan tutorial membuat aplikasi client berbasis Android dengan Xamarin untuk mengkonsumsi REST API yang sudah kita buat pada postingan ini..
Selamat mencoba, happy coding 😀
Komentar