php採用資料庫儲存session

來源:互聯網
上載者:User

  php儲存session 預設的是採用的檔案的方式來儲存的,這僅僅在檔案的空間開銷很小的windows上是可以採用的,但是如果我們採用uinx或者是liux上的檔案系統的時候,這樣的檔案系統的檔案空間開銷是很大的,然而session是要時時刻刻的使用的,大量的使用者酒藥建立很多的session檔案,這樣對整個的伺服器帶來效能問題,另一方面,如果伺服器起採用群集的方式的話就不能保持session的一致性,所以我們就緒要採用資料庫的方式來儲存session,這樣,不管有幾台伺服器同時使用,只要把他們的session儲存在一台資料庫伺服器上就可以儲存session的完整了,具體如何來實現請繼續看下去。

  php的session預設的情況下是採用的檔案方式來儲存的,我們在php的配製檔案php.ini中可以看到這樣的一行,session.save_handler="files",這樣的意思就是採用檔案來儲存session 的,要採用資料庫來儲存的話,我們需要修改成擁護模式,改稱 session.save_handler="use"就可以了,但是,這僅僅是說明我門沒有採用檔案的方式儲存session,我們還要選擇資料庫和建立資料庫的表。

  建立資料庫和資料庫的表結構,我們可以採用php可以使用的任何的資料庫,因為php和mysql的結合最好,我就使用mysql來做案例,當然根據你的需要可以改稱別的資料庫,同時因為mysql沒有事物的功能,這也比別的資料庫更快,然而儲存session 書、一 不許要事物處理的,再者裡我決的更好。

  建立資料庫  ,    CREATE DATABASE 'session'; 建立表結構 CREATE TABLE 'session'( id CHAR(30) NOT NULL  , 'user 'CHAR(30), data CHAR(3000) ,PARMIRY BY ('id') );
編寫php檔案

<?php
 $con =mysql_connection("127.0.0.1","user" , "pass");
        mysql_select_db("session");
function open($save_path, $session_name)
{
    return(true);
}
function close()
{
  return(true);
}
function read($id)
{
   if($result = mysql_query("SELECT * FROM session WHERE id='$id'"))
     {
        if($row = mysql_felth_row($result ))
           {  return $row["data"]; }
      }
   else
     {
      return "";
      }
}
function write($id, $sess_data)
{
  if($result = mysql_query("UPDATE session SET data='$sess_data' WHERE id='$id'"))
     {
        return true;
      }
   else
     {
      return false;
      }
}
function destroy($id)
{
 if($result = mysql_query("DELETE * FROM  session WHERE id='$id'"))
     {
        return true;
      }
   else
     {
      return false;
      }
}
/*********************************************
* WARNING - You will need to implement some *
* sort of garbage collection routine here.  *
*********************************************/
function gc($maxlifetime)
{
  return true;
}
session_set_save_handler("open", "close", "read", "write", "destroy", "gc");
session_start();
// proceed to use sessions normally
?>

  儲存成為session_user_start.php。

  現在我們的工作就已經完成了,只要你在需要在使用session的時候,把session_user_start.php。包含進來,注意,這個檔案一定要在檔案的第一行包含,然後就想使用檔案的session一樣的方法使用舊可以了。

  本文寫的倉促,如果有不對的地方請你提出寶貴的意見。歡迎你的斧正。



相關文章

E-Commerce Solutions

Leverage the same tools powering the Alibaba Ecosystem

Learn more >

11.11 Big Sale for Cloud

Get Unbeatable Offers with up to 90% Off,Oct.24-Nov.13 (UTC+8)

Get It Now >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。