php_PHP 上の 2 つの pecl ライブラリ memcache および memcached チュートリアル
以前 memcache を使用しようとしましたが、後で memcached が setMulti メソッドをサポートしていることがわかり、memcached ライブラリの使用に切り替えるつもりです。
(試してみました。実際、memcache は複数値セットをサポートしたことがありませんでしたが、ドキュメントにはまだ記載されていません。変更ログによると、3.0 からサポートされるようです。安定版にはこの機能がない可能性があります。 .)
効率に関しては、どれくらいの差が出るのかは分かりません。
ここには、memcached が libmemcached に基づいており、より優れている可能性があるという記事もあります。
最後に、libmemached に基づく php 拡張機能が pecl でリリースされました。
つまり、pecl には 2 つの memcache クライアントが存在します。 1 つは完全に PHP フレームワーク memcache 内で開発され、もう 1 つは libmemcached を使用する memecached です。
関数に関しては、libmemcached を見たことがありませんが、理論的には、すでに他の言語で非常に人気のある libmemcached の方がより完全な関数を備えているはずです。プログラムのパフォーマンス (メモリと CPU 使用率) については、何とも言えません。pecl::memcache はネイティブに実装されていますが、libmemcached を使用する pecl::memached は OO インターフェイスのみをサポートし、pecl::memcache は OO インターフェイスと非 OO インターフェイスの両方をサポートします。ソケットの共存が重みになります。
実際、これらは最も重要ではありません。 libmemcached を使用する明らかな利点は、memcached サーバーが将来改良されるにつれて、このライブラリもすぐに追随することになるということです。ただし、pecl::memcache は時間通りにフォローアップできない可能性があります。
pecl::memcached のもう 1 つの非常に賞賛に値する点は、動作中にフラグが設定されないことです。代わりに、統合された setOption() があります。この方法では、pecl::memcache から pecl::memcached に切り替えることは非常に価値があります。特定のインターフェイスはここにあります: http://cvs.php.net/viewvc.cgi/pecl/memcached/memcached-api.php?view=markup
ドライバーベースのアーキテクチャにできるかどうかについては pecl-dev@ で述べました。現在の MySQL と同様に、基礎となるエンジンとして mysqlnd または libmysql を使用することを選択できます。しかし、よく考えてみると、実際には、memcached でそのようなアーキテクチャを使用することはあまりサポートされていません。これは MySQL とは異なります。
mysqlnd は新しい API ではなくエンジンとして開発されているため、多数のアプリケーションがデータベース操作を変更することなく新しいエンジンを使用できるようになります。 mysqlnd が新しい拡張機能である場合、以前のプログラムと互換性を持たせたい場合は、非常に難しい選択に直面することになります。なぜなら、これまでのところ、libmysql を使用し、異なる外部インターフェイスを持つ 3 つの公式 MySQL クラス セットがあるからです。 Mysqlnd は mysql と互換性がありますが、mysqli または pdo とは互換性がありません。もちろん、独自の抽象データベース クラスを使用するプログラムの場合、互換性を確保するためにクラスを書き直すかドライバー (php レベル) を変更することでこれを実現できます。しかし、考えてみてください。抽象ライブラリを使用するとしても、世界中には非常に多くのデータベース抽象ライブラリがあり、誰でも手頃な価格で利用できるようにするには、どれだけのライブラリを変更し、どれだけのドライバを追加する必要があります。
memcached の状況ははるかに単純です。現時点では、公式システムとより密接な関係があるのは pecl::memcache だけであり、インターフェイスは基本的に libmemcache とほぼ同じ memcached プロトコルに基づいています。実際には、これらは抽象クラス内の異なるドライバーとみなすことができます。したがって、2 つの異なるクライアントのセットがありますが、それらを置き換えるときに変更を加える必要はほとんどありません。必要なのは、クラスが初期化される場所を変更し、set/get およびその他のメソッドのフラグを削除することだけです。非 OO インターフェイスを使用します。
さらに、mysql は通信とデータ取得において memcache よりも複雑で、libmysql ではできないことがいくつかあります。たとえば、PHP 内の HashTable と zval を使用してバッファを直接保存できます。たとえば、永続リンクである一部の構造をさらにキャッシュできます。 (これらは単なる私の推測であり、mysqlnd のコードを読んでいません)
Memcached マニュアル:
http://cn.php.net/manual/en/book.memcached.php
Memcache マニュアル:
http://cn.php.net/manual/en/book.memcache.php
中国語と英語の Memcached プロトコル

セッション関連の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()を呼び出してセッションを開始します。セッション名の構成は、複数のアプリケーション間のセッションデータの競合を回避し、セキュリティを強化することができますが、セッション名の一意性、セキュリティ、長さ、設定タイミングに注意してください。

セッションIDは、機密操作の前、30分ごとにログイン時に定期的に再生する必要があります。 1.セッション固定攻撃を防ぐためにログインするときにセッションIDを再生します。 2。安全性を向上させるために、敏感な操作の前に再生します。 3.定期的な再生は長期的な利用リスクを減らしますが、ユーザーエクスペリエンスの重量を量る必要があります。

PHPのセッションCookieパラメーターの設定は、session_set_cookie_params()関数を通じて達成できます。 1)この関数を使用して、有効期限、パス、ドメイン名、セキュリティフラグなどのパラメーターを設定します。 2)session_start()を呼び出して、パラメーターを有効にします。 3)ユーザーログインステータスなど、ニーズに応じてパラメーターを動的に調整します。 4)セキュリティを改善するために、セキュアとhttponlyフラグを設定することに注意してください。

PHPでセッションを使用する主な目的は、異なるページ間でユーザーのステータスを維持することです。 1)セッションはsession_start()関数を介して開始され、一意のセッションIDを作成し、ユーザーCookieに保存します。 2)セッションデータはサーバーに保存され、ログインステータスやショッピングカートのコンテンツなど、さまざまなリクエスト間でデータを渡すことができます。

サブドメイン間でセッションを共有する方法は?一般的なドメイン名にセッションCookieを設定することにより実装されます。 1.セッションCookieのドメインをサーバー側の.example.comに設定します。 2。メモリ、データベース、分散キャッシュなど、適切なセッションストレージ方法を選択します。 3. Cookieを介してセッションIDを渡すと、サーバーはIDに基づいてセッションデータを取得および更新します。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

Dreamweaver Mac版
ビジュアル Web 開発ツール

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、
