session 加入redis的实现代码_php实例

Session信息入redis

Session简介

session,中文经常翻译为会话,其本来的含义是 指有始有终的一系列动作/消息,比如打电话时从拿起电话拨号到挂断电话这中间的一系列过程可以称之为一个session。有时候我们可以看到这样的话“在 一个浏览器会话期间,...”,这里的会话一词用的就是其本义,是指从一个浏览器窗口打开到关闭这个期间①。最混乱的是“用户(客户端)在一次会话期间”这样一句话,它可能指用户的一系列动作(般情况下是同某个具体目的相关的一系列动作,比如从登录到选购商品到结账登出这样一个网上购物的过程,有时候也被称为一个transaction),然而有时候也可能仅仅是指一次连接,也有可能是指含义①,其中的差别只能靠上下文来推断②。

在本文中,使用中文“浏览器会话期间”来表达含义①,使用“session机制”来表达含义④,使用“session”表达含义⑤,使用具体的“HttpSession”来表达含义⑥

为什么要把SESSION保存在缓存

就php来说,语言本身支持的session是以文件的方式保存到磁盘文件中,保存在指定的文件夹中,保存的路径可以在配置文件中设置或者在程序中使用函数session_save_path()进行设置,但是这么做有弊端,
第一就是保存到文件系统中,效率低,只要有用到session就会从好多个文件中查找指定的sessionid,效率很低。
第二就是当用到多台服务器的时候可能会出现,session丢失问题(其实是保存在了其他服务器上)。
当然了,保存在缓存中可以解决上面的问题,如果使用php本身的session函数,可以使用 session_set_save_handler()函数很方便的对session的处理过程进行重新控制。如果不用php的session系列函数, 可以自己编写个类似的session函数,也是可以的,我现在做的这个项目就是这样,会根据用户的mid、登录时间进行求hash作为 sessionId,每次请求的时候都必须加上sessionId才算合法(第一次登录的时候是不需要的,这个时候会创建sessionId,返回给客户 端),这么做也很方便、简洁高效的。当然了,我这篇文章主要说的是在php自身的SESSION中”做做手脚”。

SESSION保存在缓存中

php将缓存保存到redis中,可以使用配置文件,对session的处理和保存做修改,当然了,在程序中使用ini_set()函数去修改也可以,这个很方便测试,我这里就使用这种方式,当然了,要是生产环境还是建议使用配置文件。

如果想简单操作session入redis操作可以将一下代码运行一下

<?php 

ini_set("session.save_handler", "redis"); 

ini_set("session.save_path", "tcp://localhost:6379"); 

session_start(); 

header("Content-type:text/html;charset=utf-8"); 

if(isset($_SESSION['view'])){ 

  $_SESSION['view'] = $_SESSION['view'] + 1; 

}else{ 

  $_SESSION['view'] = 1; 

} 

echo "【view】{$_SESSION['view']}"; 

//这里设置session.save_handler方式为redis,session.save_path为redis的地址和端口,设置之后刷新,再回头查看redis,会发现redis中的生成了sessionId,sessionId和浏览器请求的是一样的, 

//也可以使用 

Session_set_save_handler(‘open','close',' read',' write',' destory',' gc'); 

//用法如下自定义一个Redis_session类 

<?php 

class RedisSession{ 

  private $_redis = array( 

    'handler' => null, //数据库连接句柄 

    'host' => null,  //redis端口号 

    'port' => null, 

  ); 

  public function __construct($array = array()){ 

    isset($array['host'])?$array['host']:"false"; 

    isset($array['port'])?$array['host']:"false"; 

    $this->_redis = array_merge($this->_redis, $array); 

  } 

  public function begin(){ 

    //设置session处理函数 

    session_set_save_handler( 

      array($this, 'open'), 

      array($this, 'close'), 

      array($this, 'read'), 

      array($this, 'write'), 

      array($this, 'destory'), 

      array($this, 'gc') 

    ); 

  } 

  public function open(){ 

    $redis = new Redis(); 

    $redis->connect($this->_redis['host'], $this->_redis['port']); 

    if(!$redis){ 

      return false; 

    } 

    $this->_redis['handler'] = $redis; 

    $this->gc(null); 

    return true; 

  } 

  //关 

  public function close(){ 

    return $this->_redis['handler']->close(); 

  } 

  //读 

  public function read($session_id){ 

    return $this->_redis['handler']->get($session_id); 

  } 

  //写 

  public function write($sessionId, $sessionData){ 

    return $this->_redis['handler']->set($sessionId, $sessionData); 

  } 

  public function destory($sessionId){ 

    return $this->_redis['handler']->delete($sessionId) >= 1 ? true : false; 

  } 

  public function gc(){ 

    //获取所有sessionid,让过期的释放掉 

    $this->_redis['handler']->keys("*"); 

    return true; 

  } 

} 

$ses = new RedisSession(array('host'=>'127.0.0.1','port'=>'6379')); 

$ses->begin(); 

session_start(); 

$_SESSION['name']='zhangsan'; 

echo $_SESSION['name'];

这样就可以实现session数据如redis代码执行过程中必须安装redis才可以。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索php
session
redis实现session共享、redis实现session同步、redis 实现session、spring session redis、redis session共享,以便于您获取更多的相关知识。

时间: 2025-01-21 10:39:08

session 加入redis的实现代码_php实例的相关文章

使用PHP导出Redis数据到另一个Redis中的代码_php实例

从某个 Redis db 导出数据到另一个 Redis db 的PHP脚本: 复制代码 代码如下: $from = '127.0.0.1:6200/6';$to   = '127.0.0.1:6200/8'; $from_redis = redis_init($from);$to_redis   = redis_init($to); $keys  = $from_redis->keys('*');$count = 0;$total = count($keys);foreach($keys as

session 加入redis的实现代码

Session信息入redis Session简介 session,中文经常翻译为会话,其本来的含义是 指有始有终的一系列动作/消息,比如打电话时从拿起电话拨号到挂断电话这中间的一系列过程可以称之为一个session.有时候我们可以看到这样的话"在 一个浏览器会话期间,...",这里的会话一词用的就是其本义,是指从一个浏览器窗口打开到关闭这个期间①.最混乱的是"用户(客户端)在一次会话期间"这样一句话,它可能指用户的一系列动作(般情况下是同某个具体目的相关的一系列动

比较全的PHP 会话(session 时间设定)使用入门代码_php技巧

  对于 Cookie 来说,假设我们要验证用户是否登陆,就必须在 Cookie 中保存用户名和密码(可能是 md5 加密后字符串),并在每次请求页面的时候进行验证.如果用户名和密码存储在数据库,每次都要执行一次数据库查询,给数据库造成多余的负担.因为我们并不能 只做一次验证.为什么呢?因为客户端 Cookie 中的信息是有可能被修改的.假如你存储 $admin 变量来表示用户是否登陆,$admin 为 true 的时候表示登陆,为 false 的时候表示未登录,在第一次通过验证后将 $admi

CI框架中redis缓存相关操作文件示例代码_php实例

本文实例讲述了CI框架中redis缓存相关操作文件.分享给大家供大家参考,具体如下: redis缓存类文件位置: 'ci\system\libraries\Cache\drivers\Cache_redis.php' <?php /** * CodeIgniter * * An open source application development framework for PHP 5.2.4 or newer * * NOTICE OF LICENSE * * Licensed under

php同时使用session和cookie来保存用户登录信息的实现代码_php实例

1.用户登录状态操作类UserLogin <?php final class UserLogin { public function __construct() { } public static function getUserInfo() { if (isset($_COOKIE["user_id"])&&$_COOKIE["user_id"]&&(trim($_COOKIE["user_id"])!=&

PHP编写daemon process详解及实例代码_php实例

今天下午在segmentfault.com看到一个提问,提问标题是"PHP怎么做服务化",其中问道php是不是只能以web方式调用.其实很多人对PHP的使用场景都有误解,认为php只能用于编写web脚本,实际上,从PHP4开始,php的使用场景早已不限于处理web请求. 从php的架构体系来说,php分为三个层次:sapi.php core和zend engine.php core本身和web没有任何耦合,php通过sapi与其它应用程序通信,例如mod_php就是为apache编写的

PHP中如何使用session实现保存用户登录信息_php实例

session在php中是一个非常重要的东西,像我们用户登录一般都使用到session这个东西,相对于cookie来说session 要安全很多,同时我们购物车经常使用session来做临时的记录保存哦. 使用session保存页面登录信息 1.数据库连接配置页面:connectvars.php <?php //数据库的位置 define('DB_HOST', 'localhost'); //用户名 define('DB_USER', 'root'); //口令 define('DB_PASSW

PHP Cookei记录用户历史浏览信息的代码_php实例

[基础] Cookie常用方法: $_COOKIE['RecordLuHuiDUDU'] 得到Cookie setcookie('RecordLuHuiDUDU',",time()-3600*24*30); setcookie(字段名,数据,过期时间); 设置Cookie [注意] 重新设置Cookie需要使之前的Cookie失效,删除Cookie也是同样的方法: setcookie('RecordLuHuiDUDU',",time()-3600*24*30); [代码示例] /**

PHP Curl模拟登录微信公众平台、新浪微博实例代码_php实例

使用curl之前先打开curl配置,具体方式百度一下就知道,开启curl扩展.密码用md5加密,这是经过测试成功的,把用户跟密码改成你的就行了. 下面一段代码给大家介绍php使用curl模拟登录微信公众平台,具体代码如下所示: <?php //模拟微信登入 $cookie_file = tempnam('./temp','cookie'); $login_url = 'https://mp.weixin.qq.com/cgi-bin/login'; $pwd = md5("********