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 [Dies ist CS50.] [CS50.TV] 4 00:00:07,000 --> 00:00:10,920 Sessions in PHP verwendet werden, um die Funktionalität zu implementieren, 5 00:00:10,920 --> 00:00:13,440 wie Benutzer-Logins, in Ihrem Web-App. 6 00:00:13,440 --> 00:00:16,920 PHP-Sessions können Sie Informationen zu verknüpfen 7 00:00:16,920 --> 00:00:19,680 mit der gesamten Browser-Sitzung des Benutzers 8 00:00:19,680 --> 00:00:22,290 anstatt einfach nur einer einzigen Seite. 9 00:00:22,290 --> 00:00:27,330 Das heißt also, wenn der Benutzer besucht, verschiedene PHP-Seiten, aus denen sich Ihre Website, 10 00:00:27,330 --> 00:00:30,630 alle Informationen in der Session wird anhalten. 11 00:00:30,630 --> 00:00:34,770 Das heißt also, dass die Daten in der Sitzung von einer Seite gespeichert 12 00:00:34,770 --> 00:00:37,580 können später von einer anderen Seite zugegriffen werden. 13 00:00:37,580 --> 00:00:40,080 Das Speichern von Informationen in einer Sitzung ist einfach, 14 00:00:40,080 --> 00:00:48,790 und wir tun dies über die Dollarzeichen, Unterstrich, Hauptstadt SESSION-Variable. 15 00:00:48,790 --> 00:00:52,620 Dollarzeichen, Unterstrich, SESSION-wie Dollarzeichen, Unterstrich, GET 16 00:00:52,620 --> 00:00:54,710 und Dollar-Zeichen, Unterstriche, POST- 17 00:00:54,710 --> 00:00:58,690 ist ein assoziatives Array, bestehend aus Schlüssel-Wert-Paaren. 18 00:00:58,690 --> 00:01:07,980 So können wir wie Syntax-Dollar-Zeichen zu verwenden, zu unterstreichen, SESSION, 19 00:01:07,980 --> 00:01:16,000 Halterung, zitat, foo, zitat, Klammer, gleich, zitat, Bar, quote- 20 00:01:16,000 --> 00:01:20,440 , um den Wert "bar" in der Schlüssel speichern "foo". 21 00:01:20,440 --> 00:01:24,030 Doch bevor wir schreiben oder lesen aus der Sitzung Array 22 00:01:24,030 --> 00:01:26,770 wir brauchen, um eine spezielle Funktion-Call 23 00:01:26,770 --> 00:01:34,690 Sitzung, zu unterstreichen, starten, () - 24 00:01:34,690 --> 00:01:37,060 und dies wird die Sitzung zu initialisieren. 25 00:01:37,060 --> 00:01:39,850 Werfen wir also einen Blick auf ein Beispiel. 26 00:01:39,850 --> 00:01:46,570 Unsere erste Seite hello.php, verwendet das Session Ausgangs einige Daten für den Benutzer. 27 00:01:46,570 --> 00:01:53,920 Denken Sie daran, wir brauchen, um zu verwenden, bevor session_start können wir keine Sitzungsdaten zugreifen. 28 00:01:53,920 --> 00:01:59,010 Jetzt sind wir mit PHP isset, um festzustellen, ob ein Schlüssel vorhanden 29 00:01:59,010 --> 00:02:03,230 in der $ _SESSION assoziatives Array. 30 00:02:03,230 --> 00:02:07,250 Wenn das Schlüssel vorhanden ist, bedeutet, dass der Benutzer angemeldet hat, 31 00:02:07,250 --> 00:02:10,410 so dass wir den Namen des Benutzers anzuzeigen. 32 00:02:10,410 --> 00:02:14,110 Wenn diese Taste nicht gesetzt ist, bedeutet, dass der Benutzer nicht eingeloggt, 33 00:02:14,110 --> 00:02:17,880 so werden wir einen Link zu login.php anzuzeigen. 34 00:02:17,880 --> 00:02:21,380 Werfen wir also einen Blick auf login.php. 35 00:02:21,380 --> 00:02:26,260 Hier unten haben wir einen einzigen HTML-Formular mit einem einzigen Eingang. 36 00:02:26,260 --> 00:02:32,720 Action-Attribut des Formulars ist $ _SERVER ['PHP_SELF'], 37 00:02:32,720 --> 00:02:37,440 und das bedeutet einfach, dass wir wollen, dass die Form, um an der aktuellen Datei eingereicht werden, 38 00:02:37,440 --> 00:02:41,040 , der in diesem Fall ist login.php. 39 00:02:41,040 --> 00:02:43,010 Lassen Sie uns also zurück an den Anfang der Datei zu gehen. 40 00:02:43,010 --> 00:02:50,100 Wenn der Benutzer das Formular eingereicht, dann $ _POST ['name'] gesetzt werden. 41 00:02:50,100 --> 00:02:53,750 Für weitere Informationen über HTML-Formulare und Post, 42 00:02:53,750 --> 00:02:56,510 Besuche die PHP Web-Entwicklung Video. 43 00:02:56,510 --> 00:02:59,330 Im Falle, dass der Benutzer tat finden, 44 00:02:59,330 --> 00:03:03,970 möchten wir den Wert, den sie tippte in die Sitzung zu schreiben. 45 00:03:03,970 --> 00:03:08,540 Jetzt können wir den Benutzer auf hallo.php umleiten. 46 00:03:08,540 --> 00:03:11,800 Weil wir die Eingabe des Benutzers in die Sitzung gespeichert haben, 47 00:03:11,800 --> 00:03:18,240 hello.php in der Lage, den Wert, der in login.php gesetzt war zugreifen. 48 00:03:18,240 --> 00:03:21,010 Lassen Sie uns also check this out in einem Web-Browser. 49 00:03:21,010 --> 00:03:27,520 Zunächst werden wir auf http://localhost/hallo.php navigieren. 50 00:03:27,520 --> 00:03:30,220 Wir können hier sehen, dass wir noch nicht eingeloggt, 51 00:03:30,220 --> 00:03:35,040 und wir klicken auf den Login-Link, der uns umgeleitet wird login.php. 52 00:03:35,040 --> 00:03:41,760 Okay, ich werde geben in meinem Namen, der wird dann in der Session gespeichert werden. 53 00:03:41,760 --> 00:03:48,950 Great! Jetzt können wir meine Eingabe von login.php auf hello.php über die Sitzung zu sehen. 54 00:03:48,950 --> 00:03:52,270 Also, was ist mit der Anmeldung der Benutzer aus? 55 00:03:52,270 --> 00:03:58,510 Nun, um die Benutzer sich anmelden, wir einfach gespeichert einen Wert in Sitzungsnamen ein. 56 00:03:58,510 --> 00:04:03,040 Also, um den Benutzer abmelden, müssen wir einfach diesen Namen Schlüssel entfernen 57 00:04:03,040 --> 00:04:05,040 aus der Sitzung Array. 58 00:04:05,040 --> 00:04:09,130 Werfen wir also einen Blick auf diesen letzten Datei logout.php. 59 00:04:09,130 --> 00:04:12,080 Wieder einmal müssen wir session_start () aufrufen 60 00:04:12,080 --> 00:04:15,260 bevor wir etwas tun Sitzung verwandt. 61 00:04:15,260 --> 00:04:19,240 Jetzt können wir einfach anrufen session_destroy () 62 00:04:19,240 --> 00:04:22,460 die Pflege der immer alle Daten in der Session los finden wird 63 00:04:22,460 --> 00:04:26,790 und leiten den Benutzer zurück zur hello.php. 64 00:04:26,790 --> 00:04:30,700 Also, wenn ich auf den Abmelden Link klicken, 65 00:04:30,700 --> 00:04:34,690 können wir sehen, dass der Server hat vergessen, wer ich bin, 66 00:04:34,690 --> 00:04:36,970 und ich bin nicht mehr angemeldet 67 00:04:36,970 --> 00:04:39,910 Also, was ist denn hier unter der Haube? 68 00:04:39,910 --> 00:04:42,250 Um das Verhalten, das wir gerade gesehen, zu bekommen, 69 00:04:42,250 --> 00:04:44,760 unserem Server muss zwei Dinge tun. 70 00:04:44,760 --> 00:04:48,980 Zuerst muss der Server die Daten in der Session irgendwie zu speichern. 71 00:04:48,980 --> 00:04:51,910 Die verschiedenen PHP-Dateien, die eine Website umfassen 72 00:04:51,910 --> 00:04:56,500 als separate Aufrufe der PHP-Interpreter ausgeführt 73 00:04:56,500 --> 00:05:00,550 so lokale Variable kann nicht zwischen ihnen geteilt werden. 74 00:05:00,550 --> 00:05:04,030 Stattdessen unsere Session-Daten speichern muss der Server 75 00:05:04,030 --> 00:05:08,440 in einem Ort, der mehrere. php-Dateien zugreifen können. 76 00:05:08,440 --> 00:05:13,940 Zweitens muss der Server die Sitzungsdaten mit nur meine Browser-Sitzung zu verbinden. 77 00:05:13,940 --> 00:05:15,940 Wenn ich dich ein, um Facebook, 78 00:05:15,940 --> 00:05:20,460 es gibt wahrscheinlich Millionen anderer Menschen auch in Facebook zur gleichen Zeit eingeloggt. 79 00:05:20,460 --> 00:05:24,200 Aber der Server muss eine Möglichkeit der Zuordnung meine Daten 80 00:05:24,200 --> 00:05:28,340 mit meinem aktuellen Sitzung und die Daten jemand anderes mit einer anderen Sitzung. 81 00:05:28,340 --> 00:05:32,380 Zum Glück, die Autoren von PHP dachte über all dies für uns, 82 00:05:32,380 --> 00:05:35,170 so brauchen wir nicht zu einem dieser uns selbst zu implementieren. 83 00:05:35,170 --> 00:05:39,540 Aber lassen Sie uns einen Blick an, was PHP funktioniert standardmäßig. 84 00:05:39,540 --> 00:05:44,070 Wenn ich eine PHP-Seite besuchen session_start zum ersten Mal enthält, 85 00:05:44,070 --> 00:05:47,930 PHP wird eine große Zufallswert zu generieren. 86 00:05:47,930 --> 00:05:53,970 Bis session_destroy heißt-oder ich weiß nicht besuchen keine PHP-Seiten auf dieser Website für eine Weile- 87 00:05:53,970 --> 00:05:59,050 dass zufällige und wahrscheinlich einzigartigen Wert wird mit mir in Verbindung gebracht werden. 88 00:05:59,050 --> 00:06:02,780 So der Server über einen Weg zur Identifizierung von meinem Browser-Sitzung 89 00:06:02,780 --> 00:06:05,710 im Gegensatz zu jemand anderem. 90 00:06:05,710 --> 00:06:08,780 Wir können einen Blick auf die aktuelle Session-ID zu nehmen 91 00:06:08,780 --> 00:06:12,380 Verwendung der PHP-Funktion, session. 92 00:06:12,380 --> 00:06:17,250 Hier sind wir einfach die Ausgabe den Wert unserer Session-ID. 93 00:06:17,250 --> 00:06:20,580 Also, wenn wir uns wieder auf das Beispiel Web-App anmelden, 94 00:06:20,580 --> 00:06:25,530 und jetzt navigieren Sie zu sessid.php, 95 00:06:25,530 --> 00:06:27,850 wir werden diese lange Kette von Zeichen sehen, 96 00:06:27,850 --> 00:06:31,180 und das ist die aktuelle Kennung für meine Session, 97 00:06:31,180 --> 00:06:35,410 und das ist, wie der Server die Verfolgung der, der ich bin. 98 00:06:35,410 --> 00:06:37,670 Okay, aber wir haben nur die Hälfte des Problems gelöst. 99 00:06:37,670 --> 00:06:40,910 Klar, hat der Server nun eine Möglichkeit mich zu identifizieren, 100 00:06:40,910 --> 00:06:46,060 aber wenn ich eine andere Seite besuchen, muss der Server die gleiche Kennung wiederverwenden 101 00:06:46,060 --> 00:06:48,910 anstatt ein neues zu generieren. 102 00:06:48,910 --> 00:06:52,760 Denken Sie daran, wenn ich erklären, eine lokale Variable in foo.php 103 00:06:52,760 --> 00:06:55,190 und besuchen Sie dann bar.php, 104 00:06:55,190 --> 00:07:00,980 bar.php hat keine Möglichkeit, zu wissen, was in foo.php passiert. 105 00:07:00,980 --> 00:07:07,450 Also die Standard php Sitzung Umsetzung erfordert, dass der Browser den Server erinnern 106 00:07:07,450 --> 00:07:09,740 die Session-ID zu bedienen. 107 00:07:09,740 --> 00:07:12,710 Dies wird in der Form eines Cookies durchgeführt. 108 00:07:12,710 --> 00:07:15,370 Ein Cookie-in ist nicht nur ein leckerer Snack- 109 00:07:15,370 --> 00:07:18,630 ist einfach eine kleine Textdatei, die auf Ihrem Computer 110 00:07:18,630 --> 00:07:21,780 dass ein Server über den Web-Browser zu schreiben. 111 00:07:21,780 --> 00:07:27,300 Also nach meinem PHP erzeugt eindeutige Sitzungs-ID über session_start, 112 00:07:27,300 --> 00:07:34,210 es geht um den Web-Browser zu sagen, dass die Kennung in einer lokalen Textdatei oder einem Cookie speichern. 113 00:07:34,210 --> 00:07:38,490 Dann wird der Web-Browser wird in jeder Anforderung gehören, dass die Kennung 114 00:07:38,490 --> 00:07:40,780 dass es sinn an den Server. 115 00:07:40,780 --> 00:07:44,280 Also wirklich, der Web-Server nicht erinnern, wer ich bin. 116 00:07:44,280 --> 00:07:48,780 Stattdessen wird der Web-Browser einfach die Erinnerung an die eindeutige Kennung 117 00:07:48,780 --> 00:07:52,730 das wurde von PHP erzeugt und dann ständig daran erinnert den Server 118 00:07:52,730 --> 00:07:55,120 was das Bezeichner ist. 119 00:07:55,120 --> 00:08:00,760 Auf diese Weise Informationen wie meinen Benutzernamen auf dem Server nicht meine Web-Browser gespeichert. 120 00:08:00,760 --> 00:08:05,190 Der Browser zeigt einfach den Server, auf dem PHP gespeichert, dass Informationen 121 00:08:05,190 --> 00:08:07,750 so PHP kann es abzurufen. 122 00:08:07,750 --> 00:08:12,150 Damit stellt sich die Frage, wo ist eigentlich PHP Speichern dieser Informationen? 123 00:08:12,150 --> 00:08:14,910 Standardmäßig wird PHP Session Daten speichern 124 00:08:14,910 --> 00:08:19,540 in einer Datei in / tmp oder das "Temp"-Ordner. 125 00:08:19,540 --> 00:08:24,450 Der Name der Datei wird auch die PHP-Session-ID, so bestimmen kann, 126 00:08:24,450 --> 00:08:28,620 die Datei zum Lesen und Schreiben von nur über die Session-ID. 127 00:08:28,620 --> 00:08:32,280 Gut. Also lassen Sie öffnen die Registerkarte Netzwerk in Chrome-Debugger 128 00:08:32,280 --> 00:08:34,890 über das Schraubenschlüssel-Symbol oben rechts. 129 00:08:34,890 --> 00:08:38,409 Nun wollen wir den Kopf wieder hallo.php. 130 00:08:38,409 --> 00:08:42,270 Lassen Sie auf die HTTP-Anfrage an hallo.php 131 00:08:42,270 --> 00:08:44,680 und klicken Sie dann auf Sockel. 132 00:08:44,680 --> 00:08:50,390 Hier können wir sehen, dass die Cookie-Header einen Schlüssel namens PHPSESSID enthält, 133 00:08:50,390 --> 00:08:55,980 oder PHP-Session-ID mit einem Wert, dass gleichen langen String, den wir gesehen haben, ist 134 00:08:55,980 --> 00:08:59,290 als wir besuchten sessid.php. 135 00:08:59,290 --> 00:09:04,660 Das ist genau wie der Browser erinnert, welche den Server Session-ID verwendet werden soll. 136 00:09:04,660 --> 00:09:08,180 Es ist die Aufnahme in einem HTTP-Header. 137 00:09:08,180 --> 00:09:10,500 Gut. Lassen Sie den Kopf zurück zum Terminal. 138 00:09:10,500 --> 00:09:16,450 Lassen Sie navigieren auf / tmp, wo PHP die Session-Informationen zu speichern standardmäßig. 139 00:09:16,450 --> 00:09:19,160 Sicher genug, Innere dieser temporären Ordner, 140 00:09:19,160 --> 00:09:23,550 hier ist eine Datei, die exakt das gleiche Session-ID enthält. 141 00:09:23,550 --> 00:09:28,990 Wenn wir diese Datei zu öffnen, können wir sehen, wie PHP, die meine Session auf der Festplatte. 142 00:09:28,990 --> 00:09:32,870 Hier die Zeichenfolge "Tommy" wird für die Schlüssel gespeichert 'name' 143 00:09:32,870 --> 00:09:35,750 das ist genau das, was wir erwartet hatten. 144 00:09:35,750 --> 00:09:38,850 Und das ist ein Überblick über die Sessions in PHP. 145 00:09:38,850 --> 00:09:42,590 Was wir gerade gesehen habe, war nur die Standardimplementierung von Sitzungen. 146 00:09:42,590 --> 00:09:45,600 In der Tat, viele Websites ändern dieses Standardverhalten 147 00:09:45,600 --> 00:09:48,280 PHP-Sitzungen effizienter speichern 148 00:09:48,280 --> 00:09:50,390 im Interesse der Verbesserung der Leistung. 149 00:09:50,390 --> 00:09:52,800 Mein Name ist Tommy, und dies ist CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]