1 00:00:00,000 --> 00:00:02,000 [Powered by Google Translate] [PHP Sessions] 2 00:00:02,000 --> 00:00:04,000 [Tommy MacWilliam, Sveučilište Harvard] 3 00:00:04,000 --> 00:00:07,000 [To je CS50.] [CS50.TV] 4 00:00:07,000 --> 00:00:10,920 Sjednice u PHP-u može se koristiti za provedbu funkcionalnost, 5 00:00:10,920 --> 00:00:13,440 kao korisnički prijave, u vašem web app. 6 00:00:13,440 --> 00:00:16,920 PHP sjednice Vam omogućiti povezivanje informacija 7 00:00:16,920 --> 00:00:19,680 korisnikov cijele sesije 8 00:00:19,680 --> 00:00:22,290 nego jednostavno jednoj stranici. 9 00:00:22,290 --> 00:00:27,330 Dakle, to znači da kao korisnik posjećuje razne PHP stranica koje čine vaše web stranice, 10 00:00:27,330 --> 00:00:30,630 bilo kakva informacija na sjednici će ustrajati. 11 00:00:30,630 --> 00:00:34,770 Dakle, to znači da su podaci pohranjeni u sjednici jednoj stranici 12 00:00:34,770 --> 00:00:37,580 se kasnije mogu pristupiti drugoj stranici. 13 00:00:37,580 --> 00:00:40,080 Pohranjivanje podataka na sjednici je lako, 14 00:00:40,080 --> 00:00:48,790 i mi to učiniti putem znak za dolar, naglašavaju, grad SESSION varijable. 15 00:00:48,790 --> 00:00:52,620 Znak dolara, naglašavaju, SESSION-baš kao znak za dolar, naglašavaju, GET 16 00:00:52,620 --> 00:00:54,710 i znak dolara, naglašavaju, POST- 17 00:00:54,710 --> 00:00:58,690 je asocijativni niz koji se sastoji od ključnih parova vrijednosti. 18 00:00:58,690 --> 00:01:07,980 Tako možemo koristiti sintakse poput znak dolara, naglašavaju, sjednica, 19 00:01:07,980 --> 00:01:16,000 Nosač, citat, Foo, citiram, nosač, jednako, citiram, bar, citat- 20 00:01:16,000 --> 00:01:20,440 Za spremanje vrijednosti "bar" u ključnom "foo". 21 00:01:20,440 --> 00:01:24,030 Međutim, prije nego što možemo pisati ili čitati iz prijave niz, 22 00:01:24,030 --> 00:01:26,770 ćemo morati zvati posebnu funkciju- 23 00:01:26,770 --> 00:01:34,690 sjednici, naglašavaju, start, () - 24 00:01:34,690 --> 00:01:37,060 a to će započeti sjednicu. 25 00:01:37,060 --> 00:01:39,850 Tako ćemo pogledati primjer. 26 00:01:39,850 --> 00:01:46,570 Naša prva stranica, hello.php, koristi sjednicu na izlazu neke podatke za korisnika. 27 00:01:46,570 --> 00:01:53,920 Zapamtite, mi ćemo morati koristiti session_start prije nego što možete pristupiti s bilo podataka o prijavi. 28 00:01:53,920 --> 00:01:59,010 Sada smo pomoću PHP-a isset bi se utvrdilo je li ključ postoji 29 00:01:59,010 --> 00:02:03,230 u $ _SESSION asocijativni niz. 30 00:02:03,230 --> 00:02:07,250 Ako taj ključ postoji, to znači da korisnik prijavljen u, 31 00:02:07,250 --> 00:02:10,410 pa ćemo prikazati na ime. 32 00:02:10,410 --> 00:02:14,110 Ako se taj ključ nije postavljena, to znači da korisnik nije logiran još, 33 00:02:14,110 --> 00:02:17,880 pa ćemo prikazati link na login.php. 34 00:02:17,880 --> 00:02:21,380 Tako ćemo pogledati login.php. 35 00:02:21,380 --> 00:02:26,260 Ovdje dolje, imamo jednu HTML obrazac s jednim ulazom. 36 00:02:26,260 --> 00:02:32,720 Obliku akcija atribut $ _SERVER ['PHP_SELF'], 37 00:02:32,720 --> 00:02:37,440 a to jednostavno znači da želimo Obrazac se podnosi u trenutnu datoteku, 38 00:02:37,440 --> 00:02:41,040 koji, u ovom slučaju, je login.php. 39 00:02:41,040 --> 00:02:43,010 Tako ćemo se vratiti na vrh ove datoteke. 40 00:02:43,010 --> 00:02:50,100 Ako korisnik podnosi obrazac, onda $ _POST ['ime'] mora biti postavljena. 41 00:02:50,100 --> 00:02:53,750 Za više informacija o HTML forme i post, 42 00:02:53,750 --> 00:02:56,510 provjerite PHP Web Development video. 43 00:02:56,510 --> 00:02:59,330 U slučaju da korisnik učinio dostaviti obrazac, 44 00:02:59,330 --> 00:03:03,970 smo željeli napisati vrijednost koju su upisali u na sjednici. 45 00:03:03,970 --> 00:03:08,540 Sada možemo preusmjeriti korisnika na hello.php. 46 00:03:08,540 --> 00:03:11,800 Zato smo pohranjeni korisnikov ulaz na sjednici, 47 00:03:11,800 --> 00:03:18,240 hello.php će biti u mogućnosti pristupiti na vrijednost koja je bila postavljena u login.php. 48 00:03:18,240 --> 00:03:21,010 Tako ćemo provjeriti ovo u web pregledniku. 49 00:03:21,010 --> 00:03:27,520 Prvo, mi ćemo ploviti na http://localhost/hello.php. 50 00:03:27,520 --> 00:03:30,220 Možemo vidjeti da se ovdje nismo prijavljeni još, 51 00:03:30,220 --> 00:03:35,040 pa neka je kliknite na link za prijavu koji će nas preusmjeriti na login.php. 52 00:03:35,040 --> 00:03:41,760 U redu, ja ću upisati u moje ime, koje će potom biti pohranjeni na sjednici. 53 00:03:41,760 --> 00:03:48,950 Izvrsno! Sada možemo vidjeti moj ulaz iz login.php na hello.php preko sjednici. 54 00:03:48,950 --> 00:03:52,270 Dakle, što je s prijavom korisnika out? 55 00:03:52,270 --> 00:03:58,510 Pa, kako bi se prijavili korisnika u, mi jednostavno pohraniti vrijednost u ime prijave. 56 00:03:58,510 --> 00:04:03,040 Tako da se prijavite korisniku out, jednostavno trebamo ukloniti to ime tipku 57 00:04:03,040 --> 00:04:05,040 iz prijave niz. 58 00:04:05,040 --> 00:04:09,130 Tako ćemo pogledati na ovom posljednjem datoteku, logout.php. 59 00:04:09,130 --> 00:04:12,080 Još jednom, mi ćemo morati zvati session_start () 60 00:04:12,080 --> 00:04:15,260 Prije nego što možemo učiniti ništa u vezi sjednicu. 61 00:04:15,260 --> 00:04:19,240 Sada možemo jednostavno nazvati session_destroy (), 62 00:04:19,240 --> 00:04:22,460 koji će se pobrinuti za dobivanje osloboditi od svih podataka na sjednici 63 00:04:22,460 --> 00:04:26,790 a zatim preusmjeriti korisnik se vraća na hello.php. 64 00:04:26,790 --> 00:04:30,700 Dakle, ako ja kliknite na odjaviti link, 65 00:04:30,700 --> 00:04:34,690 možemo vidjeti da je server je zaboravila tko sam ja, 66 00:04:34,690 --> 00:04:36,970 i ja više ne prijavljeni 67 00:04:36,970 --> 00:04:39,910 Dakle, ono što se ovdje događa ispod haube? 68 00:04:39,910 --> 00:04:42,250 Kako bi dobili na ponašanje smo upravo vidjeli, 69 00:04:42,250 --> 00:04:44,760 naš server treba učiniti 2 stvari. 70 00:04:44,760 --> 00:04:48,980 Prvo, poslužitelj treba nekako pohraniti podatke u sesiji. 71 00:04:48,980 --> 00:04:51,910 Različite PHP datoteka koje čine web stranicu 72 00:04:51,910 --> 00:04:56,500 se izvode kao zasebne prizivanja PHP tumača 73 00:04:56,500 --> 00:05:00,550 pa lokalna varijabla ne može se dijeliti između njih. 74 00:05:00,550 --> 00:05:04,030 Umjesto toga, poslužitelj treba pohraniti svoje podatke session 75 00:05:04,030 --> 00:05:08,440 u nekom mjestu da više. php datoteke mogu pristupiti. 76 00:05:08,440 --> 00:05:13,940 Drugo, poslužitelj treba povezati podatke sjednici sa samo moje sesije. 77 00:05:13,940 --> 00:05:15,940 Kad sam se prijaviti na Facebook, 78 00:05:15,940 --> 00:05:20,460 vjerojatno postoje milijuni drugih ljudi i prijavljeni na Facebook-u isto vrijeme. 79 00:05:20,460 --> 00:05:24,200 No, poslužitelj treba neki način udruživanja moje podatke 80 00:05:24,200 --> 00:05:28,340 s moje trenutne sesije i podataka tuđe s druge sjednice. 81 00:05:28,340 --> 00:05:32,380 Srećom, autori PHP misli o svemu tome i za nas, 82 00:05:32,380 --> 00:05:35,170 tako da ne morate provesti bilo to i sami. 83 00:05:35,170 --> 00:05:39,540 Ali neka se pogled na ono što PHP radi po defaultu. 84 00:05:39,540 --> 00:05:44,070 Kad sam posjetiti PHP stranicu koja sadrži session_start po prvi put, 85 00:05:44,070 --> 00:05:47,930 PHP će generirati veliku slučajna vrijednost. 86 00:05:47,930 --> 00:05:53,970 Do session_destroy se zove ili ne idem na bilo PHP stranica na tom mjestu neko- 87 00:05:53,970 --> 00:05:59,050 da slučajna i vjerojatno jedinstvena vrijednost će biti povezan sa mnom. 88 00:05:59,050 --> 00:06:02,780 Na taj način poslužitelj ima neki način identificiranja moj pregledavanja sjednicu 89 00:06:02,780 --> 00:06:05,710 za razliku od tuđe. 90 00:06:05,710 --> 00:06:08,780 Možemo pogledati trenutne ID sesije 91 00:06:08,780 --> 00:06:12,380 korištenjem PHP funkcije, session_ID. 92 00:06:12,380 --> 00:06:17,250 Ovdje mi jednostavno si izlaza vrijednost našeg identifikator sjednice. 93 00:06:17,250 --> 00:06:20,580 Dakle, ako ćemo ponovno prijaviti na primjer web-aplikacije, 94 00:06:20,580 --> 00:06:25,530 i sada ploviti na sessid.php, 95 00:06:25,530 --> 00:06:27,850 vidjet ćemo ovaj dugi niz likova, 96 00:06:27,850 --> 00:06:31,180 i da je sadašnja identifikator za moju sjednici, 97 00:06:31,180 --> 00:06:35,410 a to je kako poslužitelj praćenje tko sam ja. 98 00:06:35,410 --> 00:06:37,670 Dobro, ali mi smo se samo riješiti pola problema. 99 00:06:37,670 --> 00:06:40,910 Naravno, poslužitelj sada ima neki način mi je identificiranje, 100 00:06:40,910 --> 00:06:46,060 ali kad sam posjetiti neku drugu stranicu, poslužitelj treba ponovno taj isti identifikator 101 00:06:46,060 --> 00:06:48,910 umjesto da stvaraju novu. 102 00:06:48,910 --> 00:06:52,760 Zapamtite, ako se proglasi lokalnu varijablu u foo.php 103 00:06:52,760 --> 00:06:55,190 a zatim posjetite bar.php, 104 00:06:55,190 --> 00:07:00,980 bar.php nema načina da znamo što se dogodilo u foo.php. 105 00:07:00,980 --> 00:07:07,450 Dakle provedba prijave zadani php zahtijeva da browser podsjetiti poslužitelj 106 00:07:07,450 --> 00:07:09,740 koji prijave ID za korištenje. 107 00:07:09,740 --> 00:07:12,710 To se provodi u obliku kolačića. 108 00:07:12,710 --> 00:07:15,370 Cookie-osim što je ukusna grickalica 109 00:07:15,370 --> 00:07:18,630 jednostavno je mala tekstualna datoteka na računalu 110 00:07:18,630 --> 00:07:21,780 da poslužitelj može pisati putem web pregledniku. 111 00:07:21,780 --> 00:07:27,300 Dakle, nakon što je PHP generira moj jedinstveni ID sesije putem session_start, 112 00:07:27,300 --> 00:07:34,210 to će reći web preglednik za pohranu taj identifikator u lokalnoj tekstualnu datoteku, ili kolačić. 113 00:07:34,210 --> 00:07:38,490 Zatim web preglednik će uključiti tog identifikatora u svakom zahtjevu 114 00:07:38,490 --> 00:07:40,780 da to čini na poslužitelj. 115 00:07:40,780 --> 00:07:44,280 Pa stvarno, web poslužitelj ne sjećajući se tko sam ja. 116 00:07:44,280 --> 00:07:48,780 Umjesto toga, web preglednik je jednostavno prisjećajući jedinstveni identifikator 117 00:07:48,780 --> 00:07:52,730 da se generira PHP i tada se stalno podsjećati na poslužitelj 118 00:07:52,730 --> 00:07:55,120 što je identifikator. 119 00:07:55,120 --> 00:08:00,760 Na taj način, informacije kao što su moje korisničko ime je pohranjena na poslužitelju ne moje web pregledniku. 120 00:08:00,760 --> 00:08:05,190 Browser jednostavno govori na poslužitelju, gdje PHP pohranjene tu informaciju 121 00:08:05,190 --> 00:08:07,750 tako da PHP može ga dohvatiti. 122 00:08:07,750 --> 00:08:12,150 Tako da moli na pitanje gdje se zapravo PHP čuvanje te informacije? 123 00:08:12,150 --> 00:08:14,910 Po defaultu, PHP će pohraniti svoje sjednice podatke 124 00:08:14,910 --> 00:08:19,540 u datoteci unutar / tmp ili mapu 'temp'. 125 00:08:19,540 --> 00:08:24,450 Naziv te datoteke će sadržavati ID sesije tako da PHP može odrediti 126 00:08:24,450 --> 00:08:28,620 koji file za čitanje i pisanje od samo putem ID sesije. 127 00:08:28,620 --> 00:08:32,280 U redu. Tako ćemo otvoriti karticu Network u debugger Chrome 128 00:08:32,280 --> 00:08:34,890 putem ikone francuskog ključa u gornjem desnom kutu. 129 00:08:34,890 --> 00:08:38,409 Sada ćemo krenuti ponovno hello.php. 130 00:08:38,409 --> 00:08:42,270 Idemo kliknite na HTTP zahtjev za hello.php 131 00:08:42,270 --> 00:08:44,680 , a zatim kliknite na zaglavlju. 132 00:08:44,680 --> 00:08:50,390 Ovdje možemo vidjeti da je header Cookie sadrži ključ zove PHPSESSID, 133 00:08:50,390 --> 00:08:55,980 ili PHP session ID-manje vrijednosti koji je taj isti dugi niz smo vidjeli 134 00:08:55,980 --> 00:08:59,290 kada smo posjetili sessid.php. 135 00:08:59,290 --> 00:09:04,660 To je točno kako je preglednik podsjećajući poslužitelj ono sjednici ID bi trebao biti korišten. 136 00:09:04,660 --> 00:09:08,180 To je to, uključujući u HTTP zaglavlju. 137 00:09:08,180 --> 00:09:10,500 U redu. Idemo natrag do terminala. 138 00:09:10,500 --> 00:09:16,450 Idemo ploviti na / tmp, gdje PHP je spremanje podataka sesije po defaultu. 139 00:09:16,450 --> 00:09:19,160 Naravno, unutar ove privremenu mapu, 140 00:09:19,160 --> 00:09:23,550 ovdje je datoteka koja sadrži isti točan ID sesije. 141 00:09:23,550 --> 00:09:28,990 Ako ćemo otvoriti ovu sliku, možemo vidjeti kako PHP zastupa svoju sjednicu na disku. 142 00:09:28,990 --> 00:09:32,870 Ovdje string "Tommy" se sprema za ključ 'naziv' 143 00:09:32,870 --> 00:09:35,750 što je točno ono što smo očekivali. 144 00:09:35,750 --> 00:09:38,850 I to je pregled sjednica u PHP-u. 145 00:09:38,850 --> 00:09:42,590 Ono što smo vidjeli bilo je samo zadani provedba sjednice. 146 00:09:42,590 --> 00:09:45,600 U stvari, mnoge web stranice promijeniti ovu zadanu ponašanje 147 00:09:45,600 --> 00:09:48,280 pohraniti PHP sjednice učinkovitije 148 00:09:48,280 --> 00:09:50,390 u interesu poboljšanja performansi. 149 00:09:50,390 --> 00:09:52,800 Moje ime je Tommy, a to je CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]