Bagaimana cara mengatur halaman landscape dan Portrait jika dalam satu file?

Penanganan session adalah konsep utama dalam PHP yang memungkinkan informasi pengguna dapat dipertahankan di semua halaman dari website atau aplikasi. Di artikel ini, Anda akan mempelajari dasar-dasar dari penangan session di PHP.

Kita akan mulai dengan penjelasan mengenai bagaimana session bekerja dan hubungannya dengan cookies.  Lalu kita akan melihat beberapa potongan kode yang mendemonstrasikan bagaimana bekerja dengan session. Anda akan mempelajari bagaimana membuat dan menghapus session, serta bagaimana mengubah variabel session.

Apa itu Session di PHP?

Session adalah mekanisme untuk mempertahankan informasi di semua halaman web yang berbeda untuk mengidentifikasi pengguna saat mereka menelusuri situs atau aplikasi. Apakah Anda bertanya-tanya mengapa session dibutuhkan untuk sebuah website? Untuk melihat kenapa session dibutuhkan, kita harus kembali ke belakang dan melihat bagaimana protokol HTTP dirancang untuk bekerja.

Protokol HTTP merupakan protokol yang tidak memiliki state, artinya tidak mungkin server dapat mengingat pengguna tertentu di antara beberapa request. Contohnya, ketika Anda mengakses sebuah halaman web, server hanya bertanggung jawab untuk menyediakan konten dari halaman di-request tersebut. Jadi ketika Anda mengakses halaman lain dari website yang sama, server web menginterpretasi setiap dan semua request secara terpisah, seolah-olah mereka tidak berhubungan satu sama lain. Tidak ada kemungkinan bagi server untuk dapat mengetahui setiap request berasal dari pengguna yang sama.

Diagram berikut secara singkat menggambarkan protokol HTTP.

Bagaimana cara mengatur halaman landscape dan Portrait jika dalam satu file?
Bagaimana cara mengatur halaman landscape dan Portrait jika dalam satu file?
Bagaimana cara mengatur halaman landscape dan Portrait jika dalam satu file?

Di model ini, jika Anda ingin menampilkan spesifik informasi tentang pengguna, Anda harus mengotentikasi pengguna di setiap request. Bayangkan jika Anda harus mengetik username dan password Anda di setiap halaman yang menampilkan informasi profil Anda!

Session memungkinkan Anda untuk berbagi informasi ke semua halaman yang berbeda dalam satu situs atau aplikasi—sehingga dapat membantu menjaga state. Ini memungkinkan server mengetahui bahwa semua request berasal dari pengguna yang sama, sehingga situs bisa menampilkan informasi spesifik dari pengguna serta preferensi.

Alur Login dengan Session dan Cookies

Mari kita lihat alur login yang umum untuk sebuah website agar dapat mengerti apa yang terjadi di balik layar.

  1. Pengguna membuka halaman login dari sebuah website.
  2. Setelah memasukkan form login, server di sisi lain mengotentikasi request dengan memvalidasi kredensial yang dimasukkan.
  3. Jika kredensial yang dimasukkan oleh pengguna valid, server membuat sebuah session baru. Server menghasilkan nomor random yang unik, yang bernama session id. Dia juga menciptakan file baru di server yang digunakan untuk menyimpan informasi spesifik dari session.
  4. Selanjutnya, session id diberikan kembali ke pengguna, beserta resource yang di-request. Di balik layar, session id ini dikirim dalam bentuk cookie
    <?php
    
    13 di header response.
  5. Ketika browser menerima response dari server, dia menemukan cookie 
    <?php
    
    13 header. Jika cookie diizinkan oleh browser, maka dia akan menyimpan cookie 
    <?php
    
    13 tersebut, yang menyimpan session id yang diberikan oleh server.
  6. Untuk request selanjutnya, cookie
    <?php
    
    13 dikirim kembali ke server. Ketika server menemukan cookie
    <?php
    
    13, dia akan mencoba menginisialisasi session dengan session id tersebut. Hal tersebut dilakukan dengan memuat file session yang dibuat saat inisialisasi session. Lalu, dia akan menginisialisasi variabel array super-global
    <?php
    
    18 dengan data yang disimpan dalam file session.

Dengan cara ini, data pengguna dapat dipertahankan untuk semua request yang berbeda, dan pengguna dapat tetap login sepanjang session.

Diagram berikut menggambarkan bagaimana protokol HTTP bekerja dengan session.

Bagaimana cara mengatur halaman landscape dan Portrait jika dalam satu file?
Bagaimana cara mengatur halaman landscape dan Portrait jika dalam satu file?
Bagaimana cara mengatur halaman landscape dan Portrait jika dalam satu file?

Sekarang Anda sudah melihat pengantar singkat tentang bagaimana session bekerja, kita akan membuat beberapa contoh praktikal yang mendemonstrasikan bagaimana membuat dan memanipulasi variabel session.

Bagaimana Memulai Session

Di bagian ini, kita akan membahas bagaimana memulai session di PHP.

Kapanpun Anda ingin berurusan dengan variabel session, Anda perlu memastikan session sudah dimulai. Ada beberapa cara Anda dapat memulai session di PHP.

Menggunakan Fungsi <?php 19

Ini adalah metode yang akan sering Anda temui, dimana session dimulai dengan fungsi

<?php
19.

1
<?php
2
// start a session

3
session_start();
4
5
// manipulate session variables

6
<?php
0

Hal yang penting adalah fungsi 

<?php
19 harus dipanggil di awal script, sebelum output apapun dikirim ke browser. Jika tidak Anda akan menjumpai error yang terkenal 
<?php
22.

Memulai Session Secara Otomatis

Jika ada kebutuhan untuk menggunakan session di seluruh aplikasi Anda, Anda dapat memilih untuk memulai session secara otomatis tanpa menggunakan fungsi

<?php
19.

Ada sebuah konfigurasi di file php.ini yang dapat membuat Anda memulai session secara otomatis untuk semua request—

<?php
24. Secara default, itu diatur
<?php
25, dan Anda dapat mengaturnya menjadi
<?php
26 untuk mengaktifkan fungsi startup otomatis.

1
<?php
2

Di sisi lain, jika Anda tidak memiliki akses ke file php.ini, dan Anda menggunakan server web Apache, Anda juga dapat mengatur variabel ini di file .htaccess.

1
<?php
4

Jika Anda menambahkan baris di atas ke file .htaccess, maka itu akan memulai session secara otomatis di aplikasi PHP Anda.

Bagaimana Mendapatkan Session Id

Seperti yang kita bahas sebelumnya, server membuat nomor unik untuk setiap session baru. Jika Anda ingin mendapatkan session id, Anda dapat menggunakan fungsi 

<?php
27, seperti yang terlihat di potongan kode berikut.

1
<?php
2
session_start();
3
2
0
4
<?php
0

Itu akan memberikan session id saat ini. Fungsi 

<?php
27 ini menarik karena dia juga dapat menerima satu argumen—sebuah session id. Jika Anda ingin mengganti session id yang dihasilkan oleh sistem dengan milik Anda sendiri, Anda dapat memberikannya ke argumen pertama dari fungsi 
<?php
27.

1
<?php
2
2
6
3
session_start();
4
<?php
0

Perlu diperhatikan bahwa fungsi 

<?php
27 harus ditaruh sebelum
<?php
19 dipanggil ketika Anda ingin memulai session dengan sebuah kustom session id.

Bagaimana Membuat Variabel Session

Di bagian ini, kita akan mengeksplorasi tentang bagaimana menginisialisasi variabel session di PHP.

Seperti yang kita bahas sebelumnya, ketika session dimulai, array super-global

<?php
18 diinisialisasi dengan informasi yang sesuai. Secara default, dia diinisialisasi dengan array kosong, dan Anda dapat menyimpan informasi tambahan dengan menggunakan key-value pair.

Mari kita lihat contoh kode berikut yang mendemonstrasikan bagaimana menginisialisasi variabel session.

1
<?php
2
// start a session

3
session_start();
4
5
// start a session

9
6
3
1
3
2
3
3
3
4
3
5
3
6
3
7
3
8
3
9
session_start();
0
session_start();
1
<?php
0

Seperti yang dapat Anda lihat, kita memulai session di bagian awal script dengan menggunakan fungsi

<?php
19. Setelah itu, kita menginisialisasi dua variabel session. Terakhir, kita mengakses variabel tersebut dengan menggunakan
<?php
18 super-global.

Ketika Anda menyimpan data di session dengan menggunakan

<?php
18 super-global, itu nantinya akan disimpan di file session yang sesuai di server yang telah dibuat saat session dimulai. Dengan ini, data session akan dibagikan ke semua request.

Seperti yang telah kita bahas, informasi session dibagikan ke semua request, sehingga variabel session yang diinisialisasi di satu halaman dapat diakses dari halaman yang lainnya juga, sampai session-nya kadaluwarsa. Secara umum, session kadaluwarsa ketika browser ditutup.

Bagaimana Memodifikasi dan Menghapus Variabel Session

Anda dapat memodifikasi atau menghapus variabel session yang telah dibuat sebelumnya di aplikasi dengan cara yang sama seperti variabel PHP biasa.

Mari kita lihat bagaimana memodifikasi variabel session.

1
<?php
2
session_start();
3
4
session_start();
9
5
4
1
6
4
3
3
2
4
5
3
4
4
7
3
5
4
1
3
7
5
1
3
9
4
5
session_start();
1
5
5
5
6
5
7
<?php
0

Pada kode di atas, kita memeriksa jika variabel

<?php
36 sudah diatur sebelumnya. Jika belum diatur, kita akan mengaturnya menjadi
<?php
26, sebaliknya kita akan menambahkanya dengan
<?php
26. Jadi, jika Anda me-refresh halaman ini beberapa kali, Anda akan melihat bahwa counter ditambahkan dengan satu setiap saat!

Di samping itu, jika Anda ingin menghapus variabel session, Anda dapat menggunakan fungsi

<?php
39, seperti yang terlihat di potongan kode berikut.

1
<?php
2
// start a session

3
session_start();
4
5
// manipulate session variables

7
6
3
1
3
2
3
4
6
2
3
5
6
4
3
7
<?php
0

Demikian, Anda tidak bisa lagi mengakses variabel 

<?php
40 karena dia sudah dihapus dengan fungsi
<?php
39. Jadi itulah caranya untuk mengatur informasi session.

Bagaimana Menghapus Session

Di bagian ini, kita akan melihat bagaimana Anda bisa menghapus session. Di bagian sebelumnya, kita membahas fungsi

<?php
39, yang digunakan jika Anda ingin menghapus spesifik variabel session. Di samping itu, jika Anda ingin menghapus semua data yang berhubungan dengan session sekaligus, Anda dapat menggunakan fungsi 
<?php
43.

Mari kita coba untuk mengerti bagaimana itu bekerja dengan menggunakan contoh berikut.

1
<?php
2
// start a session

3
session_start();
4
5
<?php
05
6
3
2
<?php
08
3
4
<?php
10
3
5
<?php
0

Fungsi 

<?php
43 menghapus semua yang disimpan di session saat ini. Sehingga, kita akan melihat variabel
<?php
18 kosong di request selanjutnya karena data session yang disimpan di disk sudah dihapus oleh fungsi 
<?php
43.

Secara umum, Anda akan menggunakan fungsi session_destroy saat pengguna logout.

Kesimpulan

Di artikel ini, kita mengeksplorasi dasar-dasar dari penanganan session di PHP. Ini adalah konsep utama yang memungkinkan Anda untuk dapat mempertahankan informasi di seluruh halaman web.

Di setengah bagian pertama artikel, kita membahas konsep dasar dari session, dan kemudian kita membuat beberapa contoh PHP untuk mendemonstrasikan bagaimana Anda dapat membuat dan menghapus session serta memanipulasi variabel session.