一个比较蛋疼的php缓存类

php缓存类
$oFC = new FileCache();
$sKey = 'ab_123';
$data = $oFC -> get($sKey);
if (is_null($data))
$oFC -> set($sKey, array('name' => 'ttt', 'datetime' => date('Y-m-d H:i:s')), 100000);
print_r($data);

 

	<?php
final class FileCache
{
    /**
     * * * 缓存目录 *
     *
     * @var string
     */
    private static $msCachePath = null;
    /**
     * * * 默认缓存失效时间(1小时) *
     *
     * @var int
     */
    const miEXPIRE = 3600;
    /**
     * * * 构造<br /> * self::$msCachePath 缓存目录为共享目录 *
     *
     * @param string $sCachePath
     */
    function __construct($sCachePath = './tmp/')
    {
        if (is_null(self :: $msCachePath))
            self :: $msCachePath = $sCachePath;
    }
    /**
     * * * 读取缓存<br /> * 返回: 缓存内容,字符串或数组;缓存为空或过期返回null *
     *
     * @param string $sKey 缓存键值(无需做md5()) *
     * @return string  null *
     * @access public
     */
    public function get($sKey)
    {
        if (empty($sKey))
            return false;
        $sFile = self :: getFileName($sKey);
        if (!file_exists($sFile))
            return null;
        else
        {
            $handle = fopen($sFile, 'rb');

            if (intval(fgets($handle)) > time())
            {
                // 检查时间戳 {	//未失效期,取出数据
                $sData = fread($handle, filesize($sFile));
                fclose($handle);
                return unserialize($sData);
            }
            else
            {
                // 已经失效期
                fclose($handle);
                return null;
            }
        }
    }
    /**
     * 写入缓存 * *
     *
     * @param string $sKey 缓存键值 *
     * @param mixed $mVal 需要保存的对象 *
     * @param int $iExpire 失效时间 *
     * @return bool
     * @access public
     */
    public function set($sKey, $mVal, $iExpire = null)
    {
        if (empty($sKey))
            return false;
        $sFile = self :: getFileName($sKey);
        if (!file_exists(dirname($sFile)))
            if (!self :: is_mkdir(dirname($sFile)))
                return false;
            $aBuf = array();
            $aBuf[] = time() + ((empty($iExpire)) ? self :: miEXPIRE : intval($iExpire));
            $aBuf[] = serialize($mVal);
            /**
             * 写入文件操作
             */
            $handle = fopen($sFile, 'wb');
            fwrite($handle, implode("\n", $aBuf));
            fclose($handle);
            return true;
        }
        /**
         * * * 删除指定的缓存键值 *
         *
         * @param string $sKey 缓存键值
         * @return bool
         */

        public function del($sKey)
        {
            if (empty($sKey))
                return false;
            else
            {
                @unlink (self :: getFileName($sKey));
                return true;
            }
        }
        /**
         * * * 获取缓存文件全路径<br /> * 返回: 缓存文件全路径<br /> * $sKey的值会被转换成md5(),并分解为3级目录进行访问 *
         *
         * @param string $sKey 缓存键 *
         * @return string
         * @access protected
         */

        private static function getFileName($sKey)
        {
            if (empty($sKey)) return false;
            $key_md5 = md5($sKey);
            /**
             * $aFileName = array();
             * $aFileName[] = rtrim(self :: $msCachePath, '/');
             * $aFileName[] = $key_md5{0} . $key_md5{1};
             * $aFileName[] = $key_md5{2} . $key_md5{3};
             * $aFileName[] = $key_md5{4} . $key_md5{5};
             * $aFileName[] = $key_md5;
             */
            return self :: $msCachePath . '/' . $key_md5;
            // return implode('/', $aFileName);
        }
        /**
         * * * 创建目录<br /> * *
         *
         * @param string $sDir
         * @return bool
         */
        private static function is_mkdir($sDir = '')
        {
            if (empty($sDir))
                return false;
            /**
             * 如果无法创建缓存目录,让系统直接抛出错误提示
             */
            echo $sDir;
            if (!mkdir($sDir, 0666))
                return false;
            else
                return true;
        }
    }
    

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索php
, 缓存
, datetime
, 蛋疼
, data
, print_r
is_null
php 缓存类、php文件缓存类、php文件缓存类映射、php 缓存类型、php 缓存类 多级目录,以便于您获取更多的相关知识。

时间: 2024-12-05 11:13:58

一个比较蛋疼的php缓存类的相关文章

一个简洁实用的PHP缓存类完整实例_php技巧

本文完整描述了一个简洁实用的PHP缓存类,可用来检查缓存文件是否在设置更新时间之内.清除缓存文件.根据当前动态文件生成缓存文件名.连续创建目录.缓存文件输出静态等功能.对于采用PHP开发CMS系统来说,离不开对缓存的处理,合理利用好缓存可有效的提高程序执行效率. php缓存类文件完整代码如下: <?php /* * 缓存类 cache */ class cache { //缓存目录 var $cacheRoot = "./cache/"; //缓存更新时间秒数,0为不缓存 var

一个简单至极的PHP缓存类代码_php技巧

网上关于 PHP 缓存类的资料很多,不过这个类应该是我见过功能满足需求,但又无比简洁的一个.废话不多说,直接看代码吧!使用说明:1.实例化$cache = new Cache(); 2.设置缓存时间和缓存目录$cache = new Cache(60, '/any_other_path/'); 第一个参数是缓存秒数,第二个参数是缓存路径,根据需要配置. 默认情况下,缓存时间是 3600 秒,缓存目录是 cache/3.读取缓存$value = $cache->get('data_key'); 4

html-本人菜鸟一枚,请教大神一个关于CSS中ID和类选择器不能用,而标签选择器能用的问题

问题描述 本人菜鸟一枚,请教大神一个关于CSS中ID和类选择器不能用,而标签选择器能用的问题 FIREFOX浏览器,代码如下: HTML代码片段: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> @import url(template/default/styl

读写锁和缓存类实现

提高性能 读写锁:分为读锁和写锁,多个读锁不互斥,读锁与写锁互斥,写锁与写锁互斥,这是由JVM控制的,我们只需要上好相应的锁即可.如果代码只读数据,可以很多人同时读,但不能同时写,那就上读锁:如果代码修改数据,只能有一个人在写,且不能同时读取,那就上写锁.总之,读的时候上读锁,写的时候上写锁. import java.util.Random; import java.util.concurrent.locks.ReadWriteLock; import java.util.concurrent.

缓存类的实现(C#)

缓存 小弟最近在编写一个O/RM组件(当然功能还是相当少的).大家都应该清楚把实体对象更新到数据库必须经过一系列的转换:特别是SQL语句的生成是比较费资源的,因为中间处里的东西实大是太多了.在设计的过程中我就想如果一个对象插入数据库后把相应的Command保存在缓存中:下一次同一个类型的对象做这个操作时检测一下缓存如果有就直接拿来用这样效率应该会高些.抱着这种想法就开始设计了(不过心里还是上上下下的,毕竟第一次尝试).因为缓存中的对象处理比较复杂点,在多线程中存在共享的问题,如果两个线程同时调用

简单的php缓存类分享

 这篇文章主要介绍了一个php缓存类,文件名使用md5加密,大家参考使用吧 代码如下: <?php class Cache  {  private $dir = "data/cache/";//定义缓存目录   private $key='c_a_sss'; // 文件名md5加密密钥    function set_dir($dirpath)  {   $this->dir=$dirpath;   $this->make_dir($this->dir);  }

iOS网络编程之六——数据缓存类NSURLCache使用解析

iOS网络编程之六--数据缓存类NSURLCache使用解析 一.引言         在前面博客中,介绍了NSURLRequest请求类的相关使用方法,其中有介绍关于请求返回数据的缓存策略,实际上,iOS中具体缓存操作的管理是由NSURLCache类来实现的.NSURLRequest类介绍的博客地址如下: iOS中NSURLRequest相关使用:http://my.oschina.net/u/2340880/blog/620225. 二.NSURLCache中方法与属性 ? 1 2 3 4

ASP.NET Core 折腾笔记二:自己写个完整的Cache缓存类来支持.NET Core

背景: 1:.NET Core 已经没System.Web,也木有了HttpRuntime.Cache,因此,该空间下Cache也木有了. 2:.NET Core 有新的Memory Cache提供,不过该内存类我看了一下,并没有支持文件的缓存依赖. 因此,在此前提下,预计.NET Core明年出来2.0版本时,可能也没支持文件的缓存依赖,因此,有必要提前准备实现. 在写此文前,我扫了一下园子里关于自定义缓存类的相关文章. 发现很多自定义的缓存类文章都简单停留在对字典的增删改查. 因此,决定补充

php文件缓存类实例整理

例1  代码如下 复制代码 <?php $fzz = new fzz_cache; $fzz->kk = $_SERVER; //写入缓存 //$fzz->set("kk",$_SERVER,10000); //此方法不与类属性想冲突,可以用任意缓存名: print_r($fzz->kk);  //读取缓存 //print_r($fzz->get("kk")); //unset($fzz->kk); //删除缓存 //$fzz-&