テストプロセスが再現可能であることを保証するために、実際には、特定状態と呼ばれるいくつかの既知の状態でテストする必要があります。ブログ アプリケーションで投稿作成機能をテストする場合、テストを実行するたびに、投稿に関連するテーブル (Post
テーブル、Comment
テーブルなど) が復元される必要があります。特定の状態。PHPUnit のドキュメントには、特定の状態の一般的な構造について詳しく説明されています。このセクションでは、主に、先ほど説明した例のようなデータベースの特定の状態を構築する方法を紹介します。これは、データベース バックエンド サポートを使用したアプリケーションのテストでおそらく最も時間のかかる部分の 1 つです。Yii によって導入された CBbFixtureManager アプリケーション コンポーネントは、一連のテストを実行するときに、基本的に次のことを実行します。 ul class=" list-paddingleft-2">
Post
表 , Comment
表)应该被恢复到一个特定的状态下. PHPUnit 文档 已经很好的描述了一般的特定状态的构建. 而本节主要介绍怎样像刚才描述的例子那样构建数据库特定状态.设置构建数据库的特定状态,这恐怕是测试以数据库为后端支持的应用最耗时的部分之一.Yii 引进的 CBbFixtureManager 应用组件可以有效的减轻这一问题.当进行一组测试的时候,它基本上会做以下这些事情:
在所有测试运行之前,它重置测试相关数据为可知的状态.
在单个测试运行之前, 它将特定的表重置为可知状态.
在一个测试方法执行过程中, 它提供了供给特定状态的行数据的访问接口.
请按如下使用我们在 应用配置 中配置的 CDbFixtureManager.
return array( 'components'=>array( 'fixture'=>array( 'class'=>'system.test.CDbFixtureManager', ), ), );
然后我们在目录 protected/tests/fixtures
下提供一个特定状态数据. 这个目录可以通过配置应用配置文件中的 CDbFixtureManager::basePath 属性指定为其他目录.特定状态数据是由多个称之为特定状态文件的PHP文件组合而成.每个特定状态文件返回一个数组, 代表数据的一个特定表的初始行.文件名和表名相同.以下则是将 Post
表的特定状态数据存储于名为 Post.php
文件里的例子.
<?php return array( 'sample1'=>array( 'title'=>'test post 1', 'content'=>'test post content 1', 'createTime'=>1230952187, 'authorId'=>1, ), 'sample2'=>array( 'title'=>'test post 2', 'content'=>'test post content 2', 'createTime'=>1230952287, 'authorId'=>1, ), );
正如我们所见, 上面返回了两行数据. 每一行都表示一个数组,其键是表的字段名,其值则是对应的字段值.每行的索引都是称之为行别名的字符串(例如: simple1
, simple2
). 稍后当我们编写测试脚本的时候, 我们可以方便地通过它的别名调用这行数据.我们将在下节中详细的介绍这个.
你也许注意到了我们并未在上述特定状态中指定 id
字段的值. 这是因为 id
字段已经被定义为自增主键了,它的值也会在我们插入新数据的时候自动生成.
当 CDbFixtureManager 第一次被引用时, 它会仔细检查所有的特定状态文件然后使用他们重置对应的表.它通过清空表,重置表主键的自增序列值,然后插入来自特定状态文件的数据行到表中来重置表.
有时候,我们可能不想在一套测试前重置特定状态文件里描述的每一个表, 因为重置太多的特定状态文件可能需要很多时间.这种情况下,我们可以写一个PHP脚本来定制这个初始化过程.这个脚本应该被保存在存放特定状态文件的目录下,并命名为 init.php
.当 CDbFixtureManager 检测到了这个脚本的存在, 它将执行这个脚本而不是重置每一个表.
不喜欢使用默认方式来重置表也是可以的,例如: 清空表然后插入特定状态数据. 如果是这种情况, 我们可以为指定的特定状态文件编写一个初始化脚本.这个脚本必须名称为表名+.init.php
. 例如: Post
表的初始化脚本文件就是 Post.init.php
すべてのテストを実行する前に、テスト関連のデータを認識可能な状態にリセットします
単一のテストを実行する前に、特定のデータをリセットします。テーブルを既知の状態にします。
rrreee
protected/tests/fixtures
の下に特定のステータス データを提供します。このディレクトリは、Configure からアクセスできます。アプリケーション構成ファイルの CDbFixtureManager::basePath 属性で別のディレクトリを指定します。特定の状態データは、特定の状態ファイルと呼ばれる複数の PHP ファイルで構成され、特定のデータを表す配列を返します。ファイル名はテーブル名と同じです。 以下は、Post.php
という名前のファイルに Post
テーブルの特定のステータス データを保存する例です。 🎜🎜rrreee🎜🎜🎜 ご覧のとおり、上記では 2 行のデータが返されます。各行は配列を表し、そのキーはテーブルのフィールド名で、その値は対応するフィールド値です。これは 🎜line エイリアス🎜 の文字列です (例: simple1
、simple2
)。後でテスト スクリプトを作成するときに、エイリアス This を通じて簡単に呼び出すことができます。これについては次のセクションで詳しく説明します。🎜🎜上記の特定の状態で id
フィールドの値を指定していないことに気づいたかもしれません。 >id code> フィールドは自動インクリメント主キーとして定義されており、新しいデータを挿入するときにその値も自動的に生成されます 🎜🎜 CDbFixtureManager が初めて参照されるとき、すべての特定のキーが注意深くチェックされます。テーブルをクリアし、テーブルの主キーの自動インクリメント シーケンス値をリセットし、特定の状態ファイルからテーブルにデータ行を挿入することで、対応するテーブルをリセットします。特定の状態ファイルに記述されているすべてのテーブルをリセットする前に、一連のテストでこれを実行したくない場合があります。これは、特定の状態ファイルのリセットが多すぎると時間がかかる可能性があるためです。この場合、PHP スクリプトを作成してカスタマイズできます。この初期化プロセスは、特定の状態ファイルをディレクトリに保存し、init.php
という名前を付けて保存する必要があります。CDbFixtureManager は、このスクリプトの存在を検出すると、それぞれをリセットする代わりにこのスクリプトを実行します。 🎜🎜デフォルトを使用したくない場合は、テーブルをクリアして特定の状態データを挿入することによって、テーブルをリセットすることもできます。スクリプトの名前はテーブル名 + .init.php
である必要があります。例: Post
テーブルの初期化スクリプト ファイルは Post.init.php
です。 CDbFixtureManager がこのスクリプトを見つけると、デフォルトのメソッドを使用してテーブルをリセットする代わりに、このスクリプトを実行します。🎜🎜🎜🎜ヒント:🎜 特定の状態ファイルが多すぎると、テスト時間が大幅に長くなります。そのため、特定の状態のみを提供する必要があります。テスト中にデータが変更されるテーブルのファイル。検索サービスに使用されるテーブルは変更されないため、特定の状態ファイルは必要ありません 🎜🎜🎜 次の 2 つのセクションでは、によって管理される特定の状態の使用方法について説明します。単体テストと機能テストにおける CDbFixtureManager 🎜🎜これは、Yii Framework 公式ガイド シリーズ 38 - 特定の状態の定義 (フィクスチャ) です。詳細については、PHP 中国語 Web サイト (www.php.cn) に注目してください。 🎜🎜🎜🎜
セッション関連の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 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

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

SublimeText3 中国語版
中国語版、とても使いやすい

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。
