php实现的Cookies操作类实例


Posted in PHP onSeptember 24, 2014

本文实例讲述了PHP实现的Cookies操作类及其用法,分享给大家供大家参考。具体分析如下:

一、功能:

1.保存,读取,更新,清除cookies数据。
2.可设置前缀。
3.强制超时控制。
4.cookies数据可以是字符串,数组,对象等。

二、用法:

Cookies.class.php类文件如下:

<?php 
/** Cookies class 保存,读取,更新,清除cookies数据。可设置前缀。强制超时。数据可以是字符串,数组,对象等。 
*  Date:  2013-12-22 
*  Author: fdipzone 
*  Ver:  1.0 
* 
*  Func: 
*  public  set    设置cookie 
*  public  get    读取cookie 
*  public  update   更新cookie 
*  public  clear   清除cookie 
*  public  setPrefix 设置前缀 
*  public  setExpire 设置过期时间 
*  private authcode  加密/解密 
*  private pack    将数据打包 
*  private unpack   将数据解包 
*  private getName  获取cookie name,增加prefix处理 
*/ 
 
class Cookies{ // class start 
 
  private $_prefix = '';                         // cookie prefix 
  private $_securekey = 'ekOt4_Ut0f3XE-fJcpBvRFrg506jpcuJeixezgPNyALm';  // encrypt key 
  private $_expire = 3600;                        // default expire 
 
  /** 初始化 
  * @param String $prefix   cookie prefix 
  * @param int  $expire   过期时间 
  * @param String $securekey cookie secure key 
  */ 
  public function __construct($prefix='', $expire=0, $securekey=''){ 
 
    if(is_string($prefix) && $prefix!=''){ 
      $this->_prefix = $prefix; 
    } 
 
    if(is_numeric($expire) && $expire>0){ 
      $this->_expire = $expire; 
    } 
 
    if(is_string($securekey) && $securekey!=''){ 
      $this->_securekey = $securekey; 
    } 
 
  } 
 
  /** 设置cookie 
  * @param String $name  cookie name 
  * @param mixed $value cookie value 可以是字符串,数组,对象等 
  * @param int  $expire 过期时间 
  */ 
  public function set($name, $value, $expire=0){ 
 
    $cookie_name = $this->getName($name); 
    $cookie_expire = time() + ($expire? $expire : $this->_expire); 
    $cookie_value = $this->pack($value, $cookie_expire); 
    $cookie_value = $this->authcode($cookie_value, 'ENCODE', $this->_securekey); 
 
    if($cookie_name && $cookie_value && $cookie_expire){ 
      setcookie($cookie_name, $cookie_value, $cookie_expire); 
    } 
 
  } 
 
  /** 读取cookie 
  * @param String $name  cookie name 
  * @return mixed     cookie value 
  */ 
  public function get($name){ 
 
    $cookie_name = $this->getName($name); 
 
    if(isset($_COOKIE[$cookie_name])){ 
 
      $cookie_value = $this->authcode($_COOKIE[$cookie_name], 'DECODE', $this->_securekey); 
      $cookie_value = $this->unpack($cookie_value); 
 
      return isset($cookie_value[0])? $cookie_value[0] : null; 
 
    }else{ 
      return null; 
    } 
 
  } 
 
  /** 更新cookie,只更新内容,如需要更新过期时间请使用set方法 
  * @param String $name  cookie name 
  * @param mixed $value cookie value 
  * @return boolean 
  */ 
  public function update($name, $value){ 
 
    $cookie_name = $this->getName($name); 
 
    if(isset($_COOKIE[$cookie_name])){ 
 
      $old_cookie_value = $this->authcode($_COOKIE[$cookie_name], 'DECODE', $this->_securekey); 
      $old_cookie_value = $this->unpack($old_cookie_value); 
 
      if(isset($old_cookie_value[1]) && $old_cookie_vlaue[1]>0){ // 获取之前的过期时间 
 
        $cookie_expire = $old_cookie_value[1]; 
 
        // 更新数据 
        $cookie_value = $this->pack($value, $cookie_expire); 
        $cookie_value = $this->authcode($cookie_value, 'ENCODE', $this->_securekey); 
 
        if($cookie_name && $cookie_value && $cookie_expire){ 
          setcookie($cookie_name, $cookie_value, $cookie_expire); 
          return true; 
        } 
      } 
    } 
    return false; 
  } 
 
  /** 清除cookie 
  * @param String $name  cookie name 
  */ 
  public function clear($name){ 
 
    $cookie_name = $this->getName($name); 
    setcookie($cookie_name); 
  } 
 
  /** 设置前缀 
  * @param String $prefix cookie prefix 
  */ 
  public function setPrefix($prefix){ 
 
    if(is_string($prefix) && $prefix!=''){ 
      $this->_prefix = $prefix; 
    } 
  } 
 
  /** 设置过期时间 
  * @param int $expire cookie expire 
  */ 
  public function setExpire($expire){ 
 
    if(is_numeric($expire) && $expire>0){ 
      $this->_expire = $expire; 
    } 
  } 
 
  /** 获取cookie name 
  * @param String $name 
  * @return String 
  */ 
  private function getName($name){ 
    return $this->_prefix? $this->_prefix.'_'.$name : $name; 
  } 
 
  /** pack 
  * @param Mixed $data   数据 
  * @param int  $expire  过期时间 用于判断 
  * @return 
  */ 
  private function pack($data, $expire){ 
 
    if($data===''){ 
      return ''; 
    } 
 
    $cookie_data = array(); 
    $cookie_data['value'] = $data; 
    $cookie_data['expire'] = $expire; 
    return json_encode($cookie_data); 
  } 
 
  /** unpack 
  * @param Mixed $data 数据 
  * @return       array(数据,过期时间) 
  */ 
  private function unpack($data){ 
 
    if($data===''){ 
      return array('', 0); 
    } 
 
    $cookie_data = json_decode($data, true); 
 
    if(isset($cookie_data['value']) && isset($cookie_data['expire'])){ 
 
      if(time()<$cookie_data['expire']){ // 未过期 
        return array($cookie_data['value'], $cookie_data['expire']); 
      } 
    } 
    return array('', 0); 
  } 
 
  /** 加密/解密数据 
  * @param String $str    原文或密文 
  * @param String $operation ENCODE or DECODE 
  * @return String      根据设置返回明文活密文 
  */ 
  private function authcode($string, $operation = 'DECODE'){ 
 
    $ckey_length = 4;  // 随机密钥长度 取值 0-32; 
 
    $key = $this->_securekey; 
 
    $key = md5($key); 
    $keya = md5(substr($key, 0, 16)); 
    $keyb = md5(substr($key, 16, 16)); 
    $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, $ckey_length): substr(md5(microtime()), -$ckey_length)) : '';
 
    $cryptkey = $keya.md5($keya.$keyc); 
    $key_length = strlen($cryptkey); 
 
    $string = $operation == 'DECODE' ? base64_decode(substr($string, $ckey_length)) : sprintf('%010d', 0).substr(md5($string.$keyb), 0, 16).$string; 
    $string_length = strlen($string); 
 
    $result = ''; 
    $box = range(0, 255); 
 
    $rndkey = array(); 
    for($i = 0; $i <= 255; $i++) { 
      $rndkey[$i] = ord($cryptkey[$i % $key_length]); 
    } 
 
    for($j = $i = 0; $i < 256; $i++) { 
      $j = ($j + $box[$i] + $rndkey[$i]) % 256; 
      $tmp = $box[$i]; 
      $box[$i] = $box[$j]; 
      $box[$j] = $tmp; 
    } 
 
    for($a = $j = $i = 0; $i < $string_length; $i++) { 
      $a = ($a + 1) % 256; 
      $j = ($j + $box[$a]) % 256; 
      $tmp = $box[$a]; 
      $box[$a] = $box[$j]; 
      $box[$j] = $tmp; 
      $result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256])); 
    } 
 
    if($operation == 'DECODE') { 
      if((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16)) { 
        return substr($result, 26); 
      } else { 
        return ''; 
      } 
    } else { 
      return $keyc.str_replace('=', '', base64_encode($result)); 
    } 
  } 
} // class end 
 
?>

demo.php示例程序如下:

<?php 
require 'Cookies.class.php'; 
 
$type = isset($_GET['type'])? strtolower($_GET['type']) : ''; 
 
if(!in_array($type, array('set','get','update','clear'))){ 
  exit('type not exists'); 
} 
 
$obj = new Cookies('member', 10); // obj 
 
switch($type){ 
 
  case 'set': // 设置 
    $data = array( 
      'name' => 'fdipzone', 
      'gender' => 'male' 
    ); 
    $obj->set('me', $data, 5); 
    echo 'set cookies'; 
    break; 
 
  case 'get': // 读取 
    $result = $obj->get('me'); 
 
    echo '<pre>'; 
    print_r($result); 
    echo '</pre>'; 
 
    echo 'get cookies'; 
    break; 
 
  case 'update': // 更新 
    $data = array( 
      'name' => 'angelababy', 
      'gender' => 'female' 
    ); 
    $flag = $obj->update('me', $data); 
 
    if($flag){ 
      echo 'update cookies success'; 
    }else{ 
      echo 'update cookies false'; 
    } 
 
    break; 
 
  case 'clear': // 清除 
    $obj->clear('me'); 
    echo 'clear cookies'; 
    break; 
}
?>

本文完整实例源码点击此处本站下载。

希望本文所述对大家的PHP程序设计有所帮助。

PHP 相关文章推荐
基于mysql的论坛(4)
Oct 09 PHP
php实现的简单压缩英文字符串的代码
Apr 24 PHP
php侧拉菜单 漂亮,可以向右或者向左展开,支持FF,IE
Oct 15 PHP
php中去除所有js,html,css代码
Oct 12 PHP
php设计模式 Command(命令模式)
Jun 26 PHP
用PHP书写安全的脚本代码
Feb 05 PHP
PHP中运用jQuery的Ajax跨域调用实现代码
Feb 21 PHP
使用php get_headers 判断URL是否有效的解决办法
Apr 27 PHP
php利用新浪接口查询ip获取地理位置示例
Jan 20 PHP
php的hash算法介绍
Feb 13 PHP
Zend Framework教程之动作的基类Zend_Controller_Action详解
Mar 07 PHP
在PHP中实现使用Guzzle执行POST和GET请求
Oct 15 PHP
PHP实现支持GET,POST,Multipart/form-data的HTTP请求类
Sep 24 #PHP
php过滤html标记属性类用法实例
Sep 23 #PHP
php广告加载类用法实例
Sep 23 #PHP
php实现根据url自动生成缩略图的方法
Sep 23 #PHP
php实现的支持imagemagick及gd库两种处理的缩略图生成类
Sep 23 #PHP
PHP图片库imagemagick安装方法
Sep 23 #PHP
安装ImageMagick出现error while loading shared libraries的解决方法
Sep 23 #PHP
You might like
造就帕卡马拉的帕卡斯是怎么被发现的
2021/03/03 咖啡文化
Email+URL的判断和自动转换函数
2006/10/09 PHP
PHP中实现汉字转区位码应用源码实例解析
2010/06/14 PHP
php实现汉字验证码和算式验证码的方法
2015/03/07 PHP
一文掌握PHP Xdebug 本地与远程调试(小结)
2019/04/23 PHP
jquerymobile checkbox及时刷新才能获取其准确值
2012/04/14 Javascript
javascript中字符串拼接详解
2014/09/26 Javascript
JavaScript字符串对象split方法入门实例(用于把字符串分割成数组)
2014/10/16 Javascript
JavaScript中发布/订阅模式的简单实例
2014/11/05 Javascript
js简单实现竖向tab选项卡的方法
2015/05/04 Javascript
jQuery实现点击按钮弹出可关闭层的浮动层插件
2015/09/19 Javascript
深入剖析JavaScript:Object类型
2016/05/10 Javascript
微信小程序 wx.request(接口调用方式)详解及实例
2016/11/23 Javascript
详解VUE 对element-ui中的ElTableColumn扩展
2018/03/28 Javascript
解决Angular2 router.navigate刷新页面的问题
2018/08/31 Javascript
Angular 利用路由跳转到指定页面的指定位置方法
2018/08/31 Javascript
浅谈Angular 观察者模式理解
2018/11/01 Javascript
详解Vue中使用Axios拦截器
2019/04/22 Javascript
JavaScript canvas绘制渐变颜色的矩形
2020/02/18 Javascript
实例解析Python设计模式编程之桥接模式的运用
2016/03/02 Python
深入探究Django中的Session与Cookie
2017/07/30 Python
pyqt5 comboBox获得下标、文本和事件选中函数的方法
2019/06/14 Python
python模式 工厂模式原理及实例详解
2020/02/11 Python
为什么称python为胶水语言
2020/06/16 Python
AmazeUI 手机版页面的顶部导航条Header与侧边导航栏offCanvas的示例代码
2020/08/19 HTML / CSS
One.com挪威:北欧成长最快的网络托管公司
2016/11/19 全球购物
什么是网络协议
2016/04/07 面试题
市场营销专业大学生职业生涯规划文
2014/03/06 职场文书
秋季校运会广播稿100字
2014/09/18 职场文书
在职员工证明书
2014/09/19 职场文书
小学班主任个人总结
2015/03/03 职场文书
评职称个人总结
2015/03/05 职场文书
行政介绍信范文
2015/05/04 职场文书
社会实践活动总结格式
2015/05/11 职场文书
2019员工保密协议书(3篇)
2019/09/23 职场文书
TypeScript 使用 Tuple Union 声明函数重载
2022/04/07 Javascript