php tutorial in youtube,php tutorial intermediate,sql i php tutorial,tutorial php javascript mysql,tutorial php json,tutorial php jquery,tutorial php javascript,tutorial php jwt,tutorial php jquery ajax,tutorial php java bridge,tutorial json php mysql,tutorial jenkins php,tutorial jquery php mysql,tutorial koneksi php mysql,tutorial koneksi php,tutorial coding php,calendar php tutorial,tutorial koneksi php ke mysql,tutorial koneksi php ke database mysql,php klein tutorial,php kafka tutorial,kumpulan tutorial php,tutorial cara membuat koneksi php dengan database mysql,k php tutorial,tutorial php login,tutorial php lengkap bahasa pemrograman php belajar php pdf,tutorial php laravel,tutorial php login session,tutorial php login & registration,tutorial php linux,tutorial php lengkap untuk pemula,tutorial php lengkap bahasa indonesia,tutorial php login system,tutorial php membuat website,tutorial php mysql bahasa indonesia pdf,tutorial php mvc,my php tutorial,php and mysql tutorial pdf,phpmyadmin database tutorial,phpmyadmin tutorial pdf,tutorial menggunakan phpmyadmin,mysql phpmyadmin tutorial,tutorial php netbeans,tutorial php namespace,tutorial php.net,tutorial php notepad++,tutorial php netbeans pdf,tutorial php nusoap,tutorial php netbeans español,tutorial nginx php,php mysqli tutorial,tutorial php online,tutorial php object oriented programming,php oop tutorial,tutorial php oracle,tutorial php oop pdf,tutorial php oop mvc,tutorial php oop programming,tutorial php oop crud,tutorial php online shop,tutorial php pemula,tutorial php pdo,tutorial php pdf bahasa indonesia,tutorial php pdo indonesia,tutorial php postgresql,tutorial php programming,tutorial php project,tutorial php postgresql pdf,tutorial php query mysql,php tutorial quiz,php tutorial quick,php tutorial query,php qt tutorial,php barcode tutorial,php tutorial quora,php tutorial questions and answers,php tutorial quakenet,php tutorial query database,tutorial php rest api,tutorial php report maker,tutorial php runner,tutorial php redis,tutorial php report maker pdf,tutorial php register,tutorial php regular expression,tutorial republic php,tutorial regex php,php tutorial restful web services,php-r tutorial,tutorial php source code aplikasi pemesanan tiket bus online - gratis,tutorial php socket,tutorial php switch,tutorial php soap,tutorial php storm,tutorial php sql,tutorial php symfony,tutorial php session,tutorial php sqlite,tutorial php to pdf,tutorial php telegram bot,tutorial php to excel,php tutorial tutorialspoint pdf,tutorial twig php,php tutorial tizag,php tutorial template,tutorial to php,php tutorial to send email,phpunit test tutorial,tutorial php untuk pemula,tutorial php unit,tutorial php unit testing phpunit laravel,tutorial php upload file,tutorial php ubuntu,tutorial php upload image,tutorial php untuk membuat website,tutorial php update insert delete and search,php tutorial udemy,tutorial php video,tutorial php validation form,php tutorial video free download,php tutorial video download,php tutorial video youtube,php tutorial variables,php tutorial visual studio,best php tutorial videos,best php tutorial video,php varnish tutorial,tutorial php w3schools,tutorial php wordpress,tutorial php website,tutorial php web service,tutorial php websocket,tutorial php web application,tutorial php with mysql,tutorial php windows,tutorial php website template,tutorial php with xampp,kalendarz w php tutorial,tworzenie stron w php tutorial,tutorial php xml,tutorial php xampp pdf,tutorial xampp php mysql,tutorial xpath php,tutorial xdebug php,tutorial php mysql xampp pdf,php xml reader tutorial,php xmlwriter tutorial,tutorial php youtube,tutorial php yii,youtube tutorial php,tutorial php y mysql,tutorial php y mysql pdf,tutorial php y mysql completo,tutorial php ya,php tutorial youtube video,php tutorial secure your login form using tokens,oop php tutorial youtube,mysql y php tutorial,tutorial php y mysqli,tutorial php y mysql netbeans,html5 y php tutorial,tutorial php y html,tutorial php y postgresql pdf,tutorial php y mysql youtube,tutorial php y mysql español,tutorial php zend framework,php tutorial zend,php tutorial zip,php ziparchive tutorial,php zlib tutorial,php tutorial za pocetnike,php tutorial using zend framework,php zeromq tutorial,php zend tutorial pdf,php zeiterfassung tutorial,a to z php tutorial,php 000webhost tutorial,tutorial php desde 0,php tutorial 101,tutorial belajar php part 1,php tutorial 1,cakephp 1.3 tutorial,tutorial php 2018,tutorial php 2017,tutorial phpmaker 2018,php tutorial 2018,php tutorial 2017 pdf,php tutorial 2016,php tutorial 2,cakephp 2.x tutorial,best php tutorial 2017,doctrine 2 php tutorial,oauth2 php tutorial,angular 2 tutorial php,angularjs 2 tutorial php,magento 2 php tutorial,php symfony2 tutorial,ionic 2 php tutorial,2 dimensional array php tutorial,phpdocumentor 2 tutorial,2 factor authentication php tutorial,tutorial cakephp 3,php tutorial 3school,php tutorial 3w,php 3 tutorial,slim 3 php tutorial,sqlite3 php tutorial,openshift 3 php tutorial,aptana studio 3 tutorial php,symfony 3 php tutorial,symphony 3 php tutorial,aptana studio 3 tutorial php pdf,sublime text 3 tutorial php,php tutorial 4,angular 4 tutorial php,psr-4 php tutorial,symfony 4 php tutorial,symphony 4 php tutorial,php 4 tutorial,phpunit 4 tutorial,tutorial php 5.6,php5 tutorial pdf,tutorial php 5.5,tutorial php 5.5 pdf,php 5.6 tutorial pdf,php5 tutorial point,php5 tutorial pdf download,php 5.3 tutorial,php 5.3 tutorial pdf,php5 tutorial - w3schools,laravel 5 phpunit tutorial,laravel 5 php tutorial,php 5 tutorial,angular 5 php tutorial,phpunit 5 tutorial,facebook sdk 5 php tutorial,php 6 tutorial pdf,phpmailer 6 tutorial,php 6 tutorial,phpunit 6 tutorial,tutorial #6 esp8266 - mysql + php en servidor local,tutorial php 7 bahasa indonesia pdf,tutorial php 7 mysql,tutorial php 7.0,tutorial php 7 español,tutorial crud php 7,tutorial point php 7,tutorial belajar php 7,php 7 tutorial w3schools,psr-7 tutorial php,php 7 tutorial,php 7 tutorial pdf,php 7 tutorial point,php 7 tutorial mysql,php 8 tutorial,tutorial phprunner 8,drupal 8 phpunit tutorial,drupal 8 php tutorial,dreamweaver 8 php tutorial pdf,php designer 8 tutorial,php designer 8 tutorial pdf,macromedia dreamweaver 8 php tutorial,phpmaker 9 tutorial,cloud 9 php tutorial,phprunner 9 tutorial,phpmaker 9 tutorial pdf,phpstorm 9 tutorial,tutorial php,tutorial php mysql,tutorial php native,tutorial php pdf,tutorial php dan mysql,tutorial php codeigniter,tutorial php lengkap,tutorial phpmaker pdf,tutorial phpmyadmin,tutorial php api,tutorial php advanced,tutorial php array,tutorial php ajax,tutorial php admin,tutorial php apache,tutorial php ajax jquery,tutorial php ajax mysql,a php tutorial for beginners,a complete php tutorial,a complete php tutorial pdf,tutorial php bahasa indonesia,tutorial php bagi pemula,tutorial php blog,tutorial php beginner,tutorial php backend,tutorial php bot telegram,tutorial php blockchain,tutorial php basico,php tutorial by tizag,tutorial php codeigniter pdf,tutorial php codeigniter bahasa indonesia,tutorial php curl,tutorial php connect mysql,tutorial php class,tutorial php composer,tutorial php contact form,tutorial php dasar,tutorial php dreamweaver cs6,tutorial php dan mysql lengkap,tutorial php dengan dreamweaver,tutorial php dasar lengkap pdf,tutorial php database,tutorial php duniailkom,tutorial php dreamweaver,tutorial php dasar pdf,tutorial di php,tutorial php excel,tutorial php eclipse,tutorial php en pdf,tutorial php ecommerce,tutorial php en netbeans,tutorial php editor,tutorial php ebook,tutorial php email form,tutorial php echo,tutorial php español,e commerce tutorial php,e commerce website tutorial php,mysql e php tutorial,e commerce website php tutorial download,ecommerce cart php tutorial,e-shop php tutorial,tutorial php framework,tutorial php form,tutorial php framework laravel,tutorial php for beginners,tutorial php framework codeigniter,tutorial php facebook api,tutorial php firebase,tutorial php-fpm,tutorial php foreach,tutorial php file upload,tutorial php generator for mysql,tutorial php gtk,tutorial php generator for mysql professional,tutorial php graphql,tutorial php grid,php tutorial github,php tutorial get,tutorial gammu php mysql,php tutorial get post,tutorial gettext php,tutorial php html,tutorial php html mysql,tutorial php html css,tutorial php html5,php tutorial hello world,tutorial highcharts php mysql,tutorial htaccess php,php tutorial home and learn,tutorial heroku php,tutorial html2pdf php,tutorial php indonesia,tutorial php indonesia pdf,tutorial php injection,tutorial php.ini,tutorial php include,tutorial php it,php tutorial in w3schools,php tutorial interactive

codeigniter https,codeigniter hooks,codeigniter html2pdf,codeigniter hack,codeigniter hmvc template,codeigniter harviacode,codeigniter h,codeigniter insert,codeigniter insert batch,codeigniter insert_id,codeigniter inner join,codeigniter insert data,codeigniter ion auth,codeigniter import excel,codeigniter insert id,codeigniter install,session i codeigniter,for loop i codeigniter,codeigniter join,codeigniter join table,codeigniter jwt,codeigniter json,codeigniter jquery,codeigniter jquery ajax post data,codeigniter javascript,codeigniter join 2 table,codeigniter jwt tutorial,codeigniter json output,jquery in codeigniter,codeigniter kirim email,codeigniter kelebihan,codeigniter kaskus,codeigniter koneksi 2 database,codeigniter keuangan,codeigniter kenjis,codeigniter koolreport,codeigniter kint,codeigniter key generator,codeigniter keep form values after submit,codeigniter like,codeigniter left join,codeigniter last insert id,codeigniter library,codeigniter logo,codeigniter language,codeigniter login user level,codeigniter logo png,codeigniter load view,codeigniter l,codeigniter model,codeigniter multiple upload,codeigniter mongodb,codeigniter menurut para ahli,codeigniter multiple database,codeigniter mpdf,codeigniter migration,codeigniter mysqli,codeigniter mvc,fpdf codeigniter,codeigniter num_rows,codeigniter nginx,codeigniter not found,codeigniter news,codeigniter no input file specified,codeigniter notification,codeigniter nodejs,codeigniter number format,codeigniter num row,codeigniter news portal,codeigniter in php,replace in codeigniter,codeigniter order by,codeigniter online shop,codeigniter order by desc,codeigniter output,codeigniter orm,codeigniter or where,codeigniter only variable references should be returned by reference,codeigniter oracle,codeigniter oauth2,codeigniter or laravel,codeigniter o laravel,codeigniter o que é,codeigniter o symfony,usando o codeigniter,configurando o codeigniter,yii or codeigniter,o'reilly codeigniter,como usar o codeigniter,como instalar o codeigniter,como funciona o codeigniter,codeigniter pdf,codeigniter php,codeigniter php 7,codeigniter postgresql,codeigniter print pdf,codeigniter pagination example,codeigniter pdf library,codeigniter project,codeigniter post,codeigniter p,codeigniter qr code,codeigniter query string,codeigniter query like,codeigniter query count,codeigniter query limit,codeigniter query insert,codeigniter query builder join,codeigniter qr code example,codeigniter q&a,codeigniter redirect,codeigniter remove index.php,codeigniter result,codeigniter rest client,codeigniter route,codeigniter react,codeigniter rental mobil,codeigniter report generator,print_r codeigniter,codeigniter r n,r&os pdf codeigniter,codeigniter send email,codeigniter select,codeigniter select count,codeigniter sendgrid,codeigniter send email gmail,codeigniter session not working,codeigniter socket io,codeigniter sql server,codeigniter sql injection,codeigniter tutorial pdf,codeigniter transaction,codeigniter template bootstrap,codeigniter terbaru,codeigniter timezone,codeigniter truncate table,codeigniter template engine,codeigniter templating,codeigniter t,codeigniter t shirt,codeigniter t_const,codeigniter t point,codeigniter update,codeigniter user guide,codeigniter upload foto,codeigniter uri,codeigniter update database,codeigniter url,codeigniter unlink,codeigniter update data,codeigniter update batch,codeigniter validation,codeigniter vue,codeigniter vue js,codeigniter view,codeigniter vs,codeigniter vs laravel 2018,codeigniter versi terbaru,codeigniter visitor statistics,codeigniter vs yii,codeigniter v 2.1.4,codeigniter or cakephp,fuelphp vs codeigniter,codeigniter where,codeigniter where not,codeigniter where between,codeigniter websocket,codeigniter where or,codeigniter web service,codeigniter website,codeigniter where in array,codeigniter where not null,codeigniter xss_clean,codeigniter xml,codeigniter xss,codeigniter xampp,codeigniter xml parser,codeigniter xlsx,codeigniter x-www-form-urlencoded,codeigniter xmlrpc,codeigniter xlsx reader,codeigniter xdebug,codeigniter x-editable,codeigniter x-mailer,x-editable codeigniter example,x-api-key codeigniter,x-xss-protection codeigniter,codeigniter x laravel,codeigniter x-forwarded-for,codeigniter 2.x,codeigniter youtube,codeigniter you did not select a file to upload,codeigniter your system folder path does not appear to be set correctly,codeigniter you have specified an invalid database connection group,codeigniter your view folder path does not appear to be set correctly,codeigniter yield,codeigniter you don't have permission to access,codeigniter you have not selected a database type to connect to,codeigniter yt,codeigniter you don't have permission to access the requested object,codeigniter y bootstrap,ajax in codeigniter,codeigniter and angularjs,angular and codeigniter,codeigniter y postgresql,codeigniter y php,codeigniter y php 7,codeigniter y vue,codeigniter y oracle,codeigniter y firebase,codeigniter zip multiple files,codeigniter zip,codeigniter zip file download,codeigniter zend library,codeigniter zip add data,codeigniter zip archive,codeigniter zip folder,codeigniter zend barcode,codeigniter zip download,codeigniter zoho mail,codeigniter 000webhost,codeigniter 0day,codeigniter where 0,codeigniter undefined offset 0,codeigniter return $_config 0 =& $config,codeigniter duplicate entry '0' for key 'primary',codeigniter error reporting 0,dompdf 0.8.2 codeigniter,codeigniter cart price 0,codeigniter row(0),undefined offset 0 codeigniter,error reporting 0 codeigniter,error number 0 codeigniter,row(0) codeigniter,codeigniter 1.7.2,codeigniter 1.7.2 download,codeigniter 1.7.3,codeigniter 1.7,codeigniter 1.7 documentation,codeigniter 1.7.2 documentation,codeigniter 1 documentation,codeigniter 1.0,codeigniter 1.7.2 user guide,codeigniter 1.7.3 download,1 codeigniter redirect,codeigniter $1 route,http // 1 / codeigniter,limit 1 codeigniter,top 1 codeigniter,remove 1 codeigniter,missing argument 1 codeigniter,undefined offset 1 codeigniter,codeigniter 2.1.4,codeigniter 2.2.6,codeigniter 2018,codeigniter 2 database,codeigniter 2.2,codeigniter 2.1.3,codeigniter 2.2 stable,codeigniter 2 download,codeigniter 2 documentation,codeigniter 2,codeigniter 2 form validation,codeigniter 2 session,codeigniter 2 docs,codeigniter 2 to 3,codeigniter 3.1.9,codeigniter 3 tutorial,codeigniter 3 tutorial pdf,codeigniter 3.1.8,codeigniter 3 hmvc,codeigniter 3 multiple database,codeigniter 3 ebook,codeigniter 3.1.6,codeigniter 3 crud,codeigniter 3.1.7,codeigniter 3,codeigniter 3 htaccess,codeigniter 3 login,codeigniter 3 form validation,codeigniter 3 php 7,codeigniter 3 multiple file upload,codeigniter 404 page not found,codeigniter 4 tutorial,codeigniter 404,codeigniter 4 release date,codeigniter 404 hosting,codeigniter 4 download,codeigniter 403 forbidden,codeigniter 4 release,codeigniter 4 documentation,codeigniter 404 page not found localhost,codeigniter 4 vs laravel,codeigniter 4 features,codeigniter 4 hmvc,codeigniter 4 docs,codeigniter 500 internal server error,codeigniter 500,codeigniter 503 service unavailable,codeigniter 500 internal server error ubuntu,codeigniter 500 error loading model,codeigniter 502 bad gateway,codeigniter 500 error,codeigniter 500 error page,codeigniter 500 internal server error .htaccess,codeigniter 504 gateway timeout,codeigniter 5,angular 5 codeigniter,sximo 5 codeigniter,facebook sdk 5 codeigniter,undefined offset 5 codeigniter,codeigniter 5 star rating system,html5 codeigniter form,codeigniter 64 bit,6 codeigniter hacks,codeigniter centos 6,codeigniter phpmailer 6,base64 codeigniter,codeigniter mpdf 6,6 codeigniter hacks for the masters,codeigniter foundation 6,extjs 6 codeigniter,phpmailer 6 codeigniter,codeigniter 6,foundation 6 codeigniter,codeigniter php 7.1,codeigniter php 7.2,codeigniter centos 7,codeigniter php 7 session,codeigniter php 7.0,codeigniter php 7 mysql,codeigniter mpdf 7,codeigniter php 7.1 session,codeigniter php 7 error,php 7 codeigniter,mpdf 7 codeigniter,centos 7 codeigniter,php 7 codeigniter session,framework 7 codeigniter,centos 7 codeigniter remove index.php,nusoap php 7 codeigniter,codeigniter 7,mpdf 7 codeigniter 3,codeigniter 8192,codeigniter port 8080,codeigniter utf 8,codeigniter netbeans 8,codeigniter utf 8 encode,codeigniter netbeans 8.2,codeigniter netbeans 8 plugin,codeigniter netbeans 8.1 plugin,codeigniter iis 8,utf 8 codeigniter,netbeans 8 codeigniter,charset utf-8 codeigniter,codeigniter cloud 9,codeigniter debian 9,cloud 9 codeigniter,codeigniter,codeigniter adalah,codeigniter download,codeigniter upload,codeigniter 4,codeigniter form validation,codeigniter vs laravel,codeigniter session,codeigniter crud,codeigniter tutorial,codeigniter adminlte,codeigniter adminlte crud,codeigniter ajax,codeigniter api,codeigniter admin,codeigniter auth,codeigniter admin template,codeigniter atau laravel,codeigniter anchor,codeigniter a href,codeigniter a database error occurred,codeigniter a php error was encountered,codeigniter a session had already been started - ignoring session_start(),codeigniter a non-numeric value encountered,codeigniter a non well formed numeric value encountered,codeigniter a php error was encountered severity 8192,codeigniter a href helper,codeigniter a php error was encountered severity notice message undefined variable,codeigniter a php error was encountered core/common.php,codeigniter bootstrap,codeigniter blog,codeigniter between,codeigniter base_url,codeigniter bootstrap dashboard template,codeigniter between date,codeigniter builder,codeigniter belajar,codeigniter breadcrumb,codeigniter bootstrap 4,codeigniter cms,codeigniter captcha,codeigniter composer,codeigniter cart,codeigniter codepolitan,codeigniter controller,codeigniter curl,codeigniter count,codeigniter datatables,codeigniter database,codeigniter delete,codeigniter datatables server side,codeigniter dompdf,codeigniter download file,codeigniter dropdown from database,codeigniter distinct,codeigniter d,yesi d codeigniter,codeigniter email,codeigniter encrypt,codeigniter ebook,codeigniter export pdf,codeigniter export excel,codeigniter example,codeigniter ecommerce,codeigniter excel,codeigniter error 500,codeigniter edit data,codeigniter e-commerce,bootstrap ke codeigniter,codeigniter e-learning,ebook codeigniter,codeigniter e-library,e commerce codeigniter download,e commerce dengan codeigniter,e commerce using codeigniter,e-learning dengan codeigniter,codeigniter e commerce application,codeigniter form,codeigniter framework,codeigniter file upload,codeigniter firebase,codeigniter flashdata,codeigniter forum,codeigniter form select,codeigniter foreach,codeigniter fpdf,codeigniter get,codeigniter github,codeigniter group by,codeigniter get_where,codeigniter generator,codeigniter guide,codeigniter get row,codeigniter get url,codeigniter get current url,codeigniter get session,codeigniter hmvc,codeigniter htaccess,codeigniter helper,codeigniter hotel

pemrograman web mata kuliah,pemrograman web materi,pemrograman web menggunakan php,pemrograman web majumapan,pemrograman web menggunakan html,pemrograman web notepad++,bahasa pemrograman web.net,pemrograman web dengan vb.net,pemrograman web online shop,pemrograman web oop,pemrograman web online,kursus pemrograman web online,pemrograman web toko online,operator pemrograman web,pemrograman web ppt,pemrograman web perangkat bergerak,pemrograman web python,pemrograman web php pdf,pemrograman web pengertian,pemrograman web perpustakaan,pemrograman web penjualan,pemrograman web php mysql,quiz pemrograman web,pemrograman web rpl,pemrograman web dengan ruby,bahasa pemrograman web ruby,rpp pemrograman web,rpp pemrograman web dinamis kurikulum 2013,rpp pemrograman web dinamis kelas xi smk rekayasa perangkat lunak,rpp pemrograman web dan perangkat bergerak,rps pemrograman web,rpp pemrograman web doc,pemrograman web statis,pemrograman web seperti apakah yang harus dipelajari anak didik di zaman yang sudah serba online,pemrograman web sederhana,pemrograman web smk kelas x,pemrograman web smk ppt,pemrograman web semester 2,pemrograman web semester 2 pdf,pemrograman web server,pemrograman web service,pemrograman web terbaru,pemrograman web terbaik,pemrograman web tkj,pemrograman web table,pemrograman web teori,pemrograman web tabel,pemrograman web unpas,pemrograman web untuk pemula,pemrograman web ub,pemrograman web uii,pemrograman web 2 unindra,laporan pemrograman web ub,pemrograman web 1 unindra,materi pemrograman web untuk smk,pemrograman web dengan visual basic,pemrograman web dengan visual studio,pemrograman desktop vs web,video pemrograman web,pemrograman web wikipedia,pemrograman web kelas x semester 1,pemrograman web dengan xampp,pemrograman web kelas x smk,materi kelas x pemrograman web,pemrograman web x,pemrograman web yang ditentukan pada sisi client adalah,pemrograman web yang paling mendasar adalah,pemrograman web yang ditentukan pada sisi client,pemrograman web yang diproses pada komputer client adalah,bahasa pemrograman web yang paling banyak digunakan,bahasa pemrograman web yang paling mudah,contoh pemrograman web yang menggunakan php dan mysql,pemrograman web 1 pdf,pemrograman web 1 html,pemrograman web kelas 10,pemrograman web kelas 10 semester 2,pemrograman web kelas 11,pemrograman web semester 1,sap pemrograman web 1,makalah pemrograman web 1,silabus pemrograman web 1,pemrograman web 2 pdf,pemrograman web 2 dengan php,pemrograman web 2017,pemrograman web 2 kelas x,makalah pemrograman web 2,bahasa pemrograman web 2017,pemrograman web semester 2 kelas x,2 jenis pemrograman web,2 kategori pemrograman web,3 bahasa pemrograman web,pemrograman web 3,4 bahasa pemrograman web,5 bahasa pemrograman web,sebutkan 5 bahasa pemrograman web,pemrograman web dengan php 7,pemrograman web dengan php 7 betha sidik,9-c2-pemrograman web-x-1.pdf,pemrograman web,pemrograman web adalah,pemrograman web dinamis,pemrograman web pdf,pemrograman web kelas x,pemrograman web dinamis pdf,pemrograman web dan mobile,pemrograman web dasar,pemrograman web atau desktop,pemrograman web array,pemrograman web asp.net,pemrograman aplikasi web,pemrograman berbasis web adalah,bahasa pemrograman web adalah,pemrograman web dinamis adalah,pemrograman web di android,pemrograman web itu apa,pemrograman web berbasis framework,pemrograman web berbasis php,pemrograman web berbasis objek,pemrograman web berorientasi objek,pemrograman web berbasis jsp,pemrograman web berbasis oop,pemrograman web base,pemrograman web berbasis server,pemrograman web buku,pemrograman web css,pemrograman web ci,pemrograman web crud,pemrograman web client side,pemrograman web client,pemrograman web coding,teknik pemrograman web client,soal pemrograman web css,materi pemrograman web css,modul pemrograman web css,pemrograman web dengan php dan mysql,pemrograman web enterprise,pemrograman web ebook,pemrograman web enterprise adalah,soal pemrograman web essay,modul pemrograman web enterprise,ebook pemrograman web dinamis menggunakan php dan mysql,ebook pemrograman web dengan php dan mysql pdf,editor pemrograman web,ebook pemrograman web html,konsep pemrograman web dan enterprise,ebook pemrograman web,pemrograman web framework,pemrograman web formulir pendaftaran,pemrograman web frame,laporan pemrograman web filkom ub,pemrograman web membuat form,materi pemrograman framework web,fungsi pemrograman web,forum pemrograman web,pemrograman web gratis,pemrograman web gunadarma,pemrograman web gis,buku pemrograman web gratis,ebook pemrograman web gratis,belajar pemrograman web gratis,download buku pemrograman web gratis,soal uas pemrograman web gunadarma,gambar pemrograman web,pemrograman web html lengkap,pemrograman web html dengan notepad,pemrograman web html.pdf,pemrograman web html ppt,soal pemrograman web html,materi pemrograman web html,modul pemrograman web html,belajar pemrograman web html,tugas pemrograman web html,pemrograman web ii,pemrograman web teknik informatika,materi pemrograman web i,istilah pemrograman web,pemrograman web java,pemrograman web javascript,pemrograman web java pdf,pemrograman java web dengan netbeans,kursus pemrograman web jogja kabupaten sleman daerah istimewa yogyakarta,kursus pemrograman web jakarta,pemrograman web dengan javascript,kursus pemrograman web jogja kabupaten sleman daerah istimewa yogyakarta 55283,modul pemrograman web java,pemrograman web kelas xi,pemrograman web kelas 10 semester 1,pemrograman web kelas x semester 2,pemrograman web kelas x semester 2 pdf,pemrograman web k13,pemrograman web lanjut,pemrograman web lanjutan,pemrograman web lengkap pdf,pemrograman web laravel,pemrograman web login,pemrograman web lengkap,materi pemrograman web lanjut,modul pemrograman web lengkap

Code-writerTalk #6: SOLID PRINCIPAL dan Penerapan dalam PHP



Hi, there! Selamat berakhir pekan! Bagaimana akhir pekanmu? Akhir pekanku di rumah dan masih punya banyak deadline. Tapi, di tengah tumpukkan deadline itu, saya tiba-tiba ingin menulis sesuatu tentang menulis dan menambah edisi serial Code-writerTalk ini. Setelah beberapa bulan hiatus dari dunia blogging, akhirnya saya bisa menulis edisi terbaru untuk serial Code-writerTalk, yeay! Dan pada edisi kali ini saya akan menuliskan kembali hasil diskusi beberapa waktu lalu dengan kang Arie Deha tentang dasar-dasar SOLID Principal dan penerapan dalam PHP. Wah, apa itu SOLID Principal? Yuk, kita bahas!


Writing code is easy, writing GOOD code is hard!

Kenapa sih sampai perlu ada "metode" dalam cara menulis sebuah program?
Dulu, duluuu banget.. membuat program itu susah, ga gampang untuk membuat sebuah program. Apalagi kalau sudah masuk ke urusan logic, banyak bahkan teman-teman saya yang kuliah di bidang IT menyerah.

Tapi sekarang?

Banyak sekali bertebaran buku-buku ataupun ebooks soal pemrograman. Misalnya, buku "Belajar xxxx dalam n jam". Buku-buku seperti itu banyak dijual di mana-mana or bisa didonlot, kalau ketemu keywordnya di google.

Jadi, sekarang membuat program itu gampang. Semua orang dapat membuat program, tinggal baca buku sedikit, bisa langsung membuat program dan menjalankan programnya. Ada error, googling dan langsung ketemu jawabannya. Banyak pertanyaan-pertanyaan atau masalah-masalah yang kita hadapi yang sudah ditanyakan oleh orang lain, dan kita bisa lihat pemecahan masalahnya. Situs-situs seperti stackoverflow itu sangat membangtu dalam hal ini.

Sekarang paradigma sudah agak berubah, dengan adanya banyak source dimana-mana. "Menulis program itu mudah, tapi menulis program YANG BAIK itu susah....".

Seperti apa sih menulis program yang baik itu?
Berdasarkan berbagai sumber, kira-kira program yang baik itu:
1. Testable (program dapat ditest / melalui proses test, dan bisa melalui postive/negative test dengan baik),
2. Refactorable (mudah kalau ada kebutuhan untuk refactor / memperbaiki flow, menyelipkan fitur baru atau tambahan, dan lain-lain),
3. Easy to work with (Kalau ada masalah, dapat dengan mudah pin-point masalahnya di mana, kalau ingin menambahkan fitur kita ga ngerombak yang sudah ada),
4. Easy to maintain (mudah untuk proses maintain)

Sekarang kapan kita membutuhkan untuk dapat membuat program yang baik?
Pada saat program kita kecil, user yang pakai juga sedikit, developernya sedikit, bisa saja kita membuat program seenaknya, entar kalau ada apa-apa yaa tinggal tanya yang buat. Tapi pada saat program kita mulai berkembang, fitur-fitur baru mulai ditambahkan, user yang pakai semakin banyak, perlu efisiensi dalam mengorganisis program, developer semakin banyak, apakah kita bisa membuat program seenaknya lagi?

Disini S.O.L.I.D berperan untuk sebagai landasan dalam membuat program yang lebih baik. Kalau sebelumnya seenaknya dalam membuat program, sekarang sesuai dengan kebutuhan, kita harus mulai mendisiplinkan diri dalam membuat program.

Oiya, kalau kamu bertanya, kenapa PHP sebaiknya perlu menerapkan SOLID Principle ini? Soalnya, karena PHP itu mudah dipelajari, lebih gampang untuk kita "salah" dalam cara membuat program daripada "benar" nya. Sekali lagi, salah dan benar itu bukan hakiki yaa. Itu kebenaran dari cara pandang masing-masing individu.

Apa itu S.O.L.I.D ?

Well, S.O.L.I.D adalah singkatan. Tepatnya adalah singkatan dari beberapa principle yang membuat cara kita membuat program itu menjadi lebih baik, yaitu:

(S)ingle Responsibility Principle,
(O)pen Close Principle,
(L)iskov Substitution Principle,
(I)nterface Segregation Principle,
(D)ependency Inversion Principle

Nah, kita akan membahas satu per satu mengenai principles ini. Tidak terlalu mendalam, tapi sebagai pengetahuan saja.

(S)ingle Responsibility Principle

=====================
Apa sih maksudnya? Intinya, setiap objek harus punya dan hanya punya SATU tujuan aja.
Untuk programmer yang masih baru, kadang prinsip ini dilanggar dengan mudah. Di sebuah literatur online pernah menyebutkan, cara untuk mengetahui bahwa sebuah function atau method itu tidak efisien adalah dengan cara, Buka di IDE, lalu buat bagian pertama function atau method ada di baris pertama di layar, dan lihat. Apabila kita perlu "page down" untuk melihat bagian bawah atau penutup function atau method tadi, itu tandanya function sudah terlalu panjang. Pastinya bisa dibuat lebih simpel atau dipecah menjadi beberapa function yang lebih kecil. Ini belum tentu benar, tapi di satu sisi, ini make sense banget, soalnya banyak function yang sangat panjang ternya bisa dipecah sampai tinggal beberapa baris saja.

Apa sih gunanya kalau function atau method dipecah-pecah?
1. Test nya gampang
2. Kalau terjadi error, gampang nemunya
3. mau ada ganti proses gampang
4. mau ada fitur sama tapi beda (misalnya) engine, gampang juga update nya...

Selama parameter input dan result output nya sama...

Responsibility, di dalam deskripsinya Robert Martin, adalah "Alasan untuk berubah"... kalau kita melihat sebuah class dan kepikiran beberapa cara utk mengubahnya, ada kemungkinan class itu punya lebih dari 1 responsibility.

contoh:

 class User {  

public function getName() {}
public function getEmail() {}

public function find($id) {}

public function save() {}
}


Class User ini bisa memiliki 2 responsibility, yaitu mengurus soal bagaimana "user" ini menampilkan data, dan mengurus data berinteraksi dengan database.

Ini bisa dipecah menjadi:

 Ini bisa dipecah menjadi:   
class User {
public function getName() {}
public function getEmail() {}
}

class UserRepository {
public function find($id) {}
public function save() {}
}


Jadi untuk urusan ke db nya ada di UserRepository dan untuk ditampilkan sebagai result ada di class User.

kalau dipecah-pecah sesuai kebutuhannya, boleh jadi diakhir nanti kita punya banyak class untuk 1 entity user.

Lalu, kenapa sih lebih baik dipecah-dipecah? Kenapa harus single responsibility?
Karena semakin banyak responsibility dalam suatu object/class, maka akan membuat responsibility-responsibility tadi menjadi closed/tightly coupled. Akhirnya kalau ada update atau penambahan fitur or lainnya, maka akan semakin sulit dan dependency terhadap responsibility tersebut jadi semakin tinggi.

(O)pen/Close Principle

=================
Artinya, sebuah class harus terbuka (open) untuk di extends, tapi tertutup (close) untuk modifikasi.
Kalau diterjemahkan secara harafiah, developer yang akan edit dikemudian hari, harus tidak dapat mengubah system / class yang sudah ada / berjalan, tapi juga, dia harus dapat dengan mudah meng-extend class itu.

Keuntungannya dari Open Close ini adalah semakin sedikit kemungkinan modifikasi yang dilakukan terhadap source utama, sehingga kemungkinan terjadinya "Dulu parameternya A aja sudah jalan, sekarang harus A dan B" dan "Karena ada fitur X ditambahkan, jadi hasil nya berubah dari {"a":[1,2,3]} jadi {"ax":{"data":[1,2,3], "name":"abc"}} "

Kalau mau ubah, yaa extend dari yg awal, sehingga tidak break yang sebelumnya. Jadi class/fungsi yang dependency kesana, tidak break karena perubahan di source yg awalnya.

(L)iskov Substitution Principle

=====================
Liskov Substitution Principle (LSP, biar gampang), berkata, "Object yg memiliki interface yang sama, harus dapat di-"pertukar"-kan (interchangeable), tanpa mempengaruhi cara / behaviour sebuah program berjalan".

Maksudnya, interface di PHP membuat struktur sebuah class sehingga bisa di implementasi dengan mudah di class/program lain yang membutuhkan.

Simplenya kita pakai contoh saja:

 interface DatamineInterface {  
public function save($table, $data) {}
public function retrieve($params) {}
}

class DatabaseMine implements DatamineInterface {
public function save($table, $data) {
$this->db->table($field)->save($data);
}
public function retrieve($params) {
return $this->db->where($params)->get();
}
}

class MongoMine implements DatamineInterface {
public function save($table, $data) {
$this->mongodb->document($table)->save($data);
}
public function retrieve($params) {
return $this->mongodb->key($params)->get();
}
}

class MemcacheMine implements DatamineInterface {
public function save($table, $data) {
$this->memcache->set($table, $data);
}
public function retrieve($params) {
return $this->memcache->get($params);
}
}

class FileMine implements DatamineInterface {
public function save($table, $data) {
file_put_contents(md5($table), $data);
}
public function retrieve($params) {
return file_get_contents(md5(serialize($params));
}
}


=> catatan, ini cuma contoh yaa... saya ga sempet bikin dan cari source yang "paten".

Sorry kalau panjang, yang ada di otak langsung ditulis...
Implementasi nya bisa:

 class accessData {  
public function doSave(DatamineInterface $miner) {
$miner->save('blabla', ['abc'=>123]);
}
public function getData(DatamineInterface $miner) {
return $miner->retrieve('blabla', ['abc'=>123]);
}
}


bisa digunakan dengan:

 $dt = new accessData;  
$dt->doSave(new DatabaseMine);
$dt->doSave(new MemcacheMine);
$resultMemcache = $dt->getData(new MemcacheMine);
$resultMongo = $dt->getData(new MongoMine);


Sekarang, kenapa pakai LSP? Soalnya dengan menggunakan LSP, kita lebih mudah untuk melalukan refactoring code kita. Misalnya kita mau ganti data source, kita ga perlu kuatir dengan parameter atau dengan nama method yg berbeda yang bisa mengubah source code kita ....

(I)nterface Segregation Principle

========================
Interface itu akan men-dikte object yang kita buat, "harus punya method-method ini".
Tapi kadang kita maksain semua method yg kepikiran sama kita dimasukin semua ke interface, atau (kalau anda cukup males untuk membuat interface diawal) interface dibuat sesudah method-method di dalam class yg implemen interface nya ada.

Nahhh ISP (interface segregation principle) itu gunanya adalah utk "memecah" interface tadi menjadi beberapa interface lagi, jadi yang dibutuhkan saja yg akan kita pakai.

Misalnya:
(sekali lagi, ini code yg muncul dipikiran saya saat ini yaa.. code nya di tulis "as is" sama isi otak saya)

 interface ScopeInterface {  
public function readScope($key) {};
public function setScope($key, $val) {};
}

interface ClientInterface {
public function readClient($key) {};
public function setClient($key, $val) {};
}

interface TokenInterface {
public function readToken($key) {};
public function setToken($key) {};
}

interface OauthAccessInterface extends ScopeInterface, ClientInterface, TokenInterface {}


Code di atas pernah saya implementasi di access token library, tp sudah rada lama ga disentuh, moga-moga ga typo...

Jadi dari contoh di atas, kalau saya mau buat class Client, saya ga ush implement yang diluar dari entity Client, tapi klo di OauthAccess, saya akan ambil (implemen) dari semua entity-entity yang dibutuhkan utk membuat access token.


(D)ependency Inversion Principle

=========================
DIP menyatakan bahwa:
A. High Level Module, harus tidak boleh bergantung ke Low Level Module, kedua nya harus bergantung kepada Object Abstract
B. Object Abstract harus tidak bergantung pada Detail, tapi Detail harus bergantung pada Object Abstract
.....
rada susah dimengerti yaa....

misalnya:
(yang ini saya translate dari "source" saya yaa....)

 class GameManager {  

protected $input;

protected $video;

public function __construct() {

$this->input = new KeyboardInput();

$this->video = new ScreenOutput();

}

public function run() {

// accept user input from $this->input

// draw the game state on $this->video

}

}


Disini object GameManager bergantung sekali pada low level class yaitu: KeyboardInput dan ScreenOutput. Masalah timbul saat kita mau mengganti input, atau output. Untuk melepas "dependency" atau kebergantungan dari kedua low level class tadi, kita memakai principle yg ke 3 tadi: Liskov Substitution Principle, dimana kita akan pakai interface2 sebagai dependency nya:

 class GameManager {  
protected $input;
protected $video;
public function __construct(
InputInterface $input;
OutputInterface $output
) {
$this->input = $input;
$this->video = $output;
}
public function run() {
// accept user input from $this->input
// draw the game state on $this->video
}
}


Disini kita lihat bahwa di __construct() kita menambahkan 2 parameter, yang keduanya dependency terhadap 2 buah interface yaitu: InputInterface dan OutputInterface ....

Sekarang kita bisa define input dan output terserah dari mana, dimana class-class nya adalah implemen dari interface tadi:

 class KeyboardInput implements InputInterface {  
public function getInputEvent() { }
}
class JoystickInput implements InputInterface {
public function getInputEvent() { }
}
class MouseInput implements InputInterface {
public function getInputEvent() { }
}
class ScreenOutput implements OutputInterface {
public function render() { }
}
class TerminalOutput implements OutputInterface {
public function render() { }
}


sekarang kita bisa jalan program dengan:

 $keyboardgame = new GameManager(new KeyboardInput, new TerminalOutput);  
$onlinegame = new GameManager(new MouseInput, new ScreenOutput);
$simulatogame = new GameManager(new JoystickInput, new ScreenOutput);



***

Dengan menggunakan SOLID Principle, kita bisa dengan mudah untuk mengembangkan sebuah fitur dan meng-implementasi-kan kedalam program kita dengan minimalisir error yang mungkin terjadi. Awal dari sini adalah kita bisa mengembangkan design pattern dan blue print dari general program, apa yang akan kita buat, ketika ada request dadakan (yang sudah kerja pasti sering ngalamin), kita bisa dengan mudah mengerjakannya, tanpa kuatir akan ada error karena dependency ke hal lain. Untuk sementara sampai disini dulu "Teori" mengenai "SOLID", ini adalah dasarnya, nanti bisa dikembangkan sendiri, atau coba2. Semoga bermanfaat. Tetap semangat berkarya ya! :)

Code-writerTalk #6: SOLID PRINCIPAL dan Penerapan dalam PHP Rating: 4.5 Diposkan Oleh: Kabar Viral

Categories

Popular Posts