有否想过PHP使用redis
作为缓存时,如何能:
1.前后台模块共用Model层;
2.但是,不能每个Model类都进行缓存,这样太浪费Redis资源;
3.前后台模块可以自由决定从数据库还是从缓存读数据;
4.没有冗余代码;
5.使用方便。
这里我们先展示实现的最终效果。
最终的代码和使用说明请移步Github:https://github.com/yeszao/php-redis-cache。
马上安装使用命令:
$ composer install yeszao/cache
经过简单配置就可以使用,请参看Github的README说明。
1 最终效果
假设在MVC框架中,model
层有一个Book
类和一个getById
方法,如下:
class Book { public function getById($id) { return $id; } }
加入缓存技术之后,原来方法的调用方式和返回的数据结构都不应该改变。
所以,我们希望,最后的效果应该是这样的:
(new Book)->getById(100); // 原始的、不用缓存的调用方式,还是原来的方式,一般是读取数据库的数据。 (new Book)->getByIdCache(100); // 使用缓存的调用方式,缓存键名为:app_models_book:getbyid: + md5(参数列表) (new Book)->getByIdClear(100); // 删除这个缓存 (new Book)->getByIdFlush(); // 删除 getById() 方法对应的所有缓存,即删除 app_models_book:getbyid:*。这个方法不需要参数。
这样我们可以很清楚的明白自己在做什么,同时又知道数据的来源函数,并且被引用方式完全统一,可谓一箭三雕。
其实实现起来也比较简单,就是使用PHP的魔术方法__call()方法。
2 __call()方法
这里简单说明一下__call
方法的作用。
在PHP中,当我们访问一个不存在的类方法时,就会调用这个类的__call()
方法。
(如果类方法不存在,又没有写__call()
方法,PHP会直接报错)
假设我们有一个Book
类:
class Book { public function __call($name, $arguments) { echo '类Book不存在方法', $name, PHP_EOL; } public function getById($id) { echo '我的ID是', $id, PHP_EOL; } }
当调用存在的getName(50)
方法时,程序打印:我的ID是50。
而如果调用不存在的getAge()
方法时,程序就会执行到A类的__call()
方法里面,这里会打印:类Book不存在方法getAge。
这就是__call
的原理。
3 实现细节
接下来我们就利用__call()
方法的这种特性,来实现缓存策略。
从上面的例子,我们看到,__call()
方法被调用时,会传入两个参数。
$name
:想要调用的方法名$arguments
:参数列表
我们就可以在参数上面做文章。
还是以Book
类为例,我们假设其原本结构如下:
class Book { public function __call($name, $arguments) { // 待填充内容 } public function getById($id) { return ['id' => $id, 'title' => 'PHP缓存技术' . $id]; } }
开始之前,我们还确认Redis的连接,这是缓存必须用到的,这里我们写个简单的单例类:
class Common { private static $redis = null; public static function redis() { if (self::$redis === null) { self::$redis = new \Redis('127.0.0.1'); self::$redis->connect('redis'); } return self::$redis; }
然后,我们开始填充__call()
方法代码,具体说明请看注释:
class Book { public function __call($name, $arguments) { // 因为我们主要是根据方法名的后缀决定具体操作, // 所以如果传入的 $name 长度小于5,可以直接报错 if (strlen($name) get($key); // 如果Redis中有数据 if ($data !== false) { $decodeData = json_decode($data, JSON_UNESCAPED_UNICODE); // 如果不是JSON格式的数据,直接返回,否则返回json解析后的数据 return $decodeData === null ? $data : $decodeData; } // 如果Redis中没有数据则继续往下执行 // 如果原方法不存在 if (method_exists($this, $method) === false) { exit('Method does not exist.'); } // 调用原方法获取数据 $data = call_user_func_array([$this, $method], $arguments); // 保存数据到Redis中以便下次使用 Common::redis()->set($key, json_encode($data), 3600); // 结束执行并返回数据 return $data; break; case 'Clear': // 缓存键名加上$arguments $key = $key . md5(json_encode($arguments)); return Common::redis()->del($key); break; case 'Flush': $key = $key . '*'; // 获取所有符合 $class:$method:* 规则的缓存键名 $keys = Common::redis()->keys($key); return Common::redis()->del($keys); break; default: exit('Method does not exist.'); } } // 其他方法 }
这样就实现了我们开始时的效果。
4 实际使用时
在实际使用中,我们需要做一些改变,把这一段代码归入一个类中,
然后在model层的基类中引用这个类,再传入Redis句柄、类对象、方法名和参数,
这样可以降低代码的耦合,使用起来也更灵活。
完整的代码已经放在Github上,请参考文章开头的参考地址。
推荐学习:《PHP视频教程》
以上がPHP+Redis キャッシュ テクノロジの概要 [手順]の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

データベースストレージセッションを使用することの主な利点には、持続性、スケーラビリティ、セキュリティが含まれます。 1。永続性:サーバーが再起動しても、セッションデータは変更されないままになります。 2。スケーラビリティ:分散システムに適用され、セッションデータが複数のサーバー間で同期されるようにします。 3。セキュリティ:データベースは、機密情報を保護するための暗号化されたストレージを提供します。

PHPでのカスタムセッション処理の実装は、SessionHandlerInterfaceインターフェイスを実装することで実行できます。具体的な手順には、次のものが含まれます。1)CussentsessionHandlerなどのSessionHandlerInterfaceを実装するクラスの作成。 2)セッションデータのライフサイクルとストレージ方法を定義するためのインターフェイス(オープン、クローズ、読み取り、書き込み、破壊、GCなど)の書き換え方法。 3)PHPスクリプトでカスタムセッションプロセッサを登録し、セッションを開始します。これにより、データをMySQLやRedisなどのメディアに保存して、パフォーマンス、セキュリティ、スケーラビリティを改善できます。

SessionIDは、ユーザーセッションのステータスを追跡するためにWebアプリケーションで使用されるメカニズムです。 1.ユーザーとサーバー間の複数のインタラクション中にユーザーのID情報を維持するために使用されるランダムに生成された文字列です。 2。サーバーは、ユーザーの複数のリクエストでこれらの要求を識別および関連付けるのに役立つCookieまたはURLパラメーターを介してクライアントに生成および送信します。 3.生成は通常、ランダムアルゴリズムを使用して、一意性と予測不可能性を確保します。 4.実際の開発では、Redisなどのメモリ内データベースを使用してセッションデータを保存してパフォーマンスとセキュリティを改善できます。

APIなどのステートレス環境でのセッションの管理は、JWTまたはCookieを使用して達成できます。 1。JWTは、無国籍とスケーラビリティに適していますが、ビッグデータに関してはサイズが大きいです。 2.cookiesはより伝統的で実装が簡単ですが、セキュリティを確保するために慎重に構成する必要があります。

セッション関連のXSS攻撃からアプリケーションを保護するには、次の測定が必要です。1。セッションCookieを保護するためにHTTPonlyとセキュアフラグを設定します。 2。すべてのユーザー入力のエクスポートコード。 3.コンテンツセキュリティポリシー(CSP)を実装して、スクリプトソースを制限します。これらのポリシーを通じて、セッション関連のXSS攻撃を効果的に保護し、ユーザーデータを確保できます。

PHPセッションのパフォーマンスを最適化する方法は次のとおりです。1。遅延セッション開始、2。データベースを使用してセッションを保存します。これらの戦略は、高い並行性環境でのアプリケーションの効率を大幅に改善できます。

thesession.gc_maxlifettinginttinginphpdethinesthelifsessessiondata、setinseconds.1)it'sconfiguredinphp.iniorviaini_set()。 2)AbalanceSneededToAvoidPerformanceIssues andunexpectedLogouts.3)php'sgarbagecollectionisisprobabilistic、影響を受けたBygc_probabi

PHPでは、session_name()関数を使用してセッション名を構成できます。特定の手順は次のとおりです。1。session_name()関数を使用して、session_name( "my_session")などのセッション名を設定します。 2。セッション名を設定した後、session_start()を呼び出してセッションを開始します。セッション名の構成は、複数のアプリケーション間のセッションデータの競合を回避し、セキュリティを強化することができますが、セッション名の一意性、セキュリティ、長さ、設定タイミングに注意してください。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)
