찾다
백엔드 개발PHP 튜토리얼PHP 파일 캐싱 방법_php 팁 요약

为大家分享很全的php文件缓存,供大家参考,具体内容如下

<&#63;php 
class cache
{ 
 private static $_instance = null;

 protected $_options = array(
  'cache_dir'  => "./",
  'file_name_prefix' => 'cache',
  'mode'   => '1', //mode 1 为serialize model 2为保存为可执行文件
 ); 
 
 /**
  * 得到本类实例
  * 
  * @return Ambiguous
  */
 public static function getInstance()
 {
  if(self::$_instance === null)
  {
   self::$_instance = new self();
  }
  return self::$_instance;
 } 
 
 /**
  * 得到缓存信息
  * 
  * @param string $id
  * @return boolean|array
  */
 public static function get($id)
 {
  $instance = self::getInstance();
  
  //缓存文件不存在
  if(!$instance->has($id))
  {
   return false;
  }
  
  $file = $instance->_file($id);
  
  $data = $instance->_fileGetContents($file);
  
  if($data['expire'] == 0 || time() < $data['expire'])
  {
   return $data['contents'];
  }
  return false;
 }
 
 /**
  * 设置一个缓存
  * 
  * @param string $id 缓存id
  * @param array $data 缓存内容
  * @param int $cacheLife 缓存生命 默认为0无限生命
  */
 public static function set($id, $data, $cacheLife = 0)
 {
  $instance = self::getInstance();
  
  $time = time();
  $cache   = array();
  $cache['contents'] = $data;
  $cache['expire'] = $cacheLife === 0 &#63; 0 : $time + $cacheLife;
  $cache['mtime'] = $time;
  
  $file = $instance->_file($id);
  
  return $instance->_filePutContents($file, $cache);
 }
 
 /**
  * 清除一条缓存
  * 
  * @param string cache id  
  * @return void
  */ 
 public static function delete($id)
 {
  $instance = self::getInstance();
  
  if(!$instance->has($id))
  {
   return false;
  }
  $file = $instance->_file($id);
  //删除该缓存
  return unlink($file);
 }
 
 /**
  * 判断缓存是否存在
  * 
  * @param string $id cache_id
  * @return boolean true 缓存存在 false 缓存不存在
  */
 public static function has($id)
 {
  $instance = self::getInstance();
  $file  = $instance->_file($id);
  
  if(!is_file($file))
  {
   return false;
  }
  return true;
 }
 
 /**
  * 通过缓存id得到缓存信息路径
  * @param string $id
  * @return string 缓存文件路径
  */
 protected function _file($id)
 {
  $instance = self::getInstance();
  $fileNmae = $instance->_idToFileName($id);
  return $instance->_options['cache_dir'] . $fileNmae;
 } 
 
 /**
  * 通过id得到缓存信息存储文件名
  * 
  * @param $id
  * @return string 缓存文件名
  */
 protected function _idToFileName($id)
 {
  $instance = self::getInstance();
  $prefix = $instance->_options['file_name_prefix'];
  return $prefix . '---' . $id;
 }
 
 /**
  * 通过filename得到缓存id
  * 
  * @param $id
  * @return string 缓存id
  */
 protected function _fileNameToId($fileName)
 {
  $instance = self::getInstance();
  $prefix = $instance->_options['file_name_prefix'];
  return preg_replace('/^' . $prefix . '---(.*)$/', '$1', $fileName);
 }
 
 /**
  * 把数据写入文件
  * 
  * @param string $file 文件名称
  * @param array $contents 数据内容
  * @return bool 
  */
 protected function _filePutContents($file, $contents)
 {
  if($this->_options['mode'] == 1)
  {
   $contents = serialize($contents);
  }
  else 
  {
   $time = time(); 
   $contents = "<&#63;php\n".
     " // mktime: ". $time. "\n".
     " return ".
     var_export($contents, true).
     "\n&#63;>";
  }
  
  $result = false;
  $f = @fopen($file, 'w');
  if ($f) {
   @flock($f, LOCK_EX);
   fseek($f, 0);
   ftruncate($f, 0);
   $tmp = @fwrite($f, $contents);
   if (!($tmp === false)) {
    $result = true;
   }
   @fclose($f);
  }
  @chmod($file,0777);
  return $result;    
 }
 
 /**
  * 从文件得到数据
  * 
  * @param sring $file
  * @return boolean|array
  */
 protected function _fileGetContents($file)
 {
  if(!is_file($file))
  {
   return false;
  }
  
  if($this->_options['mode'] == 1)
  {
   $f = @fopen($file, 'r'); 
   @$data = fread($f,filesize($file));
   @fclose($f);
   return unserialize($data);
  }
  else
  {
   return include $file;
  }
 }
 
 /**
  * 构造函数
  */
 protected function __construct()
 {
 
 }
 
 /**
  * 设置缓存路径
  * 
  * @param string $path
  * @return self
  */
 public static function setCacheDir($path)
 {
  $instance = self::getInstance();
  if (!is_dir($path)) {
   exit('file_cache: ' . $path.' 不是一个有效路径 ');
  }
  if (!is_writable($path)) {
   exit('file_cache: 路径 "'.$path.'" 不可写');
  }
 
  $path = rtrim($path,'/') . '/';
  $instance->_options['cache_dir'] = $path;
  
  return $instance;
 }
 
 /**
  * 设置缓存文件前缀
  * 
  * @param srting $prefix
  * @return self
  */
 public static function setCachePrefix($prefix)
 {
  $instance = self::getInstance();
  $instance->_options['file_name_prefix'] = $prefix;
  return $instance;
 }
 
 /**
  * 设置缓存存储类型
  * 
  * @param int $mode
  * @return self
  */
 public static function setCacheMode($mode = 1)
 {
  $instance = self::getInstance();
  if($mode == 1)
  {
   $instance->_options['mode'] = 1;
  }
  else
  {
   $instance->_options['mode'] = 2;
  }
  
  return $instance;
 }
 
 /**
  * 删除所有缓存
  * @return boolean
  */
 public static function flush()
 {
  $instance = self::getInstance();
  $glob = @glob($instance->_options['cache_dir'] . $instance->_options['file_name_prefix'] . '--*');
  
  if(empty($glob))
  {
   return false;
  }
  
  foreach ($glob as $v)
  {
   $fileName = basename($v);
   $id = $instance->_fileNameToId($fileName);
   $instance->delete($id);
  }
  return true;
 }
}

/* 初始化设置cache的配置信息什么的 */
cache::setCachePrefix('core'); //设置缓存文件前缀
cache::setCacheDir('./cache'); //设置存放缓存文件夹路径

//模式1 缓存存储方式
//a:3:{s:8:"contents";a:7:{i:0;i:1;i:1;i:2;i:2;i:3;i:3;i:34;i:4;i:5;i:5;i:6;i:6;i:6;}s:6:"expire";i:0;s:5:"mtime";i:1318218422;}
//模式2 缓存存储方式
/*
 <&#63;php
 // mktime: 1318224645
 return array (
 'contents' => 
 array (
 0 => 1,
 1 => 2,
 2 => 3,
 3 => 34,
 4 => 5,
 5 => 6,
 6 => 6,
 ),
 'expire' => 0,
 'mtime' => 1318224645,
)
&#63;>
 * 
 * 
 */
cache::setCacheMode('2');

if(!$row = cache::get('zj2'))
{
 
 $array = array(1,2,3,34,5,6,6);
 $row = cache::set('zj2',$array);
}
// cache::flush(); 清空所有缓存

print_r($row);

文件缓存class

<&#63;php
/**
 * 文件缓存类
 * @author xiaojiong & 290747680@qq.com
 * @date 2011-08-17
 */
class cache
{
 const FILE_LIFE_KEY = 'FILE_LIFE_KEY';
  
 const CLEAR_ALL_KEY = 'CLEAR_ALL';
  
 static $_instance = null;
  
 protected $_options = array(
  'cache_dir' => './cache',
  'file_locking' => true,
  'file_name_prefix' => 'cache',
  'cache_file_umask' => 0777,
  'file_life' => 100000
 );
  
 static function &getInstance($options = array())
 {
  if(self::$_instance === null)
  {
   self::$_instance = new self($options);
  } 
  return self::$_instance;
 }
  
 /**
  * 设置参数
  * @param array $options 缓存参数
  * @return void
  */
 static function &setOptions($options = array())
 {
   return self::getInstance($options);
 }
  
 /**
  * 构造函数
  * @param array $options 缓存参数
  * @return void
  */
 private function __construct($options = array())
 {  
  if ($this->_options['cache_dir'] !== null) {
    
   $dir = rtrim($this->_options['cache_dir'],'/') . '/';
   $this->_options['cache_dir'] = $dir;
    
   if (!is_dir($this->_options['cache_dir'])) {
    mkdir($this->_options['cache_dir'],0777,TRUE);
   }
   if (!is_writable($this->_options['cache_dir'])) {
    exit('file_cache: 路径 "'. $this->_options['cache_dir'] .'" 不可写');
   }
   
  } else {
   exit('file_cache: "options" cache_dir 不能为空 ');
  }
 }
 
 /**
  * 设置缓存路径
  * @param string $value
  * @return void
  */
 static function setCacheDir($value)
 {
  $self = & self::getInstance();
   
  if (!is_dir($value)) {
   exit('file_cache: ' . $value.' 不是一个有效路径 ');
  }
  if (!is_writable($value)) {
   exit('file_cache: 路径 "'.$value.'" 不可写');
  }
  
  $value = rtrim($this->_options['cache_dir'],'/') . '/';
   
  $self->_options['cache_dir'] = $value;
 }
  
 /**
  * 存入缓存数据
  * @param array $data   放入缓存的数据
  * @param string $id   缓存id(又名缓存识别码)
  * @param cache_life   缓存时间
  * @return boolean True if no problem
  */
 static function save($data, $id = null, $cache_life = null)
 {
  $self = & self::getInstance();
  if (!$id) {
   if ($self->_id) {
    $id = $self->_id;
   } else {
    exit('file_cache:save() id 不能为空!');
   }
  }
  $time = time();
   
  if($cache_life) {
   $data[self::FILE_LIFE_KEY] = $time + $cache_life;
  }
  elseif
  ($cache_life != 0){
   $data[self::FILE_LIFE_KEY] = $time + $self->_options['file_life'];
  }
   
  $file = $self->_file($id);
   
  $data = "<&#63;php\n".
    " // mktime: ". $time. "\n".
    " return ".
    var_export($data, true).
    "\n&#63;>"
    ;
   
  $res = $self->_filePutContents($file, $data);
  return $res;
 }
  
  
 /**
  * 得到缓存信息
  *
  * @param string $id 缓存id
  * @return string|array 缓存数据
  */
 static function load($id)
 {
  $self = & self::getInstance();
  $time = time();
  //检测缓存是否存在
  if (!$self->test($id)) {
   // The cache is not hit !
   return false;
  }
   
  //全部清空识别文件
  $clearFile = $self->_file(self::CLEAR_ALL_KEY);
   
  $file = $self->_file($id);
   
  //判断缓存是否已被全部清除
  if(is_file($clearFile) && filemtime($clearFile) > filemtime($file))
  {
   return false;
  }
  
  $data = $self->_fileGetContents($file);
  if(empty($data[self::FILE_LIFE_KEY]) || $time < $data[self::FILE_LIFE_KEY]) {
   unset($data[self::FILE_LIFE_KEY]); 
   return $data;   
  }
  return false;
 } 
  
 /**
  * 写入缓存文件
  *
  * @param string $file 缓存路径
  * @param string $string 缓存信息
  * @return boolean true 成功
  */
 protected function _filePutContents($file, $string)
 {
  $self = & self::getInstance();
  $result = false;
  $f = @fopen($file, 'ab+');
  if ($f) {
   if ($self->_options['file_locking']) @flock($f, LOCK_EX);
   fseek($f, 0);
   ftruncate($f, 0);
   $tmp = @fwrite($f, $string);
   if (!($tmp === false)) {
    $result = true;
   }
   @fclose($f);
  }
  @chmod($file, $self->_options['cache_file_umask']);
  return $result;
 }
  
 /**
  * 格式化后的缓存文件路径
  *
  * @param string $id 缓存id
  * @return string 缓存文件名(包括路径)
  */
 protected function _file($id)
 {
  $self = & self::getInstance();
  $fileName = $self->_idToFileName($id);
  return $self->_options['cache_dir'] . $fileName;
 } 
  
 /**
  * 格式化后的缓存文件名字
  *
  * @param string $id 缓存id
  * @return string 缓存文件名
  */
 protected function _idToFileName($id)
 {
  $self = & self::getInstance();
  $self->_id = $id;
  $prefix = $self->_options['file_name_prefix'];
  $result = $prefix . '---' . $id;
  return $result;
 } 
  
 /**
  * 判断缓存是否存在
  *
  * @param string $id Cache id
  * @return boolean True 缓存存在 False 缓存不存在
  */
 static function test($id)
 {
  $self = & self::getInstance();
  $file = $self->_file($id);
   
  if (!is_file($file)) {
   return false;
  }
   
  return true;
 }
  
 /**
  * 得到缓存信息
  *
  * @param string $file 缓存路径
  * @return string 缓存内容
  */
 protected function _fileGetContents($file)
 {
  if (!is_file($file)) {
   return false;
  }
  return include $file;
 }  
  
 /**
  * 清除所有缓存
  * 
  * @return void
  */ 
 static function clear()
 {
  $self = & self::getInstance();
  $self->save('CLEAR_ALL',self::CLEAR_ALL_KEY); 
 } 
  
 /**
  * 清除一条缓存
  * 
  * @param string cache id 
  * @return void
  */ 
 static function del($id)
 {
  $self = & self::getInstance();
  if(!$self->test($id)){
   // 该缓存不存在
   return false;
  }
  $file = $self->_file($id);
  return unlink($file);
 } 
}

存入数据

<&#63;php
$config = array(
 'name' => 'xiaojiong',
 'qq' => '290747680',
 'age' => '20',
);

//第一个参数 缓存data
//第二个参数 缓存id
//第三个参数 cache_life 0 永不过期(cache::clear()清空所有除外) 默认cache_life 为option_cache_life
cache::save($config,'config',0);

载入数据

<&#63;php
//只有一个参数 cache_id
$config = cache::load('config');

清空缓存

<&#63;php
//清空指定缓存
cache::del('config');
//清空所有缓存
cache::clear();

cache信息配置

//在执行所有cache_func前调用

$_options = array(
 'cache_dir' => './cache', //缓存文件目录
 'file_name_prefix' => 'cache',//缓存文件前缀
 'file_life' => 100000, //缓存文件生命
);
cache::setOptions($options);

//再执行 就会按着新配置信息执行,否则是默认信息
cache::save($arr,'arr');
//就是这个方法 貌似不合理 望大家指点

以上就是本文的全部内容,希望对大家的学习有所帮助。

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
세션을 저장하기 위해 데이터베이스를 사용하면 어떤 장점이 있습니까?세션을 저장하기 위해 데이터베이스를 사용하면 어떤 장점이 있습니까?Apr 24, 2025 am 12:16 AM

데이터베이스 스토리지 세션 사용의 주요 장점에는 지속성, 확장 성 및 보안이 포함됩니다. 1. 지속성 : 서버가 다시 시작 되더라도 세션 데이터는 변경되지 않아도됩니다. 2. 확장 성 : 분산 시스템에 적용하여 세션 데이터가 여러 서버간에 동기화되도록합니다. 3. 보안 : 데이터베이스는 민감한 정보를 보호하기 위해 암호화 된 스토리지를 제공합니다.

PHP에서 사용자 정의 세션 처리를 어떻게 구현합니까?PHP에서 사용자 정의 세션 처리를 어떻게 구현합니까?Apr 24, 2025 am 12:16 AM

SessionHandlerInterface 인터페이스를 구현하여 PHP에서 사용자 정의 세션 처리 구현을 수행 할 수 있습니다. 특정 단계에는 다음이 포함됩니다. 1) CustomsessionHandler와 같은 SessionHandlerInterface를 구현하는 클래스 만들기; 2) 인터페이스의 방법 (예 : Open, Close, Read, Write, Despare, GC)의 수명주기 및 세션 데이터의 저장 방법을 정의하기 위해 방법을 다시 작성합니다. 3) PHP 스크립트에 사용자 정의 세션 프로세서를 등록하고 세션을 시작하십시오. 이를 통해 MySQL 및 Redis와 같은 미디어에 데이터를 저장하여 성능, 보안 및 확장 성을 향상시킬 수 있습니다.

세션 ID 란 무엇입니까?세션 ID 란 무엇입니까?Apr 24, 2025 am 12:13 AM

SessionId는 웹 애플리케이션에 사용되는 메커니즘으로 사용자 세션 상태를 추적합니다. 1. 사용자와 서버 간의 여러 상호 작용 중에 사용자의 신원 정보를 유지하는 데 사용되는 무작위로 생성 된 문자열입니다. 2. 서버는 쿠키 또는 URL 매개 변수를 통해 클라이언트로 생성하여 보낸다. 3. 생성은 일반적으로 임의의 알고리즘을 사용하여 독창성과 예측 불가능 성을 보장합니다. 4. 실제 개발에서 Redis와 같은 메모리 내 데이터베이스를 사용하여 세션 데이터를 저장하여 성능 및 보안을 향상시킬 수 있습니다.

무국적 환경 (예 : API)에서 세션을 어떻게 처리합니까?무국적 환경 (예 : API)에서 세션을 어떻게 처리합니까?Apr 24, 2025 am 12:12 AM

JWT 또는 쿠키를 사용하여 API와 같은 무국적 환경에서 세션을 관리 할 수 ​​있습니다. 1. JWT는 무국적자 및 확장 성에 적합하지만 빅 데이터와 관련하여 크기가 크다. 2. 쿠키는보다 전통적이고 구현하기 쉽지만 보안을 보장하기 위해주의해서 구성해야합니다.

세션과 관련된 크로스 사이트 스크립팅 (XSS) 공격으로부터 어떻게 보호 할 수 있습니까?세션과 관련된 크로스 사이트 스크립팅 (XSS) 공격으로부터 어떻게 보호 할 수 있습니까?Apr 23, 2025 am 12:16 AM

세션 관련 XSS 공격으로부터 응용 프로그램을 보호하려면 다음 조치가 필요합니다. 1. 세션 쿠키를 보호하기 위해 Httponly 및 Secure 플래그를 설정하십시오. 2. 모든 사용자 입력에 대한 내보내기 코드. 3. 스크립트 소스를 제한하기 위해 컨텐츠 보안 정책 (CSP)을 구현하십시오. 이러한 정책을 통해 세션 관련 XSS 공격을 효과적으로 보호 할 수 있으며 사용자 데이터가 보장 될 수 있습니다.

PHP 세션 성능을 어떻게 최적화 할 수 있습니까?PHP 세션 성능을 어떻게 최적화 할 수 있습니까?Apr 23, 2025 am 12:13 AM

PHP 세션 성능을 최적화하는 방법 : 1. 지연 세션 시작, 2. 데이터베이스를 사용하여 세션을 저장, 3. 세션 데이터 압축, 4. 세션 수명주기 관리 및 5. 세션 공유 구현. 이러한 전략은 높은 동시성 환경에서 응용의 효율성을 크게 향상시킬 수 있습니다.

SESSION.GC_MAXLIFETIME 구성 설정은 무엇입니까?SESSION.GC_MAXLIFETIME 구성 설정은 무엇입니까?Apr 23, 2025 am 12:10 AM

THESESSION.GC_MAXLIFETIMESETTINGINSTTINGTINGSTINGTERMINESTERMINESTERSTINGSESSIONDATA, SETINSECONDS.1) IT'SCONFIGUDEDINPHP.INIORVIAINI_SET ()

PHP에서 세션 이름을 어떻게 구성합니까?PHP에서 세션 이름을 어떻게 구성합니까?Apr 23, 2025 am 12:08 AM

PHP에서는 Session_Name () 함수를 사용하여 세션 이름을 구성 할 수 있습니다. 특정 단계는 다음과 같습니다. 1. Session_Name () 함수를 사용하여 Session_Name ( "my_session")과 같은 세션 이름을 설정하십시오. 2. 세션 이름을 설정 한 후 세션을 시작하여 세션을 시작하십시오. 세션 이름을 구성하면 여러 응용 프로그램 간의 세션 데이터 충돌을 피하고 보안을 향상시킬 수 있지만 세션 이름의 독창성, 보안, 길이 및 설정 타이밍에주의를 기울일 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.