menu

Website sederhana untuk pemula menggunakan PHP - migration database


Pada website ini saya sudah membagikan tutorial untuk php native, versi php yang saya gunakan pada tutorial itu adalah 5.6 dikarenakan saya akan melakukan migrasi ke php 7.0 maka saya akan mengakhiri tutorial untuk php native 5.6.

Tutorial kali ini merupakan tutorial terakhir dari project php yang sudah saya buat sebelumnya, tutorial kali ini untuk melengkapi tutorial sebelum-sebelumnya sehingga project php native (website sederhana untuk pemula menggunakan php) yang sudah saya buat sebelum-sebelumnya bisa tinggal anda clone dan langsung di jalankan,

Pada tutorial kali ini saya akan membuatkan function migration sehingga teman2 bisa langsung menjalankannya pada terminal untuk membuat database project ini secara otomatis

Oke langsung saja kita mulai tutorialnya,
Pertama, buat folder baru dengan nama database dan buat file baru dengan nama migration.php pada folder tersebut, isikan code berikut
<?php
  $host="localhost";
  $user="root";
  $pass="root";  

  $dbname = "blog_php_5_6";
  $tablename = "crud";

  $db=mysql_connect($host,$user,$pass);

  //create database if not exists
  $sql ="CREATE DATABASE IF NOT EXISTS `$dbname` DEFAULT CHARACTER SET latin1 COLLATE latin1_swedish_ci";
  $message = mysql_query($sql,$db);
  if ($message) {
    print_r("Create database success.\n");
  }

  $sql="USE `$dbname`";
  $message = mysql_query($sql,$db);
  if ($message) {
    print_r("Choose database success.\n");
  }

  //create table if not exists
  $sql = "CREATE TABLE IF NOT EXISTS `$tablename` (
            id bigint( 20 ) AUTO_INCREMENT PRIMARY KEY,
            name varchar( 50 ) NOT NULL,
            email varchar( 150 ) NOT NULL, 
            address text( 150 ) NULL,
            created_at timestamp NULL,
            updated_at timestamp NULL
          );";
  $message = mysql_query($sql,$db);
  if (!$message) { 
    print_r(mysql_error($db)."\n");
  } else {
    print_r("Create table success.\n");
  }

  //add primary key
  $sql = "ALTER TABLE `$tablename` ADD PRIMARY KEY (`id`)";
  mysql_query($sql,$db);

  //add auto increment
  $sql = "ALTER TABLE `$tablename` MODIFY `id` bigint(20) NOT NULL AUTO_INCREMENT";
  mysql_query($sql,$db);
?>

Kemudian edit file koneksi.php
<?php
  $host="localhost";
  $user="root";
  $pass="root";
  $dbname="blog_php_5_6";

  $db=mysql_connect($host,$user,$pass);
  mysql_select_db($dbname,$db);
?>

Edit pula file Delete.php dan Update.php pada folder model
Delete.php
<?php
    $user_id  = $_GET["user_id"];
 $_id   = $_POST["id"];
 $_delete  = $_POST["dell"];
 $_name   = $_POST["name"];
 $_email   = $_POST["email"];
 $_address = $_POST["address"];

 if ($_delete) {
  if ($_id) {
   $sql="DELETE FROM crud WHERE id = '$_id'";
      mysql_query($sql,$db);
  }
     header("Location: http://localhost/BLOG/blog-php_5_6");
  die();
 }

 $sql="SELECT * FROM crud WHERE id='$user_id'";
 $hsl=mysql_query($sql,$db);
 list($name,$email,$address,$created_at,$updated_at,$id)=mysql_fetch_array($hsl);
?>
Update.php
<?php
    $user_id  = $_GET["user_id"];
 $_id   = $_POST["id"];
 $_simpan  = $_POST["simpan"];
 $_name   = $_POST["name"];
 $_email   = $_POST["email"];
 $_address = $_POST["address"];

 if ($_simpan) {
  if ($_id) {
   $sql="UPDATE crud SET
   name = '$_name',
   email = '$_email',
   address = '$_address',
   updated_at = NOW()
         WHERE id = '$_id'";
      mysql_query($sql,$db);
  }
     header("Location: http://localhost/BLOG/blog-php_5_6");
  die();
 }

 $sql="SELECT * FROM crud WHERE id='$user_id'";
 $hsl=mysql_query($sql,$db);
 list($name,$email,$address,$created_at,$updated_at,$id)=mysql_fetch_array($hsl);
?>

Terakhir edit file read.php pada folder view/crud/ dan file header.php pada folder view/master
read.php
<!-- custom css -->
<link rel="stylesheet" href="styles/style.css">
<!--  -->
<!-- model -->
<?php include_once "model/Read.php" ?>
<!--  -->
<!-- content -->
<?php include_once "view/master/header.php" ?>
<div class="content">
  <div class="fill">
   <table border="1px";>
 <tr>
  <th>No</th>
  <th>Name</th>
  <th>Email</th>
  <th>Address</th>
  <th>Created At</th>
  <th>Updated At</th>
  <th>Action</th>
 </tr>
 <?php
  $sql="SELECT * FROM crud";
  $hsl=mysql_query($sql,$db);
  $no=0;
  while(list($id,$name,$email,$address,$created_at,$updated_at)=mysql_fetch_array($hsl)){
   $no++;
   ?>
     <tr>
      <td><?=$no?></td>
      <td><?=$name?></td>
      <td><?=$email?></td>
      <td><?=$address?></td>
      <td><?=$created_at?></td>
      <td><?=$updated_at?></td>
      <td>
       <a href="view/crud/update.php?user_id=<?=$id?>">Edit</a> ||
       <a href="view/crud/delete.php?user_id=<?=$id?>">Delete</a>
      </td>
     </tr>
      <?php
  }
 ?>
 </table>
 <br>
 <button class="button_def" onclick='window.location="view/crud/create.php"'>Create</button>
  </div>
</div>
<?php include_once "view/master/footer.php" ?>
header.php
<div class="main_image">
 <div class="header_content">
  <li><a href="http://localhost/BLOG/blog-php_5_6">Home</a></li>
 </div>
</div>

===DONE!===

How to - Install phalcon


Tidak terasa sudah lebih dari 2 minggu tidak menulis blog karena sibuk pindah kantor dan pindah rumah, akhirnya bisa kembali bereksperiment,

Kali ini codedoct akan memberikan tutorial cara instalasi phalcon pada ubuntu 16.04. Phalcon sendiri merupakan framework php yang menurut saya memiliki struktur directory yang sangat sederhana bila dibandingkan dengan framework lain.

Oke kita langsung saja mulai tutorialnya,
Pertama, pastikan ubuntu kalian sudah terinstall LAMP cara installnya bisa lihat disini,

Selanjutnya, silahkan ketikan perintah berikut satu-persatu pada terminal,
cd /var/www/html
mkdir phalcon
cd phalcon

sudo apt-get install -y php7.0-fpm \
     php7.0-cli \
     php7.0-curl \
     php7.0-gd \
     php7.0-intl \
 php7.0-pgsql \
 php7.0-mbstring \
 php7.0-xml \
 php7.0-bcmath \
 php-msgpack \
 curl \
 vim \
 wget \
 git

sudo apt-add-repository ppa:phalcon/stable
sudo apt-get update
sudo apt-get install php7.0-phalcon
sudo apt-get install -y gcc make re2c libpcre3-dev php7.0-dev build-essential php7.0-zip

sudo apt-get install gcc make autoconf libc-dev pkg-config
git clone --depth=1 git://github.com/phalcon/cphalcon.git
cd cphalcon/build
sudo PATH=/opt/sp/php7.0/bin:$PATH ./install

php -i | grep Loaded //untuk melihat path php7.0
sudo bash -c "echo extension=phalcon.so > /etc/php/7.0/cli/conf.d/phalcon.ini"
sudo service php7.0-fpm restart

Untuk mengetes apakah phalcon sudah terinstall dengan baik atau belum silahkan buat file phpinfo.php pada directory /var/www/html kemudian isikan code php berikut,
<?php phpinfo(); ?>

Setelah itu buka browser dan masukan url localhost/phpinfo.php maka saat kita cari phalcon akan muncul seperti ini,


Kemudian install phalcon devtools agar kita bisa menggunakan tools yang ada pada phalcon, cara instalasinya seperti ini,
cd /var/www/html/phalcon
git clone https://github.com/phalcon/phalcon-devtools.git
ln -s /var/www/html/phalcon/phalcon-devtools/phalcon.php /usr/local/bin/phalcon
chmod +x /usr/local/bin/phalcon

Terakhir test phalcon, ketikan printah berikut pada terminal,
cd
phalcon

Sehingga akan muncul seperti ini,


===DONE!===

How - Switch php version on ubuntu


Sudah sebulanan tidak update blog dikarenakan masih proses penyesuaian bekerja pada kantor baru, akhirnya bisa kembali ngeblog.

Kantor baru laptop-pun baru dan terpaksa harus setup ulang, pada kantor lama lebih sering pakek OS Windows sekarang dikantor baru full menggunakan ubuntu untuk kebutuhan coding hehe,.,.

Oke, minggu kemarin saya sudah clone semua project yang dibahas pada website ini dan menjalankanya pada laptop kantor yang baru dan semuanya lancar, kecuali pada tutorial membuat website sederhana menggunakan php.

Hal ini dikarenakan saat develop project tersebut saya menggunakan php5.6 sedangkan laptop baru saya menggunakan php7.0 untuk itu saya harus mengganti php7.0 saya dengan php5.6 ingat! mengganti dalam hal ini mendisable php7.0 dan mengenable php5.6 bukan menghapus dan menginstall yang baru.

Dikarenakan laptop baru saya hanya ada php7.0 maka saya harus install terlebih dahulu php5.6 tanpa harus menghapus php7.0 karena keduanya bisa diinstall secara bersamaan.

Untuk memastikan saja install kembali kedua versi php tersebut dengan cara seperti ini,
sudo add-apt-repository ppa:ondrej/php
sudo apt-get update
sudo apt-get install php7.0 php5.6 php5.6-mysql php-gettext php5.6-mbstring php-mbstring php7.0-mbstring php-xdebug libapache2-mod-php5.6 libapache2-mod-php7.0

Untuk menswitch-nya dengan cara seperti ini,
dari php7.0 ke php5.6
- apache
sudo a2dismod php7.0 ; sudo a2enmod php5.6 ; sudo service apache2 restart
- cli
sudo update-alternatives --set php /usr/bin/php5.6

dari php5.6 ke php7.0
- apache
sudo a2dismod php5.6 ; sudo a2enmod php7.0 ; sudo service apache2 restart
- cli
sudo update-alternatives --set php /usr/bin/php7.0

Pada saat mengaktifkan php7.0 kita juga harus mengaktifkan proxy_fcgi karena merupakan require pada php7.0 begitupun sebalikya saat php7.0 dinonaktifkan maka proxy_fcginya juga harus dinonaktifkan, caranya.
- nonaktifkan
sudo a2dismod proxy_fcgi proxy; sudo service apache2 restart
- aktifkan
sudo a2enmod proxy_fcgi proxy; sudo service apache2 restart

===DONE!===