天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

PHP中cookies使用指南

綜述 
  Cookie是在HTTP協議下,服務器或腳本可以維護客戶工作站上信息的一種方式。Cookie是由Web服務器保存在用戶瀏覽器上的小文件,它可以包含有關用戶的信息(如身份識別號碼、密碼、用戶在Web站點購物的方式或用戶訪問該站點的次數)。無論何時用戶鏈接到服務器,Web站點都可以訪問Cookie信息。 
  怎樣設置cookies? 
  在php中可以使用setcookie函數設置一個cookie。cookie是 HTTP標頭的一部分, 因此設置cookie功能必須在任何內容送到瀏覽器之前。這種限制與header()函數一樣。任何從客戶端傳來的cookie將自動地轉化成一個php變量。php取得信息頭并分析, 提取cookie名并變成變量。因此,如果設置cookie如setcookie("mycookie","Cookies")php將自動產生一個名為$mycookie,值為"Cookies"的變量。 
  我們來看一下setcookie函數語法: 
  init setcookie(string CookieName,string CookieValue,int CookieExpireTime,path,domain,int secure);  
  參數說明: 
  PATH:表示web服務器上的目錄,默認為被調用頁面所在目錄 
  DOMAIN:cookie可以使用的域名,默認為被調用頁面的域名。這個域名必須包含兩個".",所以如果你指定你的頂級域名,你必須用".mydomain.com" 
  SECURE:如果設為"1",表示cookie只能被用戶的瀏覽器認為是安全的服務器所記住. 
cookies使用舉例 
  假設我們有這樣一個需要注冊的站點,它自動識別用戶的身份并進行相關的操作:如果是已經注冊的用戶,發送給他信息;如果不是已經注冊的用戶,則顯示一個注冊頁面的鏈接。 
  按照上面的要求,我們先創建數據庫用來保存注冊用戶的信息:名字(first name),姓(last name),Email地址(email address),計數器(visit counter)。 
  先按下面步驟建表: 
    mysql> create database users; 
    Query OK, 1 row affected (0.06 sec) 
    mysql> use users; 
    Database changed 
    mysql> create table info (FirstName varchar(20), LastName varchar(40), email varchar(40), count varchar(3)); 
    Query OK, 0 rows affected (0.05 sec)  
  然后建一個php頁面對照數據庫檢查cookies。 
  由于php能轉換可識別的cookie為相應的變量,所以我們能檢查一個名為"myCookies" 的變量: 
    <? if (isset($myCookies)) { // 如果Cookie已經存在 
    ……
    } else { //如果Cookie不存在
    ……
    } 
    ?> 
  當cookie存在時,我們執行下面步驟: 
  首先取得cookie值,用explode函數分析成不同的變量,增加計數器,并設一個新cookie: 
    $info = explode("&", $myCookies); 
    ……
    $count++; 
    $CookieString=$FirstName.'&'.$LastName.'&'.$email.'&'.$count; 
    SetCookie ("myCookies",$CookieString, time()+3600); //設置cookie  
  接著用html語句輸出用戶信息。 
  最后,用新的計數器值更新數據庫。 
  如果這個cookie不存在,我們顯示一個注冊頁(register.php)的鏈接。 
  下面的register.php是用戶注冊頁面: 
  /* register.php */
  <form method="post" action="regOK.php">
  First Name:<input type="text" name="FirstName">
  Last Name:<input type="text" name="LastName">
  <input type="submit" value="注冊">
  </form>  
  用戶在register.php注冊頁面填寫的信息提交給regOK.php
  /* regOK.php */
  if ($FirstName and $LastName and $email) {
   ……//在數據庫查詢用戶是否存在
   }
  }else{
  ……//錯誤處理
  }  

 上面的程序流程如下: 
  首先檢查所有的信息是否按要求填寫,如果沒有,返回重新輸入 
  如果所有信息填好,首先,我們從數據庫中取回用戶登錄詳細資料 
    mysql_connect() or die ("連接數據庫出現錯誤!"); 
    $query="select * from info where FirstName='$FirstName' and LastName='$LastName' and email='$email'"; 
    $result = mysql_db_query("users", $query); 
    $info=mysql_fetch_array($result); 
    $count=$info["count"];  
  檢查數據庫是否有這樣一個用戶,如果有,它指定舊的信息,并用當前的信息建一新的cookie,如果同一用戶沒有數據庫登錄,新建一數據庫登錄,并建一新的cookie。 
  現在利用isset()函數檢查用戶是否有計數器,如果有則計數器增加并且建立一個新的cookie: 
    $count++; //增加計數器
    $CookieString=$FirstName.'&'.$LastName.'&'.$email.'&'.$count; 
    SetCookie ("myCookies",$CookieString, time()+3600);  
  如果沒有一用戶計數器,在mysql中加一記錄,并設一cookie 
  注意:調用setcookie函數之前應該沒有任何數據輸出倒瀏覽器,否則將會出現錯誤。 
  如何實現跨域名Cookie? 
  從Cookie規范上說,一個cookie只能用于一個域名,因此,如果在瀏覽器中對一個域名設置了一個cookie,那么這個cookie對于其它的域名將無效。 
  下面我們來談一個跨域名cookie的實現方案: 
第一步:創建預置腳本 
  將下面的代碼加到預置腳本中(或出現在所有腳本之前的函數中)。 
    <?php 
    /*如果GET變量已經設置了,并且它與cookie變量不同 
     *則使用get變量(更新cookie) 
     */
    global $HTTP_COOKIE_VARS, $HTTP_GET_VARS; 
    if (isset($sessionid) && isset($HTTP_GET_VARS['sessionid']) && ($HTTP_COOKIE_VARS['sessionid'] != $HTTP_GET_VARS['sessionid'])) { 
      SetCookie('sessionid', $HTTP_GET_VARS['sessionid'], 0, '/', ''); 
      $HTTP_COOKIE_VARS['sessionid'] = $HTTP_GET_VARS['sessionid']; 
      $sessionid = $HTTP_GET_VARS['sessionid']; 
    } 
    ?>  
  這個代碼運行之后,一個全局變量'sessionid'將可以用于腳本。它將保存用戶的cookie中的sessionid值,或者是通過GET請求發來的sessionid值。 
第二步:為所有的交叉域名引用使用變量 
  創建一個全局的配置文件,用于存放可以進行切換的域名的基本引用形式。例如,如果我們擁有domain1.com和domain2.com,則如下設置: 
    <?php 
    $domains['domain1'] = "http://www.domain1.com/-$sessionid-"; 
    $domains['domain2'] = "http://www.domain2.com/-$sessionid-"; 
    ?>  
  我們寫這樣一段代碼: 
    <?php 
    echo "Click <a href="", $domains['domain2'], "/contact/?email=yes">here</a> to contact us."; 
    ?>  
  上面的代碼將產生如下的輸出: 
    Click <a >here</a> to contact us.  
  在這里sessionid已經被插入到URL中去了。 
第三步:配置Apache 
  現在,我們來配置Apache來重寫這個URL。 
  我們需要將
    http://www.domain2.com/-66543afe6543asdf6asd-/contact/ 
  變成這樣: 
    http://www.domain2.com/contact/?sessionid=66543afe6543asdf6asd 
  并且這種url: 
    http://www.domain2.com/-66543afe6543asdf6asd-/contact/?email=yes
  變成這樣: 
    http://www.domain2.com/contact/?email=yes&sessionid=66543afe6543asdf6asd 
  為了實現上面的要求,簡單地配置兩個虛擬服務器,作為domain1和domain2,如下操作:
    <VirtualHost ipaddress> 
    DocumentRoot /usr/local/www/domain1 
    ServerName www.domain1.com 
    RewriteEngine on 
    RewriteRule ^/-(.*)-(.*?.*)$ $2&sessionid=$1 [L,R,QSA] 
    RewriteRule ^/-(.*)-(.*)$ $2?sessionid=$1 [L,R,QSA] 
    </VirtualHost> 
    <VirtualHost ipaddress> 
    DocumentRoot /usr/local/www/domain2 
    ServerName www.domain2.com 
    RewriteEngine on 
    RewriteRule ^/-(.*)-(.*?.*)$ $2&sessionid=$1 [L,R,QSA] 
    RewriteRule ^/-(.*)-(.*)$ $2?sessionid=$1 [L,R,QSA] 
    </VirtualHost>  
  這些重寫的規則實現了上面兩個URL重寫的要求。

php技術PHP中cookies使用指南,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 日韩在线av免费视久久 | 一级做a爰片久久毛片免费 一级做a爰片久久毛片潮喷动漫 | 9国产露脸精品国产麻豆 | 亚洲午夜AV久久久精品影院色戒 | 亚洲国产精品热久久 | 最近的2019中文字幕国语 | 干丝袜美女 | 中文字幕人成人乱码亚洲影视S | 免费特黄一区二区三区视频一 | 亚洲七七久久桃花综合 | 国产精品嫩草影院一区二区三区 | 国产精品久久久久久久久无码 | 午夜成a人片在线观看 | 妈妈的职业3完整版在线播放 | 亚洲色大成网站WWW永久麻豆 | 国产99久久 | 四虎亚洲中文字幕永久在线 | 亚洲欧美日韩人成 | 领导边摸边吃奶边做爽在线观看 | 色琪琪无码成人AV视频 | 无限资源网免费看 | free性欧美xxx狂欢 | 成人a毛片久久免费播放 | 亚洲七七久久桃花综合 | 国产白丝精品爽爽久久久久久蜜臀 | 成人免费毛片观看 | 两个人的视频日本在线观看完整 | 18美女腿打开无遮软件 | 日本特交大片免费观看 | 校园全肉高h湿一女多男 | 国产免费变态视频网址网站 | 黑人巨大两根一起挤进欧美 | 国产精品一区二区AV白丝在线 | 女子叉开腿让男子桶免费软件 | 亚洲日韩视频免费观看 | 日本熟妇乱人伦A片精品软件 | 久久免费电影 | 日韩精品AV一区二区三区 | 毛片在线网址 | 天天躁日日躁狠狠躁午夜剧场 | 国产亚洲精品成人a在线 |