搜尋
首頁php教程php手册如何使用数据库实现PHP保存session

如何使用数据库实现PHP保存session

Jun 13, 2016 am 11:09 AM
phpsession使用保持如何實現資料庫文件方式用的預設

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保存session编写PHP文件

<ol class="dp-xml">
<li class="alt"><span class="tag"> ?PHP  </span></li>
<li>
<span>$</span><span class="attribute">con</span><span> =</span><span class="attribute-value">mysql_connection</span><span>("127.0.0.1"<br>,"user" , "pass");  </span>
</li>
<li class="alt"><span>mysql_select_db("session");  </span></li>
<li><span>function open($save_path, $session_name)   </span></li>
<li class="alt"><span>{  </span></li>
<li><span>return(true);  </span></li>
<li class="alt"><span>}  </span></li>
<li><span>function close()   </span></li>
<li class="alt"><span>{  </span></li>
<li><span>return(true);  </span></li>
<li class="alt"><span>}  </span></li>
<li><span>function read($id)   </span></li>
<li class="alt"><span>{  </span></li>
<li>
<span>if($</span><span class="attribute">result</span><span> = </span><span class="attribute-value">mysql_query</span><span>("select <br>* from session where </span><span class="attribute">id</span><span>=</span><span class="attribute-value">'$id'</span><span>"))  </span>
</li>
<li class="alt"><span>{  </span></li>
<li>
<span>if($</span><span class="attribute">row</span><span> = </span><span class="attribute-value">mysql_felth_row</span><span>($result ))  </span>
</li>
<li class="alt"><span>{ return $row["data"]; }  </span></li>
<li><span>}  </span></li>
<li class="alt"><span>else  </span></li>
<li><span>{  </span></li>
<li class="alt"><span>return "";  </span></li>
<li><span>}  </span></li>
<li class="alt"><span>}  </span></li>
<li><span>function write($id, $sess_data)   </span></li>
<li class="alt"><span>{  </span></li>
<li>
<span>if($</span><span class="attribute">result</span><span> = </span><span class="attribute-value">mysql_query</span><span>("update session <br>set </span><span class="attribute">data</span><span>=</span><span class="attribute-value">'$sess_data'</span><span> where </span><span class="attribute">id</span><span>=</span><span class="attribute-value">'$id'</span><span>"))  </span>
</li>
<li class="alt"><span>{  </span></li>
<li><span>return true;  </span></li>
<li class="alt"><span>}  </span></li>
<li><span>else  </span></li>
<li class="alt"><span>{  </span></li>
<li><span>return false;  </span></li>
<li class="alt"><span>}  </span></li>
<li><span>}  </span></li>
<li class="alt"><span>function destroy($id)   </span></li>
<li><span>{  </span></li>
<li class="alt">
<span>if($</span><span class="attribute">result</span><span> = </span><span class="attribute-value">mysql_query</span><span>("delete * <br>from session where </span><span class="attribute">id</span><span>=</span><span class="attribute-value">'$id'</span><span>"))  </span>
</li>
<li><span>{  </span></li>
<li class="alt"><span>return true;  </span></li>
<li><span>}  </span></li>
<li class="alt"><span>else  </span></li>
<li><span>{  </span></li>
<li class="alt"><span>return false;  </span></li>
<li><span>}  </span></li>
<li class="alt"><span>}  </span></li>
<li><span>function gc($maxlifetime)   </span></li>
<li class="alt"><span>{  </span></li>
<li><span>return true;  </span></li>
<li class="alt"><span>}  </span></li>
<li><span>session_set_save_handler("open", <br>"close", "read", "write", "destroy", "gc");  </span></li>
<li class="alt"><span>session_start();  </span></li>
<li><span>// proceed to use sessions normally  </span></li>
<li class="alt">
<span class="tag">?></span><span> </span>
</li>
</ol>

保存成为session_user_start.PHP。

现在我们的PHP保存session的工作就已经完成了,只要你在需要在使用session的时候,把session_user_start.PHP。包含进来,注意,这个文件一定要在文件的第一行包含,然后就像使用文件的session一样的方法使用就可以了。


陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡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

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

熱工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器