1 00:00:00,000 --> 00:00:02,000 [Powered by Google Translate] [PHP的會話] 2 00:00:02,000 --> 00:00:04,000 [湯米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 如用戶登錄,在您的Web應用程序。 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 我們通過美元符號這麼做,下劃線,資本SESSION變量。 15 00:00:48,790 --> 00:00:52,620 美元符號,下劃線,SESSION-就像美元符號,下劃線,GET 16 00:00:52,620 --> 00:00:54,710 和美元符號,下劃線,後期 17 00:00:54,710 --> 00:00:58,690 是一個關聯數組組成的鍵值對。 18 00:00:58,690 --> 00:01:07,980 所以我們可以使用語法類似美元符號,下劃線,會議, 19 00:01:07,980 --> 00:01:16,000 支架,報價,富,報價,支架,等於,報價,酒吧,報價, 20 00:01:16,000 --> 00:01:20,440 存儲的關鍵值“欄中的”“富”。 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 現在,我們正在使用PHP的使用isset,以確定是否存在密鑰 29 00:01:59,010 --> 00:02:03,230 在$ _SESSION關聯數組中。 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 表單的action屬性是$ _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 ['名稱']必須設置。 41 00:02:50,100 --> 00:02:53,750 有關HTML表單和崗位的詳細信息, 42 00:02:53,750 --> 00:02:56,510 檢查出的PHP Web開發視頻。 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瀏覽器。 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 我們的服務器需要做兩件事情。 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 當我訪問包含在session_start第一次一個PHP頁面, 85 00:05:44,070 --> 00:05:47,930 PHP將產生大量的隨機值。 86 00:05:47,930 --> 00:05:53,970 直到session_destroy被稱為或我不訪問該網站上的所有PHP網頁了一會兒, 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 我們可以看看在當前的會話ID 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應用程序, 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 這就是服務器如何跟踪我是誰。 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 所以默認的PHP會話實現,瀏覽器必須提醒服務器 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瀏覽器寫入。 111 00:07:21,780 --> 00:07:27,300 所以在PHP通過在session_start產生我唯一的會話ID, 112 00:07:27,300 --> 00:07:34,210 它會告訴Web瀏覽器來存儲標識符在本地文本文件,或一個cookie。 113 00:07:34,210 --> 00:07:38,490 然後,Web瀏覽器將包含該標識符在每個請求 114 00:07:38,490 --> 00:07:40,780 它使服務器。 115 00:07:40,780 --> 00:07:44,280 所以,真正的web服務器不記得我是誰。 116 00:07:44,280 --> 00:07:48,780 取而代之的是,web瀏覽器被簡單地記住的唯一標識符 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 這樣一來,信息,比如我的用戶名存儲在服務器不是我的Web瀏覽器上。 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目錄,或“臨時”文件夾內的文件。 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 好的。因此,讓我們在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 在這裡,我們可以看到,該cookie頭中包含一個名為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 這究竟是如何在瀏覽器提醒哪些會話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 這裡包含完全相同的會話ID的文件。 141 00:09:23,550 --> 00:09:28,990 如果我們打開這個文件,我們可以看到PHP是代表我在磁盤上的會話。 142 00:09:28,990 --> 00:09:32,870 這裡字符串“湯米”被存儲為鍵'的名字,' 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 我的名字是湯米,這是CS50。 150 00:09:52,800 --> 00:09:56,000 [CS50.TV]