首頁 後端開發 php教程 php中用cookies來追蹤識別用戶

php中用cookies來追蹤識別用戶

Aug 08, 2016 am 09:33 AM
cookie cookies mysql php

讓我們來看看保存在瀏覽器中的內容。如果你用的是IE5,在windows目錄下有一個cookies的目錄,裡面有很多文字文件,文件名稱都是類似wudong@15seconds[1].txt這樣的,這就是瀏覽器用來保存值的cookies了。在以前的IE版本中,cookies的內容是可以察看的,但現在內容已經被編碼了。在瀏覽器得到一個Web頁面之前,它會先看這個頁面的域名,是否在cookie中存在,如果有相比配的,瀏覽器會先把匹配的cookie傳送到伺服器,然後才接受處理伺服器傳送過來的頁面。

  先舉個cookies應用的例子:當我連接到Amazon.com時,瀏覽器在接受第一個頁面之前會把它以前設定的cookies的內容傳送給Amazon。然後Amazon.com對傳送過來的內容加以檢查,看看在資料庫中有沒有相關資料,在匹配之後,在為我建立一個定制的頁面傳送到過來。
  為cookies賦值

  必須在伺服器傳送任何內容給客戶瀏覽器之前為Cookies賦值。要做到這一點,cookies的設定就必須放在

標籤內:
     setcookie("CookieID",$USERID);
  ?>
  
  
  
  
  setcookie函數一共有六個參數,用逗號來分隔:

  cookie的名稱,是一個字串,例如:"CookieID"。其間不允許有冒號,逗號和空格。這個參數是必須的,而其它的所有參數都是可選的。如果只有這一個參數被給出,那麼這個cookie將會被刪除。

  cookie的值,通常是一個字串變量,例如:$USERID。也可以為它賦一個??來略過值的設定。

  cookie失效的時間。如果被省略(或被賦值為零),cookie將在這個對話期(session)結束後失效。這個參數可以是絕對的時間,用DD-Mon-YYHH:MM:SS來表示,例如:"24-Nov-9908:26:00"。而更常用的是設定一個相對時間。這是透過time()函數或mktime函數來實現的。例如time()+3600將使得cookie在一個小時後失效。

  一條路徑,用來匹配cookie的。當一個伺服器上有多個同名的cookie的設置,為避免混淆,就要用到這個參數了。使用"/"路徑的和省略這個參數的效果是一樣的。要注意的是Netscape的cookie定義是把網域放在路徑的前面的,而PHP則與之相反。

  伺服器的域名,也是用來匹配cookie的。要注意的是:在伺服器的網域前必須放上一個點(.)。例如:".friendshipcenter.com"。因為除非有兩個以上的點存在,否者這個參數是不能被接受的。

  cookie的安全級,是一個整數。 1表示這個cookie只能透過「安全」的網路來傳送。 0或省略則表示任何類型的網路都可以。

  Cookies和變數

  當PHP腳本從客戶瀏覽器提取了一個cookie後,它將自動的把它轉換成一個變數。例如:一個名為CookieID的cookie會變成變數$CookieID.

  Cookies的內容被封包存在HTTP_COOKIE_VARS數組中,你也可以透過這個陣列和cookie的名稱來存取指定的cookie值:

  PRint$HTTP_COOKIE_VARS[CookieID];

  記住每個使用者

  回過頭在來看看上面的submitform.php3文件,它的作用是把客戶的姓名添加到資料庫中,現在我想為它添加一些東西。我想為每個使用者都分配一個唯一的使用者標誌,然後把這個標誌放在Cookies中,這樣每當使用者造訪我的網站的時候,透過cookie和其中的使用者標誌,我就能夠知道他是誰了。

  MySQL能夠被設定成為每一個新的紀錄自動的分配一個數字,這個數字從1開始,以後每次自動加1。用一行SQL語句,你就可以輕鬆的為資料表添加這樣的一個字段,我把它叫做USERID:
  ALTERTABLEdbname
  ADDCOLUMN
  USERIDINT(11)NOTNULL
  PRIMARYKEYAUTO_INCREMENT;

  對這個字段我們作了一些特別的設定。首先,透過「INT(11)」定義它的類型為11位的整數;然後用「NOTNULL」關鍵字讓這個字段的值不能為NULL;再用「PRIMARYKEY」把它設為索引字段,這樣搜尋起來就會更快;最後,「AUTO_INCREMENT」定義它為自動增一的欄位。

  當把使用者的姓名插入到資料庫後,就應該在他們的瀏覽器上設定cookie了。這時利用的就是剛才我們談到的USERID欄位的值:

     mysql_connect(localhost,username,passWord);
  mysql_select_db(dbname);
  mysql_query("INSERTINTOtablename(first_name,last_name)
  VALUES('$first_name','$last_name')
  ");
  setcookie("CookieID",
  mysql_insert_id(),
  time()+94608000,
  "/");/*三年後cookie才會失效*/
  ?>

  PHP函數mysql_insert_id()傳回在最後一次執行了INSERT查詢後,由AUTO_INCREMENT定義的欄位的值。這樣,只要你不清除掉瀏覽器的Cookies,網站就會永遠「記得」你了

  讀取cookie

  我們來寫一個像Amazon.com所做的那樣的腳本。首先,PHP腳本會先檢查客戶瀏覽器是否發送了cookie過來,如果是那樣的話,使用者的姓名就會被顯示出來。如果沒找到cookie的話,就顯示一個表單,讓客戶登記他們的姓名,然後把他加到資料庫中,並在客戶瀏覽其中設定好cookie。

  首先,先來顯示cookie的內容:
     print$CookieID;
  ?>
  然後,就可以把名字顯示出來了:
     mysql_connect(localhost,username,password);
  mysql_select_db(dbname);
  $selectresult=mysql_query("SELECT*FROMtablename
  WHEREUSERID='$CookieID'
  ");
  $row=mysql_fetch_array($selectresult);
  echo"歡迎你的光臨",$row[first_name],"!";
  ?>
  就是這樣的了。我在其中沒有作判斷,交給你自己來完成好了  


以上就介紹了php中用cookies來追蹤辨識用戶,包括了方面的內容,希望對PHP教學有興趣的朋友有幫助。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1319
25
PHP教程
1269
29
C# 教程
1248
24
MySQL和PhpMyAdmin:核心功能和功能 MySQL和PhpMyAdmin:核心功能和功能 Apr 22, 2025 am 12:12 AM

MySQL和phpMyAdmin是強大的數據庫管理工具。 1)MySQL用於創建數據庫和表、執行DML和SQL查詢。 2)phpMyAdmin提供直觀界面進行數據庫管理、表結構管理、數據操作和用戶權限管理。

在MySQL中解釋外鍵的目的。 在MySQL中解釋外鍵的目的。 Apr 25, 2025 am 12:17 AM

在MySQL中,外鍵的作用是建立表與表之間的關係,確保數據的一致性和完整性。外鍵通過引用完整性檢查和級聯操作維護數據的有效性,使用時需注意性能優化和避免常見錯誤。

IIS和PHP的兼容性:深度潛水 IIS和PHP的兼容性:深度潛水 Apr 22, 2025 am 12:01 AM

IIS和PHP可以兼容,通過FastCGI實現。 1.IIS通過配置文件將.php文件請求轉發給FastCGI模塊。 2.FastCGI模塊啟動PHP進程處理請求,提高性能和穩定性。 3.實際應用中需注意配置細節、錯誤調試和性能優化。

比較和對比Mysql和Mariadb。 比較和對比Mysql和Mariadb。 Apr 26, 2025 am 12:08 AM

MySQL和MariaDB的主要區別在於性能、功能和許可證:1.MySQL由Oracle開發,MariaDB是其分支。 2.MariaDB在高負載環境中性能可能更好。 3.MariaDB提供了更多的存儲引擎和功能。 4.MySQL採用雙重許可證,MariaDB完全開源。選擇時應考慮現有基礎設施、性能需求、功能需求和許可證成本。

如果session_start()被多次調用會發生什麼? 如果session_start()被多次調用會發生什麼? Apr 25, 2025 am 12:06 AM

多次調用session_start()會導致警告信息和可能的數據覆蓋。 1)PHP會發出警告,提示session已啟動。 2)可能導致session數據意外覆蓋。 3)使用session_status()檢查session狀態,避免重複調用。

SQL與MySQL:澄清兩者之間的關係 SQL與MySQL:澄清兩者之間的關係 Apr 24, 2025 am 12:02 AM

SQL是一種用於管理關係數據庫的標準語言,而MySQL是一個使用SQL的數據庫管理系統。 SQL定義了與數據庫交互的方式,包括CRUD操作,而MySQL實現了SQL標準並提供了額外的功能,如存儲過程和触發器。

作曲家:通過AI的幫助開發PHP 作曲家:通過AI的幫助開發PHP Apr 29, 2025 am 12:27 AM

AI可以幫助優化Composer的使用,具體方法包括:1.依賴管理優化:AI分析依賴關係,建議最佳版本組合,減少衝突。 2.自動化代碼生成:AI生成符合最佳實踐的composer.json文件。 3.代碼質量提升:AI檢測潛在問題,提供優化建議,提高代碼質量。這些方法通過機器學習和自然語言處理技術實現,幫助開發者提高效率和代碼質量。

MySQL:數據庫,PHPMYADMIN:管理接口 MySQL:數據庫,PHPMYADMIN:管理接口 Apr 29, 2025 am 12:44 AM

MySQL和phpMyAdmin可以通過以下步驟進行有效管理:1.創建和刪除數據庫:在phpMyAdmin中點擊幾下即可完成。 2.管理表:可以創建表、修改結構、添加索引。 3.數據操作:支持插入、更新、刪除數據和執行SQL查詢。 4.導入導出數據:支持SQL、CSV、XML等格式。 5.優化和監控:使用OPTIMIZETABLE命令優化表,並利用查詢分析器和監控工具解決性能問題。

See all articles