本cookies操作类的功能,包括:

1,保存,读取,更新,清除cookies数据。

2,可设置前缀。

3,强制超时控制。

4,cookies数据可以是字符串,数组,对象等。

1,PHP cookies操作类 Cookies.class.php

复制代码 代码示例:

/** Cookies class 保存,读取,更新,清除cookies数据。可设置前缀。强制超时。数据可以是字符串,数组,对象等。

*   Date:   2013-12-22

*   Author: fdipzone

*   Ver:    1.0

*   Edit: www.jbxue.com

*   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()

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

?>

2,演示示例 demo.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 '

';

print_r($result);

echo '

';

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 Cookies操作类的源码下载地址

php强制cookies,php Cookies操作类(附源码)相关推荐

  1. PHP密码生成管理源码,php密码生成类(附源码)

    本节内容: 好用的php 密码生成类. 访代码实现的功能: 1,可设定密码长度. 2,可设定要生成的密码个数,批量生成. 3,可以指定密码的规则,字母,数字,特殊字符等. 1,密码生成类文件 Gene ...

  2. Android中SQLiteDatabase操作【附源码】

    像我们做的很多应用程序及网站一样,基本都是对数据库进行增删改查来实现相应的功能.那么Android开发也一样,不过由于在移动客户端应用,所以不会像sql server.mysql那么复杂,Androi ...

  3. 使用jsonp跨域调用百度js实现搜索框智能提示,并实现鼠标和键盘对弹出框里候选词的操作【附源码和在线测试地址】

    项目中常常用到搜索,特别是导航类的网站.自己做关键字搜索不太现实,直接调用百度的是最好的选择. 使用jquery.ajax的jsonp方法可以异域调用到百度的js并拿到返回值,当然$.getScrip ...

  4. C# 操作FireBird 附源码

    写了一个C#操作firebird数据库的小Demo,有需要的可以研究研究, 步骤: 1.创建数据库 2.建数据表,插入数据,并读取. 写的时候碰到N多奇葩问题,记录了一些 解决方案: 程序集-生成-目 ...

  5. php 断点续传,php支持断点续传的文件下载类(附源码)

    /** php下载类,支持断点续传 * Date: 2013-06-30 * Author: fdipzone * Ver: 1.0 * edit: ww.jbxue.com * Func: * do ...

  6. web和mysql连接并增删改查_Java Web 使用IDEA对mysql数据库进行简单增删改查操作(附源码下载)...

    一.加载数据库驱动 1.下载jdbc(如已下载可略过此步骤) (1)点击下载网址,选择Connector/J (2)选择Platform Independent版本 (3)下载下图所示的压缩包 2.将 ...

  7. Python数据分析实战-提取DataFrame(Excel)某列(字段)最全操作(附源码和实现效果)

    实现功能: Python数据分析实战-提取DataFrame(Excel)某列(字段)最全操作,代码演示了单列提取和多列提取两种情况,其中单列提取有返回series格式和dataframe两种情况,在 ...

  8. python算公倍数的案例_【71页】关于python经典的80个案例操作(附源码解析)

    1.Python Hello World 实例 # -*- coding: UTF-8 -*- # Filename : helloworld.py # author by : www.runoob. ...

  9. Python对带光晕的图像进行去黑底黑色背景操作(附源码)

    由于计算机图像一开始使用的颜色系统,是不包含透明度通道的,因此一些比较老的游戏里面的发光特效依然沿用基于线性减淡的图层混合方法来实现.对,说的就是你,DNF.在下发链接中大佬对此进行了科普. 去黑底和 ...

最新文章

  1. SAP ECC6.0-中建信息版
  2. python应该怎么自学-学习Python最正确的步骤
  3. 高手请进关于RAID和热备
  4. Android监听WIFI信号,这可能是Android上monitore Wifi信号强度的最佳方法
  5. python观察内存和修改内存
  6. 不定长数组取值交叉遍历组合生成算法
  7. 华为再发行30亿元超短期融资券
  8. AIR通过mx:html访问本地image
  9. vue 如何调用微信分享_Vue开发 添加微信分享功能(全局分享)
  10. CF1132G Greedy Subsequences
  11. [转贴]在C#中应用哈希表(Hashtable)
  12. caffe中pad的作用
  13. 条件编译#ifndef和#endif
  14. JavaScript编程风格 (share)
  15. 一本通————1244 和为给定数
  16. Win10系统优化工具
  17. 图说Python菜鸟版:第18章 JSON文件解析
  18. Person Re-identification using Heterogeneous Local Graph Attention Networks(基于异构局部图注意力网络的人员再识别)
  19. 王石:中国楼市泡沫必破 目前只是时间问题
  20. 【Python】一元线性回归的分析

热门文章

  1. TensorFlow报错:'dict' object has no attribute 'SerializeToString'
  2. PHP之MVC项目实战
  3. 《Python 黑科技》10万粉丝头像千图成像(撩对象)
  4. 内网穿透 --- frp
  5. VS2019 使用 C/C++ 动态链接库 并 进行调用
  6. C++学习之路 | PTA乙级—— 1035 插入与归并 (25 分)(精简)
  7. js生日计算年龄_你知道用EXCEL可以从身份证中提取生日、性别、年龄、生肖吗?...
  8. 基础知识很扎实 - 但是面试就是做不出来, 怎么办? (长, 慎入)
  9. 最近公共祖先_leetcode No.236 二叉树的最近公共祖先
  10. 服务器开设虚拟主机,服务器自动开设虚拟主机