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, Harvard University] 3 00:00:04,000 --> 00:00:07,000 [To je CS50.] [CS50.TV] 4 00:00:07,000 --> 00:00:10,920 Zasedanja v PHP se lahko uporablja za izvajanje funkcij, 5 00:00:10,920 --> 00:00:13,440 kot uporabniške prijave, v vašo spletno aplikacijo. 6 00:00:13,440 --> 00:00:16,920 PHP sej vam omogočajo, da povežete informacije 7 00:00:16,920 --> 00:00:19,680 z uporabnikovim celotno sejo 8 00:00:19,680 --> 00:00:22,290 ne le kot eno stran. 9 00:00:22,290 --> 00:00:27,330 Torej to pomeni, da ko uporabnik obišče različne PHP strani, ki sestavljajo vaše spletne strani, 10 00:00:27,330 --> 00:00:30,630 kakršne koli informacije v seji bodo prisotni. 11 00:00:30,630 --> 00:00:34,770 To pomeni, da so podatki, shranjeni v seji z ene strani 12 00:00:34,770 --> 00:00:37,580 se lahko kasneje dostopate z drugo stranjo. 13 00:00:37,580 --> 00:00:40,080 Shranjevanje podatkov na seji je enostavno, 14 00:00:40,080 --> 00:00:48,790 in mi tako preko znak za dolar, podčrtaj, kapital SESSION spremenljivko. 15 00:00:48,790 --> 00:00:52,620 Znak za dolar, podčrtaj, SESSION, tako kot znak za dolar, podčrtaj, GET 16 00:00:52,620 --> 00:00:54,710 in znak za dolar, podčrtaj, POST- 17 00:00:54,710 --> 00:00:58,690 je asociativna niz je sestavljen iz parov vrednosti ključev. 18 00:00:58,690 --> 00:01:07,980 Tako da bomo lahko uporabite-skladenjsko kot znak za dolar, podčrtaj, sklepih, 19 00:01:07,980 --> 00:01:16,000 nosilec, citiram, foo, citiram, nosilec, je enaka, citiram, bar, quote- 20 00:01:16,000 --> 00:01:20,440 Shranjevanje vrednost "bar", v ključnem "foo". 21 00:01:20,440 --> 00:01:24,030 Vendar pa, preden bomo lahko pišejo ali berejo iz matrike seje, 22 00:01:24,030 --> 00:01:26,770 bomo morali poklicati posebno funkcijo- 23 00:01:26,770 --> 00:01:34,690 seji, podčrtaj, začeti () - 24 00:01:34,690 --> 00:01:37,060 in to bo inicializacijo sejo. 25 00:01:37,060 --> 00:01:39,850 Torej, dajmo si oglejte primer. 26 00:01:39,850 --> 00:01:46,570 Naša prva stran, hello.php, uporablja sejo za izhod nekaj podatkov k uporabniku. 27 00:01:46,570 --> 00:01:53,920 Ne pozabite, da bomo morali uporabiti session_start, preden bomo lahko dostop do vseh podatkov seje. 28 00:01:53,920 --> 00:01:59,010 Zdaj smo s pomočjo PHP Isset da ugotovi, ali obstaja ključ 29 00:01:59,010 --> 00:02:03,230 v $ _SESSION asociativni array. 30 00:02:03,230 --> 00:02:07,250 Če ta ključ obstaja, kar pomeni, da je uporabnik prijavljen, 31 00:02:07,250 --> 00:02:10,410 Tako bomo prikazali uporabniškega imena. 32 00:02:10,410 --> 00:02:14,110 Če se da ključ ni nastavljen, kar pomeni, da uporabnik še ni prijavljen 33 00:02:14,110 --> 00:02:17,880 Tako bomo prikazali povezavo do login.php. 34 00:02:17,880 --> 00:02:21,380 Tako da je lahko pogled na login.php. 35 00:02:21,380 --> 00:02:26,260 Dol, imamo eno samo obliko HTML z enim samim vhodom. 36 00:02:26,260 --> 00:02:32,720 Akcijski atribut obliki je $ _SERVER ['PHP_SELF'], 37 00:02:32,720 --> 00:02:37,440 in to preprosto pomeni, da želimo, da obrazec je treba predložiti v trenutni datoteki, 38 00:02:37,440 --> 00:02:41,040 , ki je v tem primeru, je login.php. 39 00:02:41,040 --> 00:02:43,010 Torej, pojdimo nazaj na vrh te datoteke. 40 00:02:43,010 --> 00:02:50,100 Če je uporabnik predložil obrazec, nato pa $ _POST ['name'] je treba določiti. 41 00:02:50,100 --> 00:02:53,750 Za več informacij o HTML obrazcev in delovno mesto, 42 00:02:53,750 --> 00:02:56,510 preverite PHP Web Development video. 43 00:02:56,510 --> 00:02:59,330 V primeru, da uporabnik ni predložil obrazec, 44 00:02:59,330 --> 00:03:03,970 Radi bi napisali vrednost, ki so ga vnesli v na seji. 45 00:03:03,970 --> 00:03:08,540 Sedaj lahko preusmerite uporabnika na hello.php. 46 00:03:08,540 --> 00:03:11,800 Ker smo shranjen vnos uporabnika v seji 47 00:03:11,800 --> 00:03:18,240 hello.php bodo mogli dostopati do vrednosti, ki je bila ustanovljena leta login.php. 48 00:03:18,240 --> 00:03:21,010 Tako da je ček to jasno v spletnem brskalniku. 49 00:03:21,010 --> 00:03:27,520 Najprej bomo krmarite do http://localhost/hello.php. 50 00:03:27,520 --> 00:03:30,220 Vidimo lahko, da tukaj še nismo prijavljeni, 51 00:03:30,220 --> 00:03:35,040 tako da je klik na povezavo za prijavo, ki nas bo preusmeril na login.php. 52 00:03:35,040 --> 00:03:41,760 Ok, bom vnesite svoje ime, ki bi se nato shranili v seji. 53 00:03:41,760 --> 00:03:48,950 Super! Zdaj lahko vidimo, moj vložek login.php na hello.php preko seje. 54 00:03:48,950 --> 00:03:52,270 Torej, kaj pa se prijavite uporabnik ven? 55 00:03:52,270 --> 00:03:58,510 No, da se prijavite uporabnika v, preprosto shranjena vrednost v imenu seje. 56 00:03:58,510 --> 00:04:03,040 Tako, da se prijavite uporabnik ven, smo preprosto morali odstraniti, da ime ključa 57 00:04:03,040 --> 00:04:05,040 Iz matrike seje. 58 00:04:05,040 --> 00:04:09,130 Tako da je lahko pogled na to zadnjo datoteko, logout.php. 59 00:04:09,130 --> 00:04:12,080 Še enkrat, bomo morali poklicati session_start () 60 00:04:12,080 --> 00:04:15,260 Pred moremo storiti ničesar sejo povezano. 61 00:04:15,260 --> 00:04:19,240 Sedaj lahko preprosto pokličete session_destroy () 62 00:04:19,240 --> 00:04:22,460 , ki bo poskrbel, da se znebi vseh podatkov v seji 63 00:04:22,460 --> 00:04:26,790 in nato preusmeriti uporabnika nazaj na hello.php. 64 00:04:26,790 --> 00:04:30,700 Torej, če kliknem na Odjava povezavo, 65 00:04:30,700 --> 00:04:34,690 lahko vidimo, da se je strežnik pozabil, kdo sem, 66 00:04:34,690 --> 00:04:36,970 in sem več prijavljeni 67 00:04:36,970 --> 00:04:39,910 Torej, kaj se dogaja pod pokrovom? 68 00:04:39,910 --> 00:04:42,250 Da bi dobili vedenje smo pravkar videli, 69 00:04:42,250 --> 00:04:44,760 naš strežnik mora narediti 2 stvari. 70 00:04:44,760 --> 00:04:48,980 Prvič, strežnik mora nekako shranjevanje podatkov v seji. 71 00:04:48,980 --> 00:04:51,910 Različne PHP datotek, ki sestavljajo spletno stran 72 00:04:51,910 --> 00:04:56,500 se izvajajo kot samostojne priklici PHP tolmača 73 00:04:56,500 --> 00:05:00,550 Tako lokalna spremenljivka ni mogoče deliti med njimi. 74 00:05:00,550 --> 00:05:04,030 Namesto tega strežnik potrebuje za shranjevanje naših podatkov seje 75 00:05:04,030 --> 00:05:08,440 v nekem kraju, da se lahko več. php datoteke dostop. 76 00:05:08,440 --> 00:05:13,940 Drugič, strežnik mora povezati podatke o seji s samo mojim brskanjem. 77 00:05:13,940 --> 00:05:15,940 Ko sem se prijavite na Facebook, 78 00:05:15,940 --> 00:05:20,460 verjetno obstaja milijone drugih ljudi zabeleženo tudi v Facebook istočasno. 79 00:05:20,460 --> 00:05:24,200 Ampak strežnik potrebuje nek način povezuje moje podatke 80 00:05:24,200 --> 00:05:28,340 z mojo trenutno sejo in podatkov nekdo drug z drugega zasedanja. 81 00:05:28,340 --> 00:05:32,380 Na srečo, so avtorji PHP razmišljal o vsem tem za nas, 82 00:05:32,380 --> 00:05:35,170 tako da nam ni treba izvajati vse to sami. 83 00:05:35,170 --> 00:05:39,540 Vendar pa si oglejte, kaj počne PHP privzeto. 84 00:05:39,540 --> 00:05:44,070 Ko sem obiskal stran, PHP, ki vsebuje session_start prvič, 85 00:05:44,070 --> 00:05:47,930 PHP bo ustvarila veliko naključno vrednost. 86 00:05:47,930 --> 00:05:53,970 Dokler se session_destroy ti ali jaz ne obišče PHP strani na tem mestu za nekaj časa, 87 00:05:53,970 --> 00:05:59,050 da naključno in verjetno edinstvena vrednost bo povezana z menoj. 88 00:05:59,050 --> 00:06:02,780 Na ta način ima strežnik na nek način identificirati svojo sejo brskanja 89 00:06:02,780 --> 00:06:05,710 za razliko od nekoga drugega. 90 00:06:05,710 --> 00:06:08,780 Mi lahko ogledate na trenutni ID seje 91 00:06:08,780 --> 00:06:12,380 s funkcijo PHP, session_ID. 92 00:06:12,380 --> 00:06:17,250 Tukaj smo preprosto prikazovanje vrednosti našega identifikatorja seje. 93 00:06:17,250 --> 00:06:20,580 Torej, če bomo ponovno prijaviti na primer spletno aplikacijo, 94 00:06:20,580 --> 00:06:25,530 in zdaj se pomaknite do sessid.php, 95 00:06:25,530 --> 00:06:27,850 bomo videli ta dolg niz znakov, 96 00:06:27,850 --> 00:06:31,180 in da je sedanja identifikator za mojo seji, 97 00:06:31,180 --> 00:06:35,410 in to je, kako se strežnik sledenja, kdo sem. 98 00:06:35,410 --> 00:06:37,670 Ok, ampak smo rešili le polovico problema. 99 00:06:37,670 --> 00:06:40,910 Seveda, strežnik je sedaj na nek način me je ugotavljanje, 100 00:06:40,910 --> 00:06:46,060 ampak ko sem obiskal eno stran, strežnik potrebuje za ponovno uporabo to isto oznako 101 00:06:46,060 --> 00:06:48,910 namesto ustvarjanja novega. 102 00:06:48,910 --> 00:06:52,760 Ne pozabite, če izjavljam lokalno spremenljivko foo.php 103 00:06:52,760 --> 00:06:55,190 in potem obiščite bar.php, 104 00:06:55,190 --> 00:07:00,980 bar.php nikakor ne more vedeti, kaj se je zgodilo v foo.php. 105 00:07:00,980 --> 00:07:07,450 Torej izvajanje seja privzeta php zahteva, da brskalnik opomni strežnik 106 00:07:07,450 --> 00:07:09,740 ki seje ID za uporabo. 107 00:07:09,740 --> 00:07:12,710 To se izvaja v obliki piškot. 108 00:07:12,710 --> 00:07:15,370 Piškotek, poleg tega, da delicious snack- 109 00:07:15,370 --> 00:07:18,630 je le majhna besedilna datoteka v računalniku 110 00:07:18,630 --> 00:07:21,780 da lahko strežnik pisati prek spletnega brskalnika. 111 00:07:21,780 --> 00:07:27,300 Torej, po PHP ustvari svoj edinstven ID seje preko session_start, 112 00:07:27,300 --> 00:07:34,210 to bo povedal, spletni brskalnik za shranjevanje, da identifikator v lokalni besedilno datoteko ali piškotek. 113 00:07:34,210 --> 00:07:38,490 Potem bo spletni brskalnik, da to identifikator v vsaki zahtevi 114 00:07:38,490 --> 00:07:40,780 , da naredi s strežnikom. 115 00:07:40,780 --> 00:07:44,280 Torej res, je spletni strežnik ne spominja, kdo sem. 116 00:07:44,280 --> 00:07:48,780 Namesto tega Spletni brskalnik je enostavno zapomniti enotni identifikator 117 00:07:48,780 --> 00:07:52,730 , ki je bila ustvarjena z PHP in nato ves čas opozarjali strežnik 118 00:07:52,730 --> 00:07:55,120 kaj je identifikator. 119 00:07:55,120 --> 00:08:00,760 Tako podatki kot moj uporabniško ime je shranjena na strežniku ni moj spletnega brskalnika. 120 00:08:00,760 --> 00:08:05,190 Brskalnik preprosto pove strežniku, kjer PHP shranjene te informacije 121 00:08:05,190 --> 00:08:07,750 tako da lahko PHP znova pridobiti. 122 00:08:07,750 --> 00:08:12,150 Tako da se postavlja vprašanje, kje je PHP dejansko shranjevanje teh informacij? 123 00:08:12,150 --> 00:08:14,910 Privzeto je, da se bo PHP shranite podatke o seji 124 00:08:14,910 --> 00:08:19,540 v datoteki znotraj dne / tmp ali mapo "temp". 125 00:08:19,540 --> 00:08:24,450 Ime te datoteke bodo vključevale ID seje, tako da lahko PHP ugotoviti 126 00:08:24,450 --> 00:08:28,620 katere datoteke brati in pisati samo prek ID seje. 127 00:08:28,620 --> 00:08:32,280 Vse je v redu. Torej, kaj je odprla jeziček omrežij v iskanje in odpravljanje napak Chrome 128 00:08:32,280 --> 00:08:34,890 preko ikone ključa v desnem zgornjem kotu. 129 00:08:34,890 --> 00:08:38,409 Zdaj pa pojdimo še enkrat hello.php. 130 00:08:38,409 --> 00:08:42,270 Oglejmo kliknite na zahtevo HTTP na hello.php 131 00:08:42,270 --> 00:08:44,680 in nato kliknite na glavah. 132 00:08:44,680 --> 00:08:50,390 Tukaj lahko vidimo, da glava piškotek vsebuje ključ, imenovano PHPSESSID, 133 00:08:50,390 --> 00:08:55,980 ali PHP ID seje, z vrednostjo, ki je ta isti dolg niz smo videli 134 00:08:55,980 --> 00:08:59,290 ko smo obiskali sessid.php. 135 00:08:59,290 --> 00:09:04,660 To je točno, kako se brskalnik spominja na strežnik, kar seje ID je treba uporabiti. 136 00:09:04,660 --> 00:09:08,180 To je tudi v glavi HTTP. 137 00:09:08,180 --> 00:09:10,500 Vse je v redu. Pojdimo nazaj na terminal. 138 00:09:10,500 --> 00:09:16,450 Oglejmo pluti v / tmp, kjer PHP je shranjevanje podatkov o seji, ki ga privzeto. 139 00:09:16,450 --> 00:09:19,160 Seveda dovolj, znotraj tega začasno mapo, 140 00:09:19,160 --> 00:09:23,550 tukaj je datoteka, ki vsebuje točno isto ID seje. 141 00:09:23,550 --> 00:09:28,990 Če bomo odprli to datoteko, lahko vidimo, kako je PHP, ki predstavlja mojo sejo na disku. 142 00:09:28,990 --> 00:09:32,870 Tu niz "Tommy" se shranijo za ključno "ime" 143 00:09:32,870 --> 00:09:35,750 kar je točno to, kar smo pričakovali. 144 00:09:35,750 --> 00:09:38,850 In to je pregled sej v PHP. 145 00:09:38,850 --> 00:09:42,590 Kar smo pravkar videli, je bil le privzeti izvajanje sej. 146 00:09:42,590 --> 00:09:45,600 Dejstvo je, mnoge spletne strani spremeniti to privzeto vedenje 147 00:09:45,600 --> 00:09:48,280 bolj učinkovito shranjevanje PHP sej 148 00:09:48,280 --> 00:09:50,390 V interesu izboljšanja uspešnosti. 149 00:09:50,390 --> 00:09:52,800 Moje ime je Tommy, in to je CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]