1 00:00:00,000 --> 00:00:02,000 [Powered by Google Translate] [PHP Sesiuni] 2 00:00:02,000 --> 00:00:04,000 [Tommy MacWilliam, Universitatea Harvard] 3 00:00:04,000 --> 00:00:07,000 [Acest lucru este CS50.] [CS50.TV] 4 00:00:07,000 --> 00:00:10,920 Sesiuni în PHP poate fi folosit pentru a pune în aplicare o funcționalitate, 5 00:00:10,920 --> 00:00:13,440 cum ar fi datele de conectare de utilizator, în aplicația web. 6 00:00:13,440 --> 00:00:16,920 Sesiuni PHP vă permite să se asocieze informații 7 00:00:16,920 --> 00:00:19,680 cu întreaga sesiune de navigare a utilizatorului 8 00:00:19,680 --> 00:00:22,290 mai degrabă decât pur și simplu o singură pagină. 9 00:00:22,290 --> 00:00:27,330 Deci asta înseamnă ca utilizatorul vizitează diferite pagini PHP, care alcătuiesc site-ul dvs., 10 00:00:27,330 --> 00:00:30,630 orice informații în sesiunea va persista. 11 00:00:30,630 --> 00:00:34,770 Deci asta înseamnă că datele stocate în sesiunea de către o singură pagină 12 00:00:34,770 --> 00:00:37,580 pot fi accesate ulterior de către o altă pagină. 13 00:00:37,580 --> 00:00:40,080 Stocarea de informații într-o sesiune este ușor, 14 00:00:40,080 --> 00:00:48,790 și vom face acest lucru prin semnul dolar, sublinia, variabile SESIUNEA de capital. 15 00:00:48,790 --> 00:00:52,620 Semn dolar, sublinia, SESIUNEA-la fel ca semn dolar, de subliniere, GET 16 00:00:52,620 --> 00:00:54,710 și semnul dolar, sublinia, POST- 17 00:00:54,710 --> 00:00:58,690 este un tablou asociativ format din perechi de valori-cheie. 18 00:00:58,690 --> 00:01:07,980 Astfel încât să putem folosi dolar semn-sintaxă ca, de subliniere, SESIUNEA, 19 00:01:07,980 --> 00:01:16,000 suport, oferta, foo, oferta, suport, este egal cu, oferta, bar, citat- 20 00:01:16,000 --> 00:01:20,440 pentru a stoca valoarea "bar", în cheie "foo". 21 00:01:20,440 --> 00:01:24,030 Cu toate acestea, înainte de a putea scrie sau citi din gama sesiune, 22 00:01:24,030 --> 00:01:26,770 vom avea nevoie pentru a apela o functie speciala 23 00:01:26,770 --> 00:01:34,690 sesiune, subliniere, începe, () - 24 00:01:34,690 --> 00:01:37,060 și aceasta va inițializa sesiunii. 25 00:01:37,060 --> 00:01:39,850 Deci, haideți să aruncăm o privire la un exemplu. 26 00:01:39,850 --> 00:01:46,570 Primul nostru pagină, hello.php, foloseste sesiunea de ieșire unele date de utilizator. 27 00:01:46,570 --> 00:01:53,920 Amintiți-vă, vom avea nevoie pentru a utiliza session_start înainte de a putea accesa orice date de sesiune. 28 00:01:53,920 --> 00:01:59,010 Acum suntem folosind isset PHP pentru a determina dacă există o cheie 29 00:01:59,010 --> 00:02:03,230 în $ _SESSION matrice asociativ. 30 00:02:03,230 --> 00:02:07,250 Dacă există cheia, ceea ce înseamnă că utilizatorul a conectat, 31 00:02:07,250 --> 00:02:10,410 așa că vom afișa numele utilizatorului. 32 00:02:10,410 --> 00:02:14,110 În cazul în care cheia nu este setat, înseamnă că utilizatorul nu a fost încă conectat, 33 00:02:14,110 --> 00:02:17,880 așa că vom afișa un link către login.php. 34 00:02:17,880 --> 00:02:21,380 Deci, haideți să aruncăm o privire la login.php. 35 00:02:21,380 --> 00:02:26,260 Pe aici, avem un singur formular HTML cu o singură intrare. 36 00:02:26,260 --> 00:02:32,720 Atribut acțiune a formularului este de $ _SERVER ['PHP_SELF "], 37 00:02:32,720 --> 00:02:37,440 și acest lucru înseamnă pur și simplu că dorim ca formularul să fie depus la dosar curent, 38 00:02:37,440 --> 00:02:41,040 care, în acest caz, este login.php. 39 00:02:41,040 --> 00:02:43,010 Așa că haideți să ne întoarcem la partea de sus a acestui fișier. 40 00:02:43,010 --> 00:02:50,100 În cazul în care utilizatorul a depus formularul, apoi $ _POST ['nume'] trebuie să fie setat. 41 00:02:50,100 --> 00:02:53,750 Pentru mai multe informații despre forme HTML și poștă, 42 00:02:53,750 --> 00:02:56,510 a verifica afară de PHP video de Dezvoltare Web. 43 00:02:56,510 --> 00:02:59,330 În cazul în care utilizatorul a făcut formularul, 44 00:02:59,330 --> 00:03:03,970 am dori să scrie valoarea pe care au scris în în sesiunea. 45 00:03:03,970 --> 00:03:08,540 Acum putem redirecționa utilizatorul la hello.php. 46 00:03:08,540 --> 00:03:11,800 Pentru că am stocate de intrare de utilizator în sesiune, 47 00:03:11,800 --> 00:03:18,240 hello.php vor putea accesa valoarea care a fost stabilit în login.php. 48 00:03:18,240 --> 00:03:21,010 Așa că haideți să verificați acest lucru într-un browser web. 49 00:03:21,010 --> 00:03:27,520 În primul rând, vom naviga la http://localhost/hello.php. 50 00:03:27,520 --> 00:03:30,220 Putem vedea aici că nu am încă conectat, 51 00:03:30,220 --> 00:03:35,040 deci haideți să faceți clic pe link-ul de conectare, care ne va redirecționa către login.php. 52 00:03:35,040 --> 00:03:41,760 Bine, o să tastați în numele meu, care va fi apoi stocate în sesiunea. 53 00:03:41,760 --> 00:03:48,950 Mare! Acum putem vedea meu de intrare de la login.php pe hello.php prin sesiunea. 54 00:03:48,950 --> 00:03:52,270 Deci, ce zici de logare utilizatorul afară? 55 00:03:52,270 --> 00:03:58,510 Ei bine, în scopul de a conecta în utilizator, pur și simplu ne-am păstrat o valoare în nume sesiune. 56 00:03:58,510 --> 00:04:03,040 Deci, pentru a conecta utilizatorul afară, pur și simplu trebuie să scoateți cheia nume 57 00:04:03,040 --> 00:04:05,040 din matrice sesiune. 58 00:04:05,040 --> 00:04:09,130 Deci, haideți să aruncăm o privire la acest ultim dosar, logout.php. 59 00:04:09,130 --> 00:04:12,080 Încă o dată, vom avea nevoie pentru a apela session_start () 60 00:04:12,080 --> 00:04:15,260 înainte de a putea face orice sesiune legate. 61 00:04:15,260 --> 00:04:19,240 Acum putem numi pur și simplu session_destroy (), 62 00:04:19,240 --> 00:04:22,460 care va avea grijă de a scăpa de toate datele din sesiune 63 00:04:22,460 --> 00:04:26,790 și apoi redirecționa utilizatorul înapoi la hello.php. 64 00:04:26,790 --> 00:04:30,700 Deci, dacă am faceți clic pe link-ul Log out, 65 00:04:30,700 --> 00:04:34,690 putem vedea că serverul a uitat cine sunt eu, 66 00:04:34,690 --> 00:04:36,970 și eu nu mai logat 67 00:04:36,970 --> 00:04:39,910 Deci, ce se întâmplă aici, sub capota? 68 00:04:39,910 --> 00:04:42,250 În scopul de a obține comportamentul tocmai am văzut, 69 00:04:42,250 --> 00:04:44,760 serverul nostru trebuie să facă două lucruri. 70 00:04:44,760 --> 00:04:48,980 În primul rând, serverul are nevoie pentru a stoca într-un fel de date in sesiunea. 71 00:04:48,980 --> 00:04:51,910 Diferitelor dosare PHP care cuprind un site web 72 00:04:51,910 --> 00:04:56,500 sunt executate ca invocări separate ale interpretului PHP 73 00:04:56,500 --> 00:05:00,550 variabile astfel încât local nu pot fi partajate între ele. 74 00:05:00,550 --> 00:05:04,030 In schimb, serverul trebuie să stocheze datele noastre de sesiune 75 00:05:04,030 --> 00:05:08,440 într-un loc care mai multe. php pot accesa. 76 00:05:08,440 --> 00:05:13,940 În al doilea rând, serverul trebuie să asocieze datele de sesiune cu doar sesiune mea de navigare. 77 00:05:13,940 --> 00:05:15,940 Când mă pot loga pe Facebook, 78 00:05:15,940 --> 00:05:20,460 există, probabil, milioane de alte persoane, de asemenea, conectat la Facebook, în același timp. 79 00:05:20,460 --> 00:05:24,200 Dar serverul are nevoie de o modalitate de a asocia datele mele 80 00:05:24,200 --> 00:05:28,340 cu sesiunea mea actuală și date altcuiva cu o altă sesiune. 81 00:05:28,340 --> 00:05:32,380 Din fericire, autorii PHP gândit la toate astea pentru noi, 82 00:05:32,380 --> 00:05:35,170 așa că nu trebuie să pună în aplicare toate astea noi. 83 00:05:35,170 --> 00:05:39,540 Dar haideți să aruncăm o privire la ceea ce face PHP în mod implicit. 84 00:05:39,540 --> 00:05:44,070 Când m-am vizita o pagină PHP conține session_start pentru prima dată, 85 00:05:44,070 --> 00:05:47,930 PHP va genera o mare valoare aleatorie. 86 00:05:47,930 --> 00:05:53,970 Până session_destroy se numește sau nu vizita toate paginile PHP de pe site-ul pentru o vreme, 87 00:05:53,970 --> 00:05:59,050 ca valoare aleatoare și, probabil, unic va fi asociat cu mine. 88 00:05:59,050 --> 00:06:02,780 În acest fel, serverul are un mod de identificare a sesiunii de navigare 89 00:06:02,780 --> 00:06:05,710 spre deosebire de altcuiva. 90 00:06:05,710 --> 00:06:08,780 Putem arunca o privire la ID-ul de curent sesiune 91 00:06:08,780 --> 00:06:12,380 folosind funcția PHP, session_id. 92 00:06:12,380 --> 00:06:17,250 Aici suntem pur și simplu scoate valoarea identificator nostru sesiune. 93 00:06:17,250 --> 00:06:20,580 Deci, dacă am logati din nou la exemplul aplicația web, 94 00:06:20,580 --> 00:06:25,530 și acum naviga la sessid.php, 95 00:06:25,530 --> 00:06:27,850 vom vedea acest lung șir de caractere, 96 00:06:27,850 --> 00:06:31,180 și că este identificatorul curent pentru sesiune mea, 97 00:06:31,180 --> 00:06:35,410 și că este modul în care serverul este urmărirea cine sunt. 98 00:06:35,410 --> 00:06:37,670 Bine, dar am rezolvat doar jumătate din problemă. 99 00:06:37,670 --> 00:06:40,910 Sigur, serverul are acum o modalitate de identificare mine, 100 00:06:40,910 --> 00:06:46,060 dar când am vizita o altă pagină, serverul are nevoie de a reutiliza același identificator 101 00:06:46,060 --> 00:06:48,910 mai degrabă decât generatoare de unul nou. 102 00:06:48,910 --> 00:06:52,760 Amintiți-vă, dacă am declara o variabilă locale în foo.php 103 00:06:52,760 --> 00:06:55,190 și apoi vizita bar.php, 104 00:06:55,190 --> 00:07:00,980 bar.php nu are nici o modalitate de a ști ceea ce sa întâmplat în foo.php. 105 00:07:00,980 --> 00:07:07,450 Astfel încât punerea în aplicare sesiune implicit php presupune că browser-ul reaminti server 106 00:07:07,450 --> 00:07:09,740 care sesiune ID-ul de a folosi. 107 00:07:09,740 --> 00:07:12,710 Acest lucru este implementat sub forma unui cookie. 108 00:07:12,710 --> 00:07:15,370 Un cookie-în afară de a fi un delicios snack- 109 00:07:15,370 --> 00:07:18,630 este pur și simplu un mic fișier text de pe computer 110 00:07:18,630 --> 00:07:21,780 că un server poate scrie la prin intermediul browser-ul web. 111 00:07:21,780 --> 00:07:27,300 Deci, după ce PHP genereaza ID-ul meu unic sesiune prin session_start, 112 00:07:27,300 --> 00:07:34,210 se va spune browser-ul web pentru a stoca că identificator într-un fișier text local, sau un cookie. 113 00:07:34,210 --> 00:07:38,490 Apoi, browser-ul web va include ca identificator în fiecare cerere 114 00:07:38,490 --> 00:07:40,780 că nu se face la server. 115 00:07:40,780 --> 00:07:44,280 Deci, într-adevăr, serverul web nu este aminte cine sunt. 116 00:07:44,280 --> 00:07:48,780 În schimb, browser-ul este pur și simplu amintindu-și identificatorul unic 117 00:07:48,780 --> 00:07:52,730 care a fost generat de PHP și apoi amintind în mod constant pe server 118 00:07:52,730 --> 00:07:55,120 ceea ce este că identificator. 119 00:07:55,120 --> 00:08:00,760 În acest fel, informații cum ar fi numele meu de utilizator este stocat pe serverul nu browser-ul meu. 120 00:08:00,760 --> 00:08:05,190 Browser-ul pur și simplu spune serverul pe care PHP stocate că informațiile 121 00:08:05,190 --> 00:08:07,750 astfel PHP poate recupera. 122 00:08:07,750 --> 00:08:12,150 Astfel că duce la intrebarea, unde este PHP stocarea de fapt aceste informații? 123 00:08:12,150 --> 00:08:14,910 În mod implicit, PHP va stoca datele dvs. de sesiune 124 00:08:14,910 --> 00:08:19,540 într-un fișier în interiorul / tmp, sau directorul "temp". 125 00:08:19,540 --> 00:08:24,450 Numele de fișier care va include ID-ul de sesiune, astfel PHP poate determina 126 00:08:24,450 --> 00:08:28,620 care fișier să citească și să scrie de prin doar ID-ul sesiunii. 127 00:08:28,620 --> 00:08:32,280 Bine. Deci, haideți să deschidem fila rețea în depanator Chrome 128 00:08:32,280 --> 00:08:34,890 prin pictograma cheie din dreapta sus. 129 00:08:34,890 --> 00:08:38,409 Acum, să mergem la hello.php din nou. 130 00:08:38,409 --> 00:08:42,270 Să faceți clic pe cererea HTTP a hello.php 131 00:08:42,270 --> 00:08:44,680 și apoi faceți clic pe Anteturi. 132 00:08:44,680 --> 00:08:50,390 Aici putem vedea că antetul cookie conține o cheie numit PHPSESSID, 133 00:08:50,390 --> 00:08:55,980 sau sesiune PHP-ID, cu o valoare care este același șir lung-am văzut 134 00:08:55,980 --> 00:08:59,290 atunci când am vizitat sessid.php. 135 00:08:59,290 --> 00:09:04,660 Acesta este exact modul în care browser-ul este amintindu-server ce ID de sesiune ar trebui să fie utilizat. 136 00:09:04,660 --> 00:09:08,180 Este ea, inclusiv într-un antet HTTP. 137 00:09:08,180 --> 00:09:10,500 Bine. Să ne întoarcem la terminal. 138 00:09:10,500 --> 00:09:16,450 Să navigați la / tmp, în cazul în care PHP este stocarea informațiilor sesiune în mod implicit. 139 00:09:16,450 --> 00:09:19,160 Destul de sigur, în interiorul acestui folder temporar, 140 00:09:19,160 --> 00:09:23,550 aici este un fișier care conține același ID exact sesiune. 141 00:09:23,550 --> 00:09:28,990 Dacă vom deschide acest fișier, putem vedea cum PHP reprezintă sesiune mea pe disc. 142 00:09:28,990 --> 00:09:32,870 Aici string "Tommy" sunt stocate pentru cheie "numele" 143 00:09:32,870 --> 00:09:35,750 care este exact ceea ce ne așteptam. 144 00:09:35,750 --> 00:09:38,850 Și asta este o imagine de ansamblu a sesiunilor în PHP. 145 00:09:38,850 --> 00:09:42,590 Ceea ce tocmai am văzut a fost doar punerea în aplicare implicit a sesiuni. 146 00:09:42,590 --> 00:09:45,600 De fapt, multe site-uri modifica acest comportament implicit 147 00:09:45,600 --> 00:09:48,280 pentru a stoca sesiuni PHP mai eficient 148 00:09:48,280 --> 00:09:50,390 în interesul de îmbunătățire a performanței. 149 00:09:50,390 --> 00:09:52,800 Numele meu este Tommy, iar acest lucru este CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]