1 00:00:00,000 --> 00:00:02,000 [Powered by Google Translate] [PHP Sesyen] 2 00:00:02,000 --> 00:00:04,000 [Tommy MacWilliam, Universiti Harvard] 3 00:00:04,000 --> 00:00:07,000 [Ini adalah CS50.] [CS50.TV] 4 00:00:07,000 --> 00:00:10,920 Sesyen dalam PHP boleh digunakan untuk melaksanakan fungsi, 5 00:00:10,920 --> 00:00:13,440 seperti login pengguna, dalam aplikasi web anda. 6 00:00:13,440 --> 00:00:16,920 Sesi PHP membolehkan anda untuk mengaitkan maklumat 7 00:00:16,920 --> 00:00:19,680 dengan seluruh sesi menyemak imbas pengguna 8 00:00:19,680 --> 00:00:22,290 bukan sekadar satu halaman. 9 00:00:22,290 --> 00:00:27,330 Ini bermakna sebagai pengguna melawat pelbagai halaman PHP yang membentuk laman web anda, 10 00:00:27,330 --> 00:00:30,630 apa-apa maklumat dalam sesi akan berterusan. 11 00:00:30,630 --> 00:00:34,770 Ini bermakna bahawa data yang disimpan dalam sesi dengan satu halaman 12 00:00:34,770 --> 00:00:37,580 kemudian boleh diakses oleh laman lain. 13 00:00:37,580 --> 00:00:40,080 Menyimpan maklumat dalam sesi yang mudah, 14 00:00:40,080 --> 00:00:48,790 dan kami berbuat demikian melalui tanda dolar, menekankan, SESI modal berubah-ubah. 15 00:00:48,790 --> 00:00:52,620 Tanda dolar, menekankan, SESI-seperti tanda dollar, menekankan, GET 16 00:00:52,620 --> 00:00:54,710 dan tanda dolar, menekankan, SELEPAS 17 00:00:54,710 --> 00:00:58,690 adalah pelbagai bersekutu yang terdiri daripada pasangan nilai utama. 18 00:00:58,690 --> 00:01:07,980 Oleh itu, kita boleh menggunakan sintaks seperti tanda dollar, menekankan, SESI, 19 00:01:07,980 --> 00:01:16,000 kurungan, quote, foo, quote, kurungan, sama, quote, bar, quote- 20 00:01:16,000 --> 00:01:20,440 untuk menyimpan "bar" nilai dalam kunci "Anu." 21 00:01:20,440 --> 00:01:24,030 Walau bagaimanapun, sebelum kita boleh menulis atau membaca dari pelbagai sesi, 22 00:01:24,030 --> 00:01:26,770 kita perlu memanggil fungsi-khas 23 00:01:26,770 --> 00:01:34,690 sesi, menekankan, bermula, () - 24 00:01:34,690 --> 00:01:37,060 dan ini akan memulakan sesi. 25 00:01:37,060 --> 00:01:39,850 Jadi mari kita lihat satu contoh. 26 00:01:39,850 --> 00:01:46,570 Halaman pertama kami, hello.php, menggunakan sesi kepada output beberapa data kepada pengguna. 27 00:01:46,570 --> 00:01:53,920 Ingat, kita akan perlu untuk menggunakan session_start sebelum kita boleh mengakses mana-mana data sesi. 28 00:01:53,920 --> 00:01:59,010 Sekarang kita menggunakan isset PHP untuk menentukan jika kunci wujud 29 00:01:59,010 --> 00:02:03,230 dalam $ _SESSION array bersekutu. 30 00:02:03,230 --> 00:02:07,250 Jika utama yang wujud, ini bermakna pengguna telah log masuk, 31 00:02:07,250 --> 00:02:10,410 jadi kita akan memaparkan nama pengguna. 32 00:02:10,410 --> 00:02:14,110 Jika utama yang tidak ditetapkan, ini bermakna pengguna tidak log masuk lagi, 33 00:02:14,110 --> 00:02:17,880 jadi kita akan memaparkan pautan ke login.php. 34 00:02:17,880 --> 00:02:21,380 Jadi mari kita lihat login.php. 35 00:02:21,380 --> 00:02:26,260 Turun di sini, kami mempunyai bentuk HTML tunggal dengan input tunggal. 36 00:02:26,260 --> 00:02:32,720 Bentuk atribut tindakan adalah $ _SERVER ['PHP_SELF'], 37 00:02:32,720 --> 00:02:37,440 dan ini bermakna bahawa kita mahu bentuk itu dikemukakan kepada fail semasa, 38 00:02:37,440 --> 00:02:41,040 yang, dalam kes ini, adalah login.php. 39 00:02:41,040 --> 00:02:43,010 Jadi mari kita kembali ke bahagian atas fail ini. 40 00:02:43,010 --> 00:02:50,100 Jika pengguna menghantar borang, kemudian $ _POST ['nama'] mesti ditetapkan. 41 00:02:50,100 --> 00:02:53,750 Untuk maklumat lanjut mengenai bentuk HTML dan pos, 42 00:02:53,750 --> 00:02:56,510 menyemak PHP video Pembangunan Web. 43 00:02:56,510 --> 00:02:59,330 Dalam kes yang pengguna lakukan mengemukakan borang, 44 00:02:59,330 --> 00:03:03,970 kita ingin menulis nilai yang mereka ditaip dalam ke dalam sesi. 45 00:03:03,970 --> 00:03:08,540 Sekarang kita boleh mengarahkan pengguna untuk hello.php. 46 00:03:08,540 --> 00:03:11,800 Kerana kita telah disimpan input pengguna ke dalam sesi, 47 00:03:11,800 --> 00:03:18,240 hello.php akan dapat untuk mengakses nilai yang telah ditetapkan dalam login.php. 48 00:03:18,240 --> 00:03:21,010 Jadi mari kita lihat ini dalam pelayar web. 49 00:03:21,010 --> 00:03:27,520 Pertama, kita akan pergi ke http://localhost/hello.php. 50 00:03:27,520 --> 00:03:30,220 Kita boleh lihat di sini bahawa kita tidak log masuk lagi, 51 00:03:30,220 --> 00:03:35,040 jadi mari kita klik link login, yang akan mengarahkan kita login.php. 52 00:03:35,040 --> 00:03:41,760 Okay, saya akan menaip nama saya, yang kemudiannya akan disimpan dalam sesi. 53 00:03:41,760 --> 00:03:48,950 Hebat! Sekarang kita boleh melihat input saya dari login.php pada hello.php melalui sesi. 54 00:03:48,950 --> 00:03:52,270 Jadi, bagaimana dengan log pengguna keluar? 55 00:03:52,270 --> 00:03:58,510 Nah, untuk log masuk pengguna, kita hanya disimpan nilai ke dalam nama sesi. 56 00:03:58,510 --> 00:04:03,040 Jadi untuk log masuk pengguna, kita hanya perlu untuk membuang bahawa kunci nama 57 00:04:03,040 --> 00:04:05,040 dari pelbagai sesi. 58 00:04:05,040 --> 00:04:09,130 Jadi mari kita lihat fail terakhir ini, logout.php. 59 00:04:09,130 --> 00:04:12,080 Sekali lagi, kita perlu untuk memanggil session_start () 60 00:04:12,080 --> 00:04:15,260 sebelum kita boleh melakukan apa sahaja yang berkaitan sesi. 61 00:04:15,260 --> 00:04:19,240 Sekarang kita hanya boleh memanggil session_destroy (), 62 00:04:19,240 --> 00:04:22,460 yang akan menjaga menghapuskan semua data dalam sesi 63 00:04:22,460 --> 00:04:26,790 dan kemudian mengarahkan pengguna kembali ke hello.php. 64 00:04:26,790 --> 00:04:30,700 Jadi jika saya klik pada pautan Log keluar, 65 00:04:30,700 --> 00:04:34,690 kita dapat melihat bahawa pelayan telah lupa siapa saya, 66 00:04:34,690 --> 00:04:36,970 dan saya tidak lagi log masuk 67 00:04:36,970 --> 00:04:39,910 Jadi apa yang berlaku di sini di bawah hood? 68 00:04:39,910 --> 00:04:42,250 Dalam usaha untuk mendapatkan tingkah laku yang kita hanya melihat, 69 00:04:42,250 --> 00:04:44,760 server kita perlu melakukan 2 perkara. 70 00:04:44,760 --> 00:04:48,980 Pertama, pelayan perlu entah bagaimana menyimpan data dalam sesi. 71 00:04:48,980 --> 00:04:51,910 Fail-fail PHP yang berbeza yang terdiri daripada laman web 72 00:04:51,910 --> 00:04:56,500 dilaksanakan sebagai doa berasingan jurubahasa PHP 73 00:04:56,500 --> 00:05:00,550 ubah jadi tempatan tidak boleh dikongsi di antara mereka. 74 00:05:00,550 --> 00:05:04,030 Sebaliknya, pelayan perlu untuk menyimpan data sesi kami 75 00:05:04,030 --> 00:05:08,440 di beberapa tempat yang berganda. fail php boleh akses. 76 00:05:08,440 --> 00:05:13,940 Kedua, pelayan perlu mengaitkan data sesi dengan hanya sesi semak imbas saya. 77 00:05:13,940 --> 00:05:15,940 Apabila saya masuk ke Facebook, 78 00:05:15,940 --> 00:05:20,460 mungkin ada berjuta-juta orang lain juga log masuk ke dalam Facebook pada masa yang sama. 79 00:05:20,460 --> 00:05:24,200 Tetapi pelayan memerlukan beberapa cara mengaitkan data saya 80 00:05:24,200 --> 00:05:28,340 dengan sesi semasa saya dan data orang lain dengan sesi yang lain. 81 00:05:28,340 --> 00:05:32,380 Nasib baik, pengarang PHP berfikir tentang semua ini bagi kami, 82 00:05:32,380 --> 00:05:35,170 jadi kami tidak perlu melaksanakan apa-apa ini diri kita sendiri. 83 00:05:35,170 --> 00:05:39,540 Tetapi mari kita lihat apa PHP tidak secara lalai. 84 00:05:39,540 --> 00:05:44,070 Apabila saya melawat laman yang mengandungi PHP session_start buat kali pertama, 85 00:05:44,070 --> 00:05:47,930 PHP akan menjana nilai rawak yang besar. 86 00:05:47,930 --> 00:05:53,970 Sehingga session_destroy dipanggil-atau saya tidak melawat mana-mana halaman PHP di laman web yang untuk sementara- 87 00:05:53,970 --> 00:05:59,050 bahawa nilai rawak dan mungkin unik akan dikaitkan dengan saya. 88 00:05:59,050 --> 00:06:02,780 Dengan cara itu pelayan mempunyai beberapa cara mengenalpasti sesi semak imbas saya 89 00:06:02,780 --> 00:06:05,710 berbanding dengan orang lain. 90 00:06:05,710 --> 00:06:08,780 Kita boleh lihat ID sesi terkini 91 00:06:08,780 --> 00:06:12,380 menggunakan fungsi PHP, session_ID. 92 00:06:12,380 --> 00:06:17,250 Di sini kita hanya akan keluarkan nilai pengecam sesi kami. 93 00:06:17,250 --> 00:06:20,580 Jadi, jika kita sekali lagi log masuk ke aplikasi web contoh, 94 00:06:20,580 --> 00:06:25,530 dan kini pergi ke sessid.php, 95 00:06:25,530 --> 00:06:27,850 kita akan melihat ini rentetan panjang aksara, 96 00:06:27,850 --> 00:06:31,180 dan itulah pengecam semasa sesi saya, 97 00:06:31,180 --> 00:06:35,410 dan bagaimana pelayan mengesan siapa saya. 98 00:06:35,410 --> 00:06:37,670 Baiklah, tetapi kami hanya diselesaikan separuh masalah tersebut. 99 00:06:37,670 --> 00:06:40,910 Pasti, pelayan itu kini mempunyai beberapa cara mengenal pasti saya, 100 00:06:40,910 --> 00:06:46,060 tetapi apabila saya melawat laman yang lain, pelayan perlu untuk menggunakan semula pengecam yang sama 101 00:06:46,060 --> 00:06:48,910 bukannya menjana yang baru. 102 00:06:48,910 --> 00:06:52,760 Ingat, jika saya mengisytiharkan pembolehubah tempatan dalam foo.php 103 00:06:52,760 --> 00:06:55,190 dan kemudian melawat bar.php, 104 00:06:55,190 --> 00:07:00,980 bar.php tidak mempunyai cara untuk mengetahui apa yang berlaku di foo.php. 105 00:07:00,980 --> 00:07:07,450 Jadi pelaksanaan sesi php lalai memerlukan pelayar mengingatkan pelayan 106 00:07:07,450 --> 00:07:09,740 yang sesi ID untuk digunakan. 107 00:07:09,740 --> 00:07:12,710 Ini dilaksanakan dalam bentuk cookie. 108 00:07:12,710 --> 00:07:15,370 A cookie di samping menjadi snek yang lazat 109 00:07:15,370 --> 00:07:18,630 hanya satu fail teks kecil pada komputer anda 110 00:07:18,630 --> 00:07:21,780 bahawa pelayan boleh menulis kepada melalui pelayar web. 111 00:07:21,780 --> 00:07:27,300 Jadi selepas PHP menjana ID sesi saya unik menerusi session_start, 112 00:07:27,300 --> 00:07:34,210 ia akan memberitahu pelayar web untuk menyimpan pengecam yang dalam fail teks tempatan, atau cookie. 113 00:07:34,210 --> 00:07:38,490 Kemudian pelayar web termasuk pengecam bahawa dalam setiap permintaan 114 00:07:38,490 --> 00:07:40,780 bahawa ia masuk ke pelayan. 115 00:07:40,780 --> 00:07:44,280 Jadi benar-benar, pelayan web itu tidak mengingati siapa saya. 116 00:07:44,280 --> 00:07:48,780 Sebaliknya, pelayar web adalah hanya mengingati pengecam unik 117 00:07:48,780 --> 00:07:52,730 yang telah dijana oleh PHP dan kemudian sentiasa mengingatkan pelayan 118 00:07:52,730 --> 00:07:55,120 apa pengecam yang. 119 00:07:55,120 --> 00:08:00,760 Dengan cara itu, maklumat seperti nama pengguna saya disimpan pada pelayan tidak pelayar web saya. 120 00:08:00,760 --> 00:08:05,190 Penyemak imbas hanya memberitahu pelayan di mana PHP disimpan maklumat yang 121 00:08:05,190 --> 00:08:07,750 jadi PHP boleh mengambil ia. 122 00:08:07,750 --> 00:08:12,150 Jadi yang menimbulkan soalan, di mana PHP sebenarnya menyimpan maklumat ini? 123 00:08:12,150 --> 00:08:14,910 Secara lalai, PHP akan menyimpan data sesi anda 124 00:08:14,910 --> 00:08:19,540 dalam fail dalam / tmp, atau 'temp' folder. 125 00:08:19,540 --> 00:08:24,450 Nama fail yang akan termasuk ID sesi supaya PHP boleh menentukan 126 00:08:24,450 --> 00:08:28,620 yang fail untuk membaca dan menulis dari melalui hanya ID sesi. 127 00:08:28,620 --> 00:08:32,280 Baiklah. Jadi mari kita membuka tekan Rangkaian dalam penyahpepijat Chrome 128 00:08:32,280 --> 00:08:34,890 melalui ikon sepana di sebelah kanan atas. 129 00:08:34,890 --> 00:08:38,409 Sekarang mari kita menuju ke hello.php lagi. 130 00:08:38,409 --> 00:08:42,270 Mari kita klik pada permintaan HTTP untuk hello.php 131 00:08:42,270 --> 00:08:44,680 dan kemudian klik pada Tajuk. 132 00:08:44,680 --> 00:08:50,390 Di sini kita dapat melihat bahawa header cookie mengandungi kunci yang dipanggil PHPSESSID, 133 00:08:50,390 --> 00:08:55,980 atau sesi PHP ID-dengan nilai itu adalah bahawa rentetan sama lama kita melihat 134 00:08:55,980 --> 00:08:59,290 apabila kita melawat sessid.php. 135 00:08:59,290 --> 00:09:04,660 Ini betul-betul bagaimana pelayar tidak mengingatkan pelayan apa ID sesi harus digunakan. 136 00:09:04,660 --> 00:09:08,180 Ia termasuk ia dalam header HTTP. 137 00:09:08,180 --> 00:09:10,500 Baiklah. Mari kita kembali ke terminal. 138 00:09:10,500 --> 00:09:16,450 Mari kita pergi ke / tmp, di mana PHP menyimpan maklumat sesi secara lalai. 139 00:09:16,450 --> 00:09:19,160 Apa yang pasti, di dalam folder sementara ini, 140 00:09:19,160 --> 00:09:23,550 di sini adalah fail yang mengandungi ID sesi tepat yang sama. 141 00:09:23,550 --> 00:09:28,990 Jika kita membuka fail ini, kita dapat melihat bagaimana PHP mewakili sesi saya pada cakera. 142 00:09:28,990 --> 00:09:32,870 Berikut rentetan "Tommy" disimpan untuk kekunci 'nama,' 143 00:09:32,870 --> 00:09:35,750 yang betul-betul apa yang kita telah menjangkakan. 144 00:09:35,750 --> 00:09:38,850 Dan itulah gambaran keseluruhan sesi dalam PHP. 145 00:09:38,850 --> 00:09:42,590 Apa yang kita hanya melihat hanya pelaksanaan lalai sesi. 146 00:09:42,590 --> 00:09:45,600 Malah, banyak laman web mengubah tingkah laku lalai ini 147 00:09:45,600 --> 00:09:48,280 untuk menyimpan sesi PHP dengan lebih cekap 148 00:09:48,280 --> 00:09:50,390 bagi kepentingan meningkatkan prestasi. 149 00:09:50,390 --> 00:09:52,800 Nama saya Tommy, dan ini adalah CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]