-->

Sabtu, 25 Agustus 2018

Tutorial Laravel 5.5 - Mengupload Image menggunakan CDN Gratis Cloudinary


Jika sebelumnya saya menjelaskan mengenai upload image menggunakan Amazon S3, pada artikel kali ini saya akan menjelaskan bagaimana cara mengupload image dengan menggunakan Cloudinary. Jika Amazon S3 adalah layanan premium maka kita bisa memanfaatkan Cloudinary ini sebagai alternatif nya karena layanan gratis yang disediakan oleh Cloudinary ini sudah cukup besar yaitu 10GB untuk storage.

Salah satu keunggulan menggunakan layanan Cloudinary ini adalah anda dapat menghemat space storage serta bandwidth dari hosting yang anda pakai. Anda dapat mengupload file seperti gambar dan video pada Cloudinary ini. Berikut ini adalah langkah-langkah yang harus anda lakukan :

#Membuat akun Cloudinary

Gunakan link berikut https://cloudinary.com/ dan lakukan registrasi. Isilah data-data yang diperlukan dan kemudian cek email anda untuk melakukan aktivasi akun. Setelah semua proses selesai anda akan melihat tampilan dashboard dari akun anda seperti gambar di bawah ini.

Dashboard Cloudinary
Pada tampilan dashboard tersebut ada 3 informasi yang perlu anda simpan karena nantinya akan digunakan pada program laravel yaitu, Cloud name, API Key, dan API Secret.


#Menginstall Package jrm2k6/cloudder

Langkah selanjutnya adalah menginstall package yang sudah disediakan untuk memanipulasi data pada Cloudinary yaitu jrm2k6/cloudder. Caranya adalah dengan menjalankan perintah composer di bawah ini pada direktori program laravel anda

composer require jrm2k6/cloudder

Setelah proses tersebut selesai silahkan tambahkan kode di bawah ini pada file config/app.php.

'providers' => array(
  'JD\Cloudder\CloudderServiceProvider'
);

'aliases' => array(
  'Cloudder' => 'JD\Cloudder\Facades\Cloudder'
);

Seperti biasanya tambahkan providers pada bagian providers dan aliases pada bagian aliases seperti anda menginstall package laravel lainnya.

Kemudian jalankan perintah artisan di bawah ini pada command prompt direktori program anda 

php artisan vendor:publish --provider="JD\Cloudder\CloudderServiceProvider"

Untuk lebih jelasnya dapat anda lihat pada gambar di bawah ini


Langkah terakhir yang perlu anda lakukan adalah menambahkan variabel pada file .env.

CLOUDINARY_API_KEY=xxxxx
CLOUDINARY_API_SECRET=yyyyy
CLOUDINARY_CLOUD_NAME=zzzzz

Isilah variabel-variabel tersebut dengan 3 informasi yang terdapat pada dashboard Cloudinary anda sebelumnya. 


#Contoh Penggunaan pada Laravel

Berikut ini adalah contoh bagaimana melakukan upload Image pada Cloudinary

    public function uploadCloudinary(Request $request){
        Cloudder::upload($request->file('fileToUpload'));
        // Cloudder::upload($request->file('fileToUpload'),null, ['folder' => 'Test/']);
        $c=Cloudder::getResult();
        dd($c);
    }

Perintah dasar yang digunakan untuk melakukan upload adalah 

        Cloudder::upload($request->file('fileToUpload'));

Untuk mendapatkan hasil upload digunakan perintah berikut

       Cloudder::getResult();

Disini saya menggunakan dd($c) untuk melihat nilai kembalian dari file yang saya upload. Berikut ini adalah hasil yang muncul


Pada gambar di atas dapat anda lihat terdapat informasi public_id, url, dan secure_url. Jika program anda menyimpan informasi gambar pada database maka data-data inilah yang menurut saya perlu anda simpan dalam database anda. 
  • public_id digunakan sebagai primary key dari image yang anda buat. Nantinya public_id yang akan digunakan jika anda ingin menghapus image tersebut atau mendapatkan informasi-informasi lainnya.
  • url digunakan sebagai url yang menampilkan image yang anda upload pada Cloudinary
  • secure_url sama dengan url hanya menggunakan https 
Pada contoh kode di atas terdapat kode yang saya comment //. Kode tersebut digunakan jika anda ingin melakukan upload image ke dalam folder tertentu pada Cloudinary. Silahkan ubah nilai pada bagian folder dan sesuaikan dengan nama folder yang anda buat.

Sedangkan jika anda ingin menghapus image pada Cloudinary gunakan perintah berikut

Cloudder::delete($publicId)

Dimana $publicId adalah public_id dari image yang ingin anda hapus. 

Perintah-perintah lengkapnya jika misalnya anda membutuhkan hal-hal lainyya dapat anda baca pada link berikut https://github.com/jrm2k6/cloudder. Pada link tersebut diberikan informasi lengkap kode-kode perintah apa saja yang dimiliki oleh package tersebut.


Demikianlah artikel Tutorial Laravel 5.5 - Mengupload Image menggunakan CDN Gratis Cloudinary. Semoga penjelasan di atas dapat dimengerti dan selamat mencoba.