백엔드 개발 PHP 튜토리얼 如何使用数据库实现PHP保存session_PHP教程

如何使用数据库实现PHP保存session_PHP教程

Jul 15, 2016 pm 01:32 PM
php session 사용 저장 어떻게 성취하다 데이터 베이스 문서 방법 용적 ~의 기본

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">?&gt;</span><span> </span>
</li>
</ol>
로그인 후 복사

保存成为session_user_start.PHP。

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


www.bkjia.comtruehttp://www.bkjia.com/PHPjc/446131.htmlTechArticlePHP保存session默认的是采用的文件的方式来保存的,这仅仅在文件的空间开销很小的windows上是可以采用的,但是如果我们采用uinx或者是liu...
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Dec 24, 2024 pm 04:42 PM

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드

CakePHP 날짜 및 시간 CakePHP 날짜 및 시간 Sep 10, 2024 pm 05:27 PM

CakePHP 날짜 및 시간

CakePHP 프로젝트 구성 CakePHP 프로젝트 구성 Sep 10, 2024 pm 05:25 PM

CakePHP 프로젝트 구성

CakePHP 파일 업로드 CakePHP 파일 업로드 Sep 10, 2024 pm 05:27 PM

CakePHP 파일 업로드

CakePHP 라우팅 CakePHP 라우팅 Sep 10, 2024 pm 05:25 PM

CakePHP 라우팅

CakePHP 토론 CakePHP 토론 Sep 10, 2024 pm 05:28 PM

CakePHP 토론

PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 Dec 20, 2024 am 11:31 AM

PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법

CakePHP 빠른 가이드 CakePHP 빠른 가이드 Sep 10, 2024 pm 05:27 PM

CakePHP 빠른 가이드

See all articles