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, Πανεπιστήμιο Χάρβαρντ] 3 00:00:04,000 --> 00:00:07,000 [Αυτό είναι CS50.] [CS50.TV] 4 00:00:07,000 --> 00:00:10,920 Συνεδρίες σε PHP μπορεί να χρησιμοποιηθεί για την υλοποίηση της λειτουργικότητας, 5 00:00:10,920 --> 00:00:13,440 όπως logins χρηστών, web app σας. 6 00:00:13,440 --> 00:00:16,920 Συνεδρίες PHP σας επιτρέπουν να συνδέσει πληροφορίες 7 00:00:16,920 --> 00:00:19,680 με όλη περιήγησης του χρήστη 8 00:00:19,680 --> 00:00:22,290 και όχι απλώς μία μόνο σελίδα. 9 00:00:22,290 --> 00:00:27,330 Έτσι, αυτό σημαίνει ότι ο χρήστης επισκέπτεται διάφορες σελίδες PHP που απαρτίζουν την ιστοσελίδα σας, 10 00:00:27,330 --> 00:00:30,630 κάθε πληροφορία στη συνεδρία θα συνεχιστεί. 11 00:00:30,630 --> 00:00:34,770 Έτσι ώστε να σημαίνει ότι τα δεδομένα που αποθηκεύονται στη συνεδρία κατά μία σελίδα 12 00:00:34,770 --> 00:00:37,580 μπορεί αργότερα να προσεγγιστεί από μια άλλη σελίδα. 13 00:00:37,580 --> 00:00:40,080 Την αποθήκευση πληροφοριών σε μια συνεδρία είναι εύκολο, 14 00:00:40,080 --> 00:00:48,790 και εμείς να το πράξουν μέσω το σύμβολο του δολαρίου, υπογραμμίζουν, μεταβλητού κεφαλαίου ΣΥΝΕΔΡΙΑ. 15 00:00:48,790 --> 00:00:52,620 Σύμβολο του δολαρίου, υπογραμμίζουν, ΣΥΝΕΔΡΙΑ-όπως ακριβώς και το σύμβολο του δολαρίου, υπογραμμίζουν, GET 16 00:00:52,620 --> 00:00:54,710 και το σύμβολο του δολαρίου, υπογραμμίζουν, POST- 17 00:00:54,710 --> 00:00:58,690 είναι ένας associative πίνακα που αποτελείται από βασικά ζεύγη αξίας. 18 00:00:58,690 --> 00:01:07,980 Έτσι, μπορούμε να χρησιμοποιήσουμε σύνταξη που μοιάζει με το σύμβολο του δολαρίου, υπογραμμίζουν, ΣΥΝΕΔΡΙΑ, 19 00:01:07,980 --> 00:01:16,000 βραχίονα, παραθέτω, foo, παραθέτω, βραχίονα, ισούται με, παραθέτω, μπαρ, παραθέτω- 20 00:01:16,000 --> 00:01:20,440 για να αποθηκεύσετε την τιμή "bar" στο πλήκτρο "foo". 21 00:01:20,440 --> 00:01:24,030 Ωστόσο, για να μπορέσουμε να γράψει ή να διαβάσει από τον πίνακα συνεδρία, 22 00:01:24,030 --> 00:01:26,770 θα πρέπει να καλέσετε μια ειδική λειτουργία- 23 00:01:26,770 --> 00:01:34,690 συνεδρία, υπογραμμίζουν, ξεκινήστε, () - 24 00:01:34,690 --> 00:01:37,060 και αυτό θα προετοιμάσει τη σύνοδο. 25 00:01:37,060 --> 00:01:39,850 Έτσι, ας ρίξουμε μια ματιά σε ένα παράδειγμα. 26 00:01:39,850 --> 00:01:46,570 Η πρώτη μας σελίδα, hello.php, χρησιμοποιεί τη σύνοδο για έξοδο κάποια στοιχεία για τον χρήστη. 27 00:01:46,570 --> 00:01:53,920 Θυμηθείτε, θα πρέπει να χρησιμοποιήσετε session_start πριν μπορούμε να έχουμε πρόσβαση οποιαδήποτε δεδομένα συνεδρία. 28 00:01:53,920 --> 00:01:59,010 Τώρα είμαστε με isset PHP προκειμένου να διαπιστωθεί εάν υπάρχει ένα βασικό 29 00:01:59,010 --> 00:02:03,230 στο $ _SESSION associative array. 30 00:02:03,230 --> 00:02:07,250 Εάν υπάρχει αυτό το κλειδί, αυτό σημαίνει ότι ο χρήστης έχει συνδεθεί, 31 00:02:07,250 --> 00:02:10,410 έτσι θα εμφανίσει το όνομα του χρήστη. 32 00:02:10,410 --> 00:02:14,110 Αν δεν υπάρχει αυτό το κλειδί, αυτό σημαίνει ότι ο χρήστης δεν έχει συνδεθεί ακόμα, 33 00:02:14,110 --> 00:02:17,880 έτσι θα επιδείξει μια σύνδεση με login.php. 34 00:02:17,880 --> 00:02:21,380 Έτσι, ας ρίξουμε μια ματιά στο login.php. 35 00:02:21,380 --> 00:02:26,260 Εδώ κάτω, έχουμε μια ενιαία μορφή HTML με μία μόνο είσοδο. 36 00:02:26,260 --> 00:02:32,720 Χαρακτηριστικό δράση της φόρμας είναι $ _SERVER ['PHP_SELF »], 37 00:02:32,720 --> 00:02:37,440 και αυτό σημαίνει απλά ότι θέλουμε το έντυπο που θα υποβληθεί στο τρέχον αρχείο, 38 00:02:37,440 --> 00:02:41,040 η οποία, στην περίπτωση αυτή, είναι login.php. 39 00:02:41,040 --> 00:02:43,010 Οπότε ας πάμε πίσω στην κορυφή αυτού του αρχείου. 40 00:02:43,010 --> 00:02:50,100 Εάν ο χρήστης υπέβαλε τη μορφή, τότε θα πρέπει να οριστεί $ _POST ['name']. 41 00:02:50,100 --> 00:02:53,750 Για περισσότερες πληροφορίες σχετικά με τις φόρμες HTML και μετά, 42 00:02:53,750 --> 00:02:56,510 ελέγξτε την ανάπτυξη Ιστού PHP βίντεο. 43 00:02:56,510 --> 00:02:59,330 Στην περίπτωση που ο χρήστης έκανε υποβάλουν το έντυπο, 44 00:02:59,330 --> 00:03:03,970 θα θέλαμε να γράψει την τιμή που πληκτρολογήσατε στο στη σύνοδο. 45 00:03:03,970 --> 00:03:08,540 Τώρα μπορούμε να ανακατευθύνει το χρήστη να hello.php. 46 00:03:08,540 --> 00:03:11,800 Επειδή έχουμε αποθηκευμένα είσοδο του χρήστη στο συνεδρία, 47 00:03:11,800 --> 00:03:18,240 hello.php θα είναι σε θέση να έχουν πρόσβαση την τιμή που έχει οριστεί στο login.php. 48 00:03:18,240 --> 00:03:21,010 Οπότε ας ελέγξει αυτό έξω σε ένα web browser. 49 00:03:21,010 --> 00:03:27,520 Κατ 'αρχάς, θα περιηγηθείτε σε http://localhost/hello.php. 50 00:03:27,520 --> 00:03:30,220 Μπορούμε να δούμε εδώ ότι δεν έχουν συνδεθεί ακόμα, 51 00:03:30,220 --> 00:03:35,040 οπότε ας κάντε κλικ στο σύνδεσμο σύνδεσης, η οποία θα μας ανακατευθύνει σε login.php. 52 00:03:35,040 --> 00:03:41,760 Εντάξει, θα πληκτρολογήσετε το όνομά μου, το οποίο στη συνέχεια θα αποθηκεύεται στη σύνοδο. 53 00:03:41,760 --> 00:03:48,950 Μεγάλη! Τώρα μπορούμε να δούμε εισόδου μου από login.php για hello.php μέσω του συνεδρία. 54 00:03:48,950 --> 00:03:52,270 Έτσι, τι γίνεται με την αποσύνδεση του χρήστη έξω; 55 00:03:52,270 --> 00:03:58,510 Λοιπόν, για να συνδέσει τον χρήστη στο, εμείς απλώς αποθηκεύονται σε μια τιμή όνομα περιόδου. 56 00:03:58,510 --> 00:04:03,040 Έτσι για να καταγράψει το χρήστη έξω, εμείς απλά πρέπει να αφαιρέσετε το κλειδί το όνομα 57 00:04:03,040 --> 00:04:05,040 από τη συστοιχία συνεδρία. 58 00:04:05,040 --> 00:04:09,130 Έτσι, ας ρίξουμε μια ματιά σε αυτό το τελευταίο αρχείο, logout.php. 59 00:04:09,130 --> 00:04:12,080 Για άλλη μια φορά, θα πρέπει να καλέσετε session_start () 60 00:04:12,080 --> 00:04:15,260 για να μπορέσουμε να κάνουμε τίποτα συνεδρία που αφορούν. 61 00:04:15,260 --> 00:04:19,240 Τώρα μπορούμε απλά να καλέσετε session_destroy (), 62 00:04:19,240 --> 00:04:22,460 η οποία θα φροντίσει για να απαλλαγούμε από όλα τα δεδομένα στην περίοδο 63 00:04:22,460 --> 00:04:26,790 και στη συνέχεια να ανακατευθύνει το χρήστη πίσω στο hello.php. 64 00:04:26,790 --> 00:04:30,700 Έτσι, αν κάνω κλικ στο σύνδεσμο Αποσύνδεση, 65 00:04:30,700 --> 00:04:34,690 μπορούμε να δούμε ότι ο διακομιστής έχει ξεχάσει ποιος είμαι, 66 00:04:34,690 --> 00:04:36,970 και είμαι πλέον εισέλθει 67 00:04:36,970 --> 00:04:39,910 Λοιπόν, τι συμβαίνει εδώ κάτω από την κουκούλα; 68 00:04:39,910 --> 00:04:42,250 Για να πάρετε τη συμπεριφορά που μόλις είδαμε, 69 00:04:42,250 --> 00:04:44,760 server μας θα πρέπει να κάνετε 2 πράγματα. 70 00:04:44,760 --> 00:04:48,980 Πρώτον, ο διακομιστής πρέπει με κάποιο τρόπο να αποθηκεύουν τα δεδομένα στη σύνοδο. 71 00:04:48,980 --> 00:04:51,910 Τα διαφορετικά αρχεία PHP που περιλαμβάνει μια ιστοσελίδα 72 00:04:51,910 --> 00:04:56,500 εκτελούνται ως ξεχωριστά επικλήσεις του διερμηνέα PHP 73 00:04:56,500 --> 00:05:00,550 τόσο την τοπική μεταβλητή δεν μπορεί να μοιραστεί μεταξύ τους. 74 00:05:00,550 --> 00:05:04,030 Αντ 'αυτού, ο διακομιστής πρέπει να αποθηκεύουν δεδομένα της συνεδρίας μας 75 00:05:04,030 --> 00:05:08,440 σε κάποιο μέρος που πολλαπλά αρχεία. php μπορεί να έχει πρόσβαση. 76 00:05:08,440 --> 00:05:13,940 Δεύτερον, ο διακομιστής πρέπει να συνδέσει τα δεδομένα συνεδρία με μόνο περιήγησης μου. 77 00:05:13,940 --> 00:05:15,940 Όταν συνδεθείτε στο Facebook, 78 00:05:15,940 --> 00:05:20,460 πιθανώς να υπάρχουν εκατομμύρια άλλα άτομα, επίσης συνδεδεμένοι στο Facebook την ίδια στιγμή. 79 00:05:20,460 --> 00:05:24,200 Αλλά ο διακομιστής χρειάζεται κάποιο τρόπο σύνδεσης των στοιχείων μου 80 00:05:24,200 --> 00:05:28,340 με την τρέχουσα συνεδρία μου και τα δεδομένα σε κάποιον άλλο με μια άλλη συνεδρίαση. 81 00:05:28,340 --> 00:05:32,380 Ευτυχώς, οι συντάκτες της PHP σκεφτεί όλα αυτά για μας, 82 00:05:32,380 --> 00:05:35,170 γι 'αυτό δεν χρειάζεται να εφαρμόσει οποιαδήποτε από μόνοι μας. 83 00:05:35,170 --> 00:05:39,540 Αλλά ας ρίξουμε μια ματιά στο τι είναι η PHP κάνει από προεπιλογή. 84 00:05:39,540 --> 00:05:44,070 Όταν επισκέπτομαι μια σελίδα PHP που περιέχουν session_start για πρώτη φορά, 85 00:05:44,070 --> 00:05:47,930 PHP θα δημιουργήσει μια μεγάλη τυχαία τιμή. 86 00:05:47,930 --> 00:05:53,970 Μέχρι session_destroy λέγεται ή δεν επισκέπτονται τις σελίδες PHP σε αυτό το site για λίγο- 87 00:05:53,970 --> 00:05:59,050 ότι οι τυχαίες και μάλλον μοναδική αξία θα σχετίζεται με μένα. 88 00:05:59,050 --> 00:06:02,780 Με αυτόν τον τρόπο ο διακομιστής έχει κάποιον τρόπο εντοπισμού περιήγησης μου 89 00:06:02,780 --> 00:06:05,710 σε αντίθεση με κάποιον άλλο. 90 00:06:05,710 --> 00:06:08,780 Μπορούμε να ρίξουμε μια ματιά στο σημερινό αναγνωριστικό περιόδου 91 00:06:08,780 --> 00:06:12,380 χρησιμοποιώντας τη λειτουργία PHP, Session_ID. 92 00:06:12,380 --> 00:06:17,250 Εδώ είμαστε απλά εξάγει την τιμή του αναγνωριστικού συνεδρία μας. 93 00:06:17,250 --> 00:06:20,580 Έτσι, αν και πάλι να συνδεθείτε με το παράδειγμα web app, 94 00:06:20,580 --> 00:06:25,530 και τώρα να πλοηγηθείτε σε sessid.php, 95 00:06:25,530 --> 00:06:27,850 θα δούμε αυτή τη μακρά σειρά των χαρακτήρων, 96 00:06:27,850 --> 00:06:31,180 και αυτό είναι το τρέχον αναγνωριστικό για συνεδρία μου, 97 00:06:31,180 --> 00:06:35,410 και αυτό είναι το πώς ο server είναι η παρακολούθηση του ποιος είμαι. 98 00:06:35,410 --> 00:06:37,670 Εντάξει, αλλά λύσαμε μόνο το μισό πρόβλημα. 99 00:06:37,670 --> 00:06:40,910 Σίγουρα, ο διακομιστής έχει πλέον κάποιον τρόπο εντοπισμού μου, 100 00:06:40,910 --> 00:06:46,060 αλλά όταν επισκέπτεστε μια άλλη σελίδα, ο διακομιστής πρέπει να χρησιμοποιήσετε ξανά το ίδιο αναγνωριστικό 101 00:06:46,060 --> 00:06:48,910 αντί να δημιουργήσουν ένα νέο. 102 00:06:48,910 --> 00:06:52,760 Να θυμάστε, αν δηλώνω μια τοπική μεταβλητή στην foo.php 103 00:06:52,760 --> 00:06:55,190 και στη συνέχεια να επισκεφθείτε bar.php, 104 00:06:55,190 --> 00:07:00,980 bar.php δεν έχει καμία δυνατότητα να γνωρίζει τι συνέβη στο foo.php. 105 00:07:00,980 --> 00:07:07,450 Επομένως, η εφαρμογή συνεδρία default php απαιτεί ότι ο browser θυμίζουν το διακομιστή 106 00:07:07,450 --> 00:07:09,740 που συνεδρία ID να χρησιμοποιήσετε. 107 00:07:09,740 --> 00:07:12,710 Αυτό υλοποιείται με τη μορφή ενός cookie. 108 00:07:12,710 --> 00:07:15,370 Ένα cookie-πέραν του ότι είναι ένα νόστιμο σνακ 109 00:07:15,370 --> 00:07:18,630 είναι απλά ένα μικρό αρχείο κειμένου στον υπολογιστή σας 110 00:07:18,630 --> 00:07:21,780 ότι ένας διακομιστής μπορεί να γράψει μέσω του web browser. 111 00:07:21,780 --> 00:07:27,300 Έτσι, μετά την PHP δημιουργεί μοναδικό αναγνωριστικό συνόδου μου μέσω session_start, 112 00:07:27,300 --> 00:07:34,210 πρόκειται να πει το web browser για να αποθηκεύσετε αυτό το αναγνωριστικό σε ένα τοπικό αρχείο κειμένου, ή ένα μπισκότο. 113 00:07:34,210 --> 00:07:38,490 Στη συνέχεια, ο web browser θα περιλαμβάνει αυτό το αναγνωριστικό σε κάθε αίτημα 114 00:07:38,490 --> 00:07:40,780 ότι κάνει στο διακομιστή. 115 00:07:40,780 --> 00:07:44,280 Έτσι, πραγματικά, ο web server δεν θυμάται ποιος είμαι. 116 00:07:44,280 --> 00:07:48,780 Αντ 'αυτού, ο web browser είναι απλώς να θυμηθούμε το μοναδικό αναγνωριστικό 117 00:07:48,780 --> 00:07:52,730 που δημιουργήθηκε με PHP και, στη συνέχεια, υπενθυμίζοντας συνεχώς το διακομιστή 118 00:07:52,730 --> 00:07:55,120 τι είναι αναγνωριστικό. 119 00:07:55,120 --> 00:08:00,760 Με αυτόν τον τρόπο, πληροφορίες όπως το όνομα χρήστη μου είναι αποθηκευμένα στο διακομιστή δεν περιηγητή μου. 120 00:08:00,760 --> 00:08:05,190 Το πρόγραμμα περιήγησης απλά ενημερώνει το διακομιστή όπου αποθηκεύονται PHP αυτές τις πληροφορίες 121 00:08:05,190 --> 00:08:07,750 έτσι PHP μπορεί να το ανακτήσει. 122 00:08:07,750 --> 00:08:12,150 Έτσι ανακύπτει το ερώτημα, πού είναι στην πραγματικότητα PHP αποθηκεύει αυτές τις πληροφορίες; 123 00:08:12,150 --> 00:08:14,910 Από προεπιλογή, η PHP θα αποθηκεύσει τα δεδομένα της συνεδρίας σας 124 00:08:14,910 --> 00:08:19,540 σε ένα αρχείο μέσα στο / tmp, ή στο φάκελο "temp". 125 00:08:19,540 --> 00:08:24,450 Το όνομα αυτού του αρχείου θα περιλαμβάνει το ID της συνεδρίας, ώστε PHP μπορεί να προσδιορίσει 126 00:08:24,450 --> 00:08:28,620 που το αρχείο για να διαβάσει και να γράψει από μόνο μέσω του ID της συνεδρίας. 127 00:08:28,620 --> 00:08:32,280 Εντάξει. Οπότε ας ανοίξει την καρτέλα Network στο πρόγραμμα εντοπισμού σφαλμάτων του Chrome 128 00:08:32,280 --> 00:08:34,890 μέσω εικονίδιο με το κλειδί στο πάνω δεξιά. 129 00:08:34,890 --> 00:08:38,409 Τώρα ας το κεφάλι για να hello.php πάλι. 130 00:08:38,409 --> 00:08:42,270 Ας κάνουμε κλικ στην αίτηση HTTP hello.php 131 00:08:42,270 --> 00:08:44,680 και στη συνέχεια κάντε κλικ στο κεφαλίδες. 132 00:08:44,680 --> 00:08:50,390 Εδώ μπορούμε να δούμε ότι η κεφαλίδα μπισκότο περιέχει ένα κλειδί που ονομάζεται PHPSESSID, 133 00:08:50,390 --> 00:08:55,980 ή PHP συνεδρία ID-με μια τιμή που είναι η ίδια μακρά σειρά είδαμε 134 00:08:55,980 --> 00:08:59,290 όταν επισκεφτήκαμε sessid.php. 135 00:08:59,290 --> 00:09:04,660 Αυτό είναι ακριβώς το πώς ο browser θυμίζει τον server τι συνεδρία ID θα πρέπει να χρησιμοποιείται. 136 00:09:04,660 --> 00:09:08,180 Είναι ότι ακόμη και σε μια κεφαλίδα HTTP. 137 00:09:08,180 --> 00:09:10,500 Εντάξει. Ας πάμε πίσω στο τερματικό. 138 00:09:10,500 --> 00:09:16,450 Ας πλοηγηθείτε στο / tmp, όπου PHP αποθηκεύει τις πληροφορίες της περιόδου από προεπιλογή. 139 00:09:16,450 --> 00:09:19,160 Σίγουρα αρκετά, μέσα από αυτό το προσωρινό φάκελο, 140 00:09:19,160 --> 00:09:23,550 εδώ είναι ένα αρχείο που περιέχει ακριβώς το ίδιο αναγνωριστικό περιόδου. 141 00:09:23,550 --> 00:09:28,990 Αν ανοίξουμε το αρχείο αυτό, μπορούμε να δούμε πώς PHP εκπροσωπεί συνεδρία μου στο δίσκο. 142 00:09:28,990 --> 00:09:32,870 Εδώ το string "Tommy" που αποθηκεύονται για το κλειδί το όνομα, ' 143 00:09:32,870 --> 00:09:35,750 το οποίο είναι ακριβώς αυτό που περιμέναμε. 144 00:09:35,750 --> 00:09:38,850 Και αυτό είναι μια επισκόπηση των συνόδων σε PHP. 145 00:09:38,850 --> 00:09:42,590 Αυτό που μόλις είδαμε ήταν μόνο η προεπιλεγμένη εφαρμογή των συνεδριών. 146 00:09:42,590 --> 00:09:45,600 Στην πραγματικότητα, πολλές ιστοσελίδες αλλάξετε αυτή την προεπιλεγμένη συμπεριφορά 147 00:09:45,600 --> 00:09:48,280 για την αποθήκευση PHP συνεδρίες πιο αποτελεσματικά 148 00:09:48,280 --> 00:09:50,390 προς το συμφέρον της βελτίωσης των επιδόσεων. 149 00:09:50,390 --> 00:09:52,800 Το όνομά μου είναι ο Tommy, και αυτό είναι CS50. 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]