1 00:00:00,000 --> 00:00:02,000 [Powered by Google Translate] [Sesiynau PHP] 2 00:00:02,000 --> 00:00:04,000 [Tommy MacWilliam, Prifysgol Harvard] 3 00:00:04,000 --> 00:00:07,000 [Mae hyn yn CS50.] [CS50.TV] 4 00:00:07,000 --> 00:00:10,920 Gall sesiynau yn PHP yn cael ei ddefnyddio i weithredu'r swyddogaeth, 5 00:00:10,920 --> 00:00:13,440 fel mewngofnodi defnyddwyr, yn eich app we. 6 00:00:13,440 --> 00:00:16,920 Sesiynau PHP yn caniatáu i chi i gysylltu gwybodaeth 7 00:00:16,920 --> 00:00:19,680 gyda sesiwn pori gyfan y defnyddiwr 8 00:00:19,680 --> 00:00:22,290 yn hytrach na dim ond un dudalen. 9 00:00:22,290 --> 00:00:27,330 Felly, mae hynny'n golygu fod y defnyddiwr yn ymweld dudalennau amrywiol PHP sy'n ffurfio eich gwefan, 10 00:00:27,330 --> 00:00:30,630 Bydd unrhyw wybodaeth yn y sesiwn yn parhau. 11 00:00:30,630 --> 00:00:34,770 Felly mae hynny'n golygu bod data yn y sesiwn gan un dudalen 12 00:00:34,770 --> 00:00:37,580 wedyn yn gallu cael mynediad dudalen arall. 13 00:00:37,580 --> 00:00:40,080 Storio gwybodaeth mewn sesiwn yn hawdd, 14 00:00:40,080 --> 00:00:48,790 ac yr ydym yn gwneud hynny trwy gyfrwng yr arwydd doler, tanlinellu, amrywiol SESIWN cyfalaf. 15 00:00:48,790 --> 00:00:52,620 Arwydd doler, tanlinellu, SESIWN-yn union fel arwydd doler, tanlinellu, GAEL 16 00:00:52,620 --> 00:00:54,710 ac arwydd doler, tanlinellu, POST- 17 00:00:54,710 --> 00:00:58,690 yn amrywiaeth cysylltiadol cynnwys parau gwerth allweddol. 18 00:00:58,690 --> 00:01:07,980 Felly, gallwn ddefnyddio cystrawen-fel arwydd doler, tanlinellu, SESIWN, 19 00:01:07,980 --> 00:01:16,000 braced, dyfynnwch, foo, dyfynnwch, braced, yn hafal i, dyfynnwch, bar, dyfynnwch- 20 00:01:16,000 --> 00:01:20,440 i storio gwerth "bar" yn yr allwedd "foo." 21 00:01:20,440 --> 00:01:24,030 Fodd bynnag, cyn y gallwn ysgrifennu neu ddarllen o'r amrywiaeth sesiwn, 22 00:01:24,030 --> 00:01:26,770 bydd angen i ni alw swyddogaeth-arbennig 23 00:01:26,770 --> 00:01:34,690 sesiwn, tanlinellu, yn dechrau, () - 24 00:01:34,690 --> 00:01:37,060 a bydd hyn yn ymgychwyn y sesiwn. 25 00:01:37,060 --> 00:01:39,850 Felly, gadewch i ni edrych ar enghraifft. 26 00:01:39,850 --> 00:01:46,570 Mae ein tudalen gyntaf, hello.php, yn defnyddio'r sesiwn i allbwn rhywfaint o ddata i'r defnyddiwr. 27 00:01:46,570 --> 00:01:53,920 Cofiwch, bydd angen i ni ddefnyddio session_start cyn y gallwn gael gafael ar unrhyw ddata sesiwn. 28 00:01:53,920 --> 00:01:59,010 Nawr rydym yn defnyddio ISSET PHP i benderfynu os allweddol yn bodoli 29 00:01:59,010 --> 00:02:03,230 yn y $ _SESSION amrywiaeth cysylltiadol. 30 00:02:03,230 --> 00:02:07,250 Os yw hynny'n allweddol yn bodoli, sy'n golygu bod y defnyddiwr wedi mewngofnodi i mewn, 31 00:02:07,250 --> 00:02:10,410 felly byddwn yn arddangos enw'r defnyddiwr. 32 00:02:10,410 --> 00:02:14,110 Os nad yw allwedd wedi ei osod, mae hynny'n golygu nad yw'r defnyddiwr wedi mewngofnodi eto, 33 00:02:14,110 --> 00:02:17,880 felly byddwn yn dangos dolen i login.php. 34 00:02:17,880 --> 00:02:21,380 Felly, gadewch i ni edrych ar login.php. 35 00:02:21,380 --> 00:02:26,260 I lawr yma, mae gennym ffurflen HTML sengl gyda mewnbwn sengl. 36 00:02:26,260 --> 00:02:32,720 Priodoledd gweithredu Mae'r ffurflen yw $ _SERVER ['PHP_SELF'], 37 00:02:32,720 --> 00:02:37,440 ac mae hyn yn syml yn golygu ein bod am i'r ffurflen gael ei gyflwyno i'r ffeil cyfredol, 38 00:02:37,440 --> 00:02:41,040 sydd, yn yr achos hwn, yn login.php. 39 00:02:41,040 --> 00:02:43,010 Felly, gadewch i ni fynd yn ôl i'r brig y ffeil. 40 00:02:43,010 --> 00:02:50,100 Os yw'r defnyddiwr gyflwyno'r ffurflen, yna $ _POST ['enw'] Rhaid gosod. 41 00:02:50,100 --> 00:02:53,750 I gael rhagor o wybodaeth am ffurflenni HTML ac ôl, 42 00:02:53,750 --> 00:02:56,510 edrychwch ar y fideo Datblygu'r We PHP. 43 00:02:56,510 --> 00:02:59,330 Yn yr achos bod y defnyddiwr oedd cyflwyno'r ffurflen, 44 00:02:59,330 --> 00:03:03,970 byddem yn hoffi ysgrifennu y gwerth y maent yn teipio i mewn i mewn i'r sesiwn. 45 00:03:03,970 --> 00:03:08,540 Nawr gallwn ailgyfeirio'r defnyddiwr i hello.php. 46 00:03:08,540 --> 00:03:11,800 Oherwydd ein bod wedi cael eu storio cyfraniad y defnyddiwr i mewn i'r sesiwn, 47 00:03:11,800 --> 00:03:18,240 Bydd hello.php yn gallu cael mynediad at y gwerth a sefydlwyd yn login.php. 48 00:03:18,240 --> 00:03:21,010 Felly, gadewch i ni edrych ar hyn mewn porwr gwe. 49 00:03:21,010 --> 00:03:27,520 Yn gyntaf, byddwn yn ewch i http://localhost/hello.php. 50 00:03:27,520 --> 00:03:30,220 Gallwn weld yma nad ydym wedi mewngofnodi eto, 51 00:03:30,220 --> 00:03:35,040 felly gadewch i ni cliciwch ar y ddolen mewngofnodi, a fydd yn ailgyfeirio i ni login.php. 52 00:03:35,040 --> 00:03:41,760 Iawn, 'n annhymerus' deipio yn fy enw i, a fydd wedyn yn cael ei storio yn y sesiwn. 53 00:03:41,760 --> 00:03:48,950 Great! Nawr gallwn weld fy mewnbwn gan login.php ar hello.php drwy'r sesiwn. 54 00:03:48,950 --> 00:03:52,270 Felly, beth am logio y defnyddiwr allan? 55 00:03:52,270 --> 00:03:58,510 Wel, er mwyn mewngofnodi i'r defnyddiwr mewn, rydym yn syml storio gwerth i enw sesiwn. 56 00:03:58,510 --> 00:04:03,040 Felly, er mwyn logio y defnyddiwr allan, syml, mae angen i ni gael gwared ar yr enw hwnnw allweddol 57 00:04:03,040 --> 00:04:05,040 o'r amrywiaeth sesiwn. 58 00:04:05,040 --> 00:04:09,130 Felly, gadewch i ni edrych ar y ffeil ddiwethaf, logout.php. 59 00:04:09,130 --> 00:04:12,080 Unwaith eto, bydd angen i ni alw session_start () 60 00:04:12,080 --> 00:04:15,260 cyn y gallwn wneud unrhyw beth sy'n ymwneud sesiwn. 61 00:04:15,260 --> 00:04:19,240 Nawr gallwn ffoniwch session_destroy (), 62 00:04:19,240 --> 00:04:22,460 a fydd yn cymryd gofal o gael gwared ar yr holl y data yn y sesiwn 63 00:04:22,460 --> 00:04:26,790 ac yna ailgyfeirio'r defnyddiwr yn ôl i'r hello.php. 64 00:04:26,790 --> 00:04:30,700 Felly os wyf yn cliciwch ar y ddolen Log allan, 65 00:04:30,700 --> 00:04:34,690 gallwn weld bod y gweinydd wedi anghofio pwy ydw i, 66 00:04:34,690 --> 00:04:36,970 ac yr wyf bellach yn mewngofnodi 67 00:04:36,970 --> 00:04:39,910 Felly, beth sy'n digwydd yma o dan y cwfl? 68 00:04:39,910 --> 00:04:42,250 Er mwyn cael yr ymddygiad yr ydym yn jyst yn gweld, 69 00:04:42,250 --> 00:04:44,760 Mae angen ein gweinydd i wneud 2 beth. 70 00:04:44,760 --> 00:04:48,980 Yn gyntaf, mae angen i'r gweinydd i storio data yn y sesiwn rhywsut. 71 00:04:48,980 --> 00:04:51,910 Y gwahanol ffeiliau PHP sy'n cynnwys gwefan 72 00:04:51,910 --> 00:04:56,500 yn cael eu gweithredu fel invocations ar wahân o'r cyfieithydd PHP 73 00:04:56,500 --> 00:05:00,550 Ni all newidyn mor lleol yn cael ei rannu rhyngddynt. 74 00:05:00,550 --> 00:05:04,030 Yn lle hynny, mae angen i'r gweinydd i storio ein data sesiwn 75 00:05:04,030 --> 00:05:08,440 mewn rhai lle y gellir lluosog. php ffeiliau gael mynediad. 76 00:05:08,440 --> 00:05:13,940 Yn ail, mae angen i'r gweinydd i gysylltu data sesiwn gyda dim ond fy sesiwn pori. 77 00:05:13,940 --> 00:05:15,940 Pan fyddaf yn mewngofnodi i Facebook, 78 00:05:15,940 --> 00:05:20,460 mae'n debyg fod yna filiynau o bobl eraill sydd wedi mewngofnodi hefyd i Facebook ar yr un pryd. 79 00:05:20,460 --> 00:05:24,200 Ond mae angen gweinydd rhyw ffordd o gysylltu fy data 80 00:05:24,200 --> 00:05:28,340 gyda fy sesiwn cyfredol a data rhywun arall gyda sesiwn arall. 81 00:05:28,340 --> 00:05:32,380 Yn ffodus, mae'r awduron o PHP yn meddwl am hyn oll i ni, 82 00:05:32,380 --> 00:05:35,170 felly nid oes angen i ni weithredu unrhyw un o'r hyn ein hunain. 83 00:05:35,170 --> 00:05:39,540 Ond gadewch i ni edrych ar yr hyn PHP yn ei wneud yn ddiofyn. 84 00:05:39,540 --> 00:05:44,070 Pan fyddaf yn ymweld â dudalen PHP yn cynnwys session_start am y tro cyntaf, 85 00:05:44,070 --> 00:05:47,930 Bydd PHP gynhyrchu gwerth ar hap mawr. 86 00:05:47,930 --> 00:05:53,970 Hyd nes y galw i neu session_destroy yn Nid wyf yn ymweld ag unrhyw dudalennau PHP ar y safle hwnnw am gyfnod- 87 00:05:53,970 --> 00:05:59,050 Bydd gwerth ar hap ac mae'n debyg unigryw fod yn gysylltiedig gyda mi. 88 00:05:59,050 --> 00:06:02,780 Fel hyn mae'r gweinydd yn cael rhyw ffordd o adnabod fy sesiwn pori 89 00:06:02,780 --> 00:06:05,710 yn hytrach na rhywun arall. 90 00:06:05,710 --> 00:06:08,780 Gallwn gymryd edrych ar y ID sesiwn cyfredol 91 00:06:08,780 --> 00:06:12,380 ddefnyddio'r swyddogaeth PHP, session_id. 92 00:06:12,380 --> 00:06:17,250 Yma rydym yn syml outputting gwerth ein dynodwr sesiwn. 93 00:06:17,250 --> 00:06:20,580 Felly, os ydym eto mewngofnodi at yr enghraifft ar y we app, 94 00:06:20,580 --> 00:06:25,530 ac yn awr llywio i sessid.php, 95 00:06:25,530 --> 00:06:27,850 byddwn yn gweld y llinyn hir o gymeriadau, 96 00:06:27,850 --> 00:06:31,180 a dyna'r dynodwr presennol ar gyfer fy sesiwn, 97 00:06:31,180 --> 00:06:35,410 a dyna sut y gweinydd yn cadw cofnod o bwy ydw i. 98 00:06:35,410 --> 00:06:37,670 Iawn, ond dim ond wedi datrys hanner y broblem. 99 00:06:37,670 --> 00:06:40,910 Cadarn, mae gan y gweinydd rhyw ffordd o adnabod i mi, 100 00:06:40,910 --> 00:06:46,060 ond pan fyddaf yn ymweld dudalen arall, mae angen i'r gweinydd i ailddefnyddio yr un dynodwr 101 00:06:46,060 --> 00:06:48,910 yn hytrach nag creu un newydd. 102 00:06:48,910 --> 00:06:52,760 Cofiwch, os wyf yn datgan newidyn lleol mewn foo.php 103 00:06:52,760 --> 00:06:55,190 ac yna ewch bar.php, 104 00:06:55,190 --> 00:07:00,980 bar.php Nid oes ffordd o wybod hyn a ddigwyddodd yn foo.php. 105 00:07:00,980 --> 00:07:07,450 Felly mae'r php diofyn gweithredu sesiwn ei gwneud yn ofynnol bod y porwr atgoffa'r gweinydd 106 00:07:07,450 --> 00:07:09,740 pa sesiwn ID i'w ddefnyddio. 107 00:07:09,740 --> 00:07:12,710 Mae hyn yn cael ei weithredu ar ffurf cwci. 108 00:07:12,710 --> 00:07:15,370 Mae cwci-yn ogystal â bod yn byrbryd blasus- 109 00:07:15,370 --> 00:07:18,630 yn unig yw ffeil destun bach ar eich cyfrifiadur 110 00:07:18,630 --> 00:07:21,780 y gall gweinyddwr ysgrifennu at trwy'r porwr gwe. 111 00:07:21,780 --> 00:07:27,300 Felly, ar ôl PHP yn cynhyrchu fy ID Sesiwn unigryw drwy session_start, 112 00:07:27,300 --> 00:07:34,210 mae'n mynd i ddweud wrth y porwr gwe i storio'r dynodwr mewn ffeil destun lleol, neu cwci. 113 00:07:34,210 --> 00:07:38,490 Yna bydd y porwr gwe yn cynnwys y dynodwr ym mhob cais 114 00:07:38,490 --> 00:07:40,780 ei fod yn gwneud i'r gweinydd. 115 00:07:40,780 --> 00:07:44,280 Felly mewn gwirionedd, nid yw'r gweinydd gwe yn cofio pwy ydw. 116 00:07:44,280 --> 00:07:48,780 Yn hytrach, y porwr gwe yn syml cofio y dynodwr unigryw 117 00:07:48,780 --> 00:07:52,730 a gynhyrchwyd gan PHP ac yna atgoffa'r gweinydd yn gyson 118 00:07:52,730 --> 00:07:55,120 beth yw'r dynodwr ydyw. 119 00:07:55,120 --> 00:08:00,760 Y ffordd honno, gwybodaeth fel fy enw defnyddiwr yn cael ei storio ar y gweinydd nad yw fy porwr gwe. 120 00:08:00,760 --> 00:08:05,190 Mae'r porwr yn syml yn dweud wrth y gweinydd lle PHP storio wybodaeth honno 121 00:08:05,190 --> 00:08:07,750 fel y gall PHP adalw. 122 00:08:07,750 --> 00:08:12,150 Felly rhaid gofyn y cwestiwn, lle mae PHP mewn gwirionedd yn storio'r wybodaeth hon? 123 00:08:12,150 --> 00:08:14,910 Yn ddiofyn, bydd PHP storio eich data sesiwn 124 00:08:14,910 --> 00:08:19,540 mewn ffeil tu mewn / tmp, neu ffolder 'dros dro'. 125 00:08:19,540 --> 00:08:24,450 Bydd enw'r ffeil yn cynnwys y sesiwn fel y gall ID PHP benderfynu 126 00:08:24,450 --> 00:08:28,620 pa ffeil i'w darllen ac ysgrifennu o dim ond drwy sesiwn adnabod. 127 00:08:28,620 --> 00:08:32,280 Mae pob hawl. Felly, gadewch i ni agor y tab Rhwydwaith debugger Chrome yn 128 00:08:32,280 --> 00:08:34,890 trwy yr eicon wrench ar dde uchaf. 129 00:08:34,890 --> 00:08:38,409 Nawr, gadewch i ni pen i hello.php eto. 130 00:08:38,409 --> 00:08:42,270 Gadewch i ni glicio ar y cais HTTP i hello.php 131 00:08:42,270 --> 00:08:44,680 ac yna cliciwch ar Headers. 132 00:08:44,680 --> 00:08:50,390 Yma, gallwn weld bod y pennawd cwci yn cynnwys allwedd o'r enw PHPSESSID, 133 00:08:50,390 --> 00:08:55,980 neu sesiwn PHP ID-gyda gwerth hynny yw bod yr un llinyn hir gwelsom 134 00:08:55,980 --> 00:08:59,290 pan fyddwn yn ymweld â sessid.php. 135 00:08:59,290 --> 00:09:04,660 Mae hyn yn union sut y mae'r porwr yn atgoffa y gweinydd pa ID sesiwn y dylid eu defnyddio. 136 00:09:04,660 --> 00:09:08,180 Mae'n ei gynnwys mewn pennawd HTTP. 137 00:09:08,180 --> 00:09:10,500 Mae pob hawl. Gadewch i ni fod yn bennaeth yn ôl i'r derfynell. 138 00:09:10,500 --> 00:09:16,450 Gadewch i ni fynd i / tmp, lle PHP yn storio'r wybodaeth sesiwn yn ddiofyn. 139 00:09:16,450 --> 00:09:19,160 Yn sicr ddigon, y tu mewn y ffolder dros dro, 140 00:09:19,160 --> 00:09:23,550 dyma ffeil sy'n cynnwys yr un fath yn union sesiwn adnabod. 141 00:09:23,550 --> 00:09:28,990 Os byddwn yn agor y ffeil, gallwn weld sut PHP yn cynrychioli fy sesiwn ar ddisg. 142 00:09:28,990 --> 00:09:32,870 Yma y llinyn "Tommy" yn cael ei storio am yr allwedd 'enw,' 143 00:09:32,870 --> 00:09:35,750 sef yr union beth yr ydym yn ei ddisgwyl. 144 00:09:35,750 --> 00:09:38,850 A dyna trosolwg o sesiynau yn PHP. 145 00:09:38,850 --> 00:09:42,590 Yr hyn yr ydym jyst yn gweld dim ond gweithredu diofyn o sesiynau. 146 00:09:42,590 --> 00:09:45,600 Yn wir, mae llawer o wefannau newid ymddygiad diofyn hwn 147 00:09:45,600 --> 00:09:48,280 i storio sesiynau PHP yn fwy effeithlon 148 00:09:48,280 --> 00:09:50,390 er budd o wella perfformiad. 149 00:09:50,390 --> 00:09:52,800 Fy enw i yw Tommy, ac mae hyn yn CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]