ホームページ バックエンド開発 PHPチュートリアル PHP 開発フレームワーク Yii Framework チュートリアル (3) アプリケーションにログを追加する

PHP 開発フレームワーク Yii Framework チュートリアル (3) アプリケーションにログを追加する

Jan 21, 2017 am 09:33 AM

アプリケーションの開発プロセスでは、IDE でサポートされているリアルタイム デバッグ (VS.PHP や IDE でサポートされているデバッグ機能など) に加えて、Web アプリケーションに適切なデバッグ情報を追加することも非常に重要です。これは、Java または .Net アプリケーションを開発したことがある人なら誰でも、log4XX ​​に精通しているので、Yii Framework には、CWebApplication の組み込みコンポーネントとして表示される、同様の Log 関数 Yii::log も用意されています。これは設定ファイルを通じて設定できます (Yii の設定は通常 protected/config/main.php です)。

前回の記事「Yii フレームワーク開発の簡潔なチュートリアル (2) Yii Web アプリケーションの基礎」では、アプリケーションのコンポーネントについて簡単に説明しました。

Log コンポーネントに加えて、Yii は一般的な Web アプリケーションで使用される機能を提供する一連のコアアプリケーションコンポーネントを事前定義しています。たとえば、リクエスト コンポーネントは、ユーザー リクエストを解析し、URL や Cookie などの情報を提供するために使用されます。 これらのコアコンポーネントのプロパティを設定することで、ほぼあらゆる面で Yii のデフォルトの動作を変更できます。

以下に、CWebApplication によって事前定義されたコア コンポーネントをリストします。

assetManager: CAssetManager - プライベートアセットファイルのリリースを管理します。

authManager: CAuthManager - ロールベースのアクセス制御 (RBAC) を管理します。

cache: CCache - データキャッシュ機能を提供します。実際のクラス (CMemCache、CDbCache など) を指定する必要があることに注意してください。 それ以外の場合、このコンポーネントにアクセスすると NULL が返されます。

clientScript: CClientScript - クライアント側スクリプト (JavaScript および CSS) を管理します。

coreMessages: CPhpMessageSource - Yii フレームワークによって使用されるコアメッセージの翻訳を提供します。

db: CDbConnection - データベース接続を提供します。このコンポーネントを使用するには、その connectionString プロパティを設定する必要があることに注意してください。

errorHandler: CErrorHandler - 捕捉されなかった PHP エラーと例外を処理します。

format: CFormatter - フォーマットされた数値表示。この機能はバージョン 1.1.0 以降で利用可能です。

messages: CPhpMessageSource - Yii アプリケーションで使用されるメッセージ翻訳を提供します。

request: CHttpRequest - ユーザーのリクエストに関する情報を提供します。

securityManager: CSecurityManager - ハッシュ、暗号化などのセキュリティ関連サービスを提供します。

session: CHttpSession - セッション関連の機能を提供します。

statePersister: CStatePersister - グローバル状態永続メソッドを提供します。

urlManager: CUrlManager - URL 解析および作成関連機能を提供します。

user: CWebUser - 現在のユーザーの識別情報を提供します。

themeManager: CThemeManager - テーマを管理します。これらのコンポーネントは、後続のチュートリアルで段階的に紹介されます。 Log 関数の基本的な使用方法を以下に示します。 ここでは、Yii フレームワーク開発の簡潔なチュートリアル (1) を変更します。 最初のアプリケーションは Hello World です。それにログを追加します。 1. 設定ファイル protected/config/main.php を作成します。ログをファイルに書き込みたい場合は、次の設定を使用できます: Yii::log または Yii::trace を通じて記録された情報。のメモリに保存されます。 通常、それらをブラウザ ウィンドウに表示するか、ファイルや電子メールなどの永続ストレージに保存する必要があります。これを情報ルーティングと呼びます。

通常、Log 機能を使用する場合は、プリロードによって設定された Log コンポーネントをプリロードする必要があります。 ヒント: デフォルトでは、アプリケーション コンポーネントは必要に応じて作成されます。これは、コンポーネントがアクセスされた場合にのみ作成されることを意味します。 したがって、多くのコンポーネントの構成によってシステム全体のパフォーマンスが低下することはありません。一部のアプリケーション コンポーネント (CLogRouter など) は、使用されるかどうかに関係なく作成されます。この場合、アプリケーションの構成ファイル preload にこれらのコンポーネントの ID をリストします。

2. エントリスクリプトindex.phpを変更し、新しく作成した構成ファイルを使用するようにメインアプリケーションインスタンスを構成します。

// This is the main Web application configuration. Any writable// CWebApplication properties can be configured here.return array(
// preloading 'log' component'preload'=>array('log'),
// application components'components'=>array(
'log'=>array('class'=>'CLogRouter','routes'=>array(array('class'=>'CFileLogRoute','levels'=>'info,error, warning',),
),),),
);
ログイン後にコピー

ログファイルが書き込まれるデフォルトのディレクトリは protected/runtime であるため、事前に runtime ディレクトリを作成する必要があります。そうしないと、Yii は Web ページにログを直接表示します。

4. このように、Yii::log または Yii::trace を使用してアプリケーションにログを追加できます。

違いは、後者はアプリケーションがデバッグ モードで実行されているときにのみ情報を記録することです。

$yii='C:/yiiframework/yii.php';
// remove the following line when in production mode
defined('YII_DEBUG') or define('YII_DEBUG',true);
$config=dirname(__FILE__).'/protected/config/main.php';
require_once($yii);
Yii::createWebApplication($config)->run();3. 创建protected/runtime
ログイン後にコピー

情報を記録するときは、そのカテゴリとレベルを指定する必要があります。カテゴリは、パスのエイリアスに似た形式の文字列です。 たとえば、メッセージが CController に記録されている場合、分類として system.web.CController を使用できます。情報レベルは次の値のいずれかである必要があります:

trace: これは Yii::trace で使用されるレベルです。開発中にプログラムの実行フローを追跡するために使用されます。

info: これは一般的な情報を記録するために使用されます。

profile: 公演概要(プロフィール)です。詳細な手順は後ほど説明します。

warning: これは警告メッセージに使用されます。

error: これは致命的なエラー メッセージに使用されます。

Yii のログはレベルとカテゴリによって分類およびフィルタリングされます。前述したように、複数のレベルまたはカテゴリはカンマで接続する必要があります。

由于 信息分类是类似 xxx.yyy.zzz 格式的,我们可以将其视为一个分类层级。 具体地,我们说 xxx 是 xxx.yyy 的父级,而 xxx.yyy 又是 xxx.yyy.zzz 的父级。 这样我们就可以使用 xxx.* 表示分类 xxx 及其所有的子级和孙级分类。

有了以 上知识,我们修改SiteController的actionIndex,添加一行日志。

public function actionIndex()
{
Yii::log("action","info","site.action");
$this->render("index");
}
ログイン後にコピー

5. 运行应用,可以看到Yii在protected/runtime 创建了一个application.log

其内容如下:

2012/12/11 21:23:38 [info] [site.action] action

注: 日志存放的位置和文件名都可以通过配置来修改,一般情 况使用缺省值就可以了,和log4X 类似,应用的日志可以通过路由同时写到多个目的地(文件,Email等)这些多可以通过配置 来实现,具体可以参见日志记录。

以上就是PHP开发框架Yii Framework教程(3) 为应用添加日志的内容,更多相关内容请关注PHP中文网(www.php.cn)!


このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホット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衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Microsoft NET Framework のインストールの問題エラー コード 0x800c0006 の修正 Microsoft NET Framework のインストールの問題エラー コード 0x800c0006 の修正 May 05, 2023 pm 04:01 PM

開発者とエンド ユーザーが Windows 上で最新バージョンのアプリケーションを実行するには、.NET Framework 4 が必要です。しかし、.NET Framework 4 のダウンロードとインストール中に、多くのユーザーから、インストーラーが途中で停止し、「ダウンロードがエラー コード 0x800c0006 で失敗したため、.NET Framework 4 はインストールされていません」というエラー メッセージが表示されるという苦情が寄せられました。デバイスに .NETFramework4 をインストールしているときにもこの問題が発生する場合は、正しい場所にいます。

Windows 11/10 で SetupDiag を使用して Windows アップグレードの問題を特定する方法 Windows 11/10 で SetupDiag を使用して Windows アップグレードの問題を特定する方法 Apr 17, 2023 am 10:07 AM

Windows 11 または Windows 10 PC でアップグレードまたはアップデートの問題が発生すると、通常、失敗の背後にある実際の理由を示すエラー コードが表示されます。ただし、エラー コードが表示されずにアップグレードまたはアップデートが失敗すると、混乱が生じることがあります。便利なエラー コードを使用すると、問題の場所が正確にわかるので、修正を試みることができます。ただし、エラー コードが表示されないため、問題を特定して解決することが困難になります。エラーの背後にある理由を見つけるだけでも多くの時間がかかります。この場合、Microsoft が提供する SetupDiag という専用ツールを使用すると、エラーの背後にある本当の理由を簡単に特定できます。

SCNotification が動作を停止しました [問題を解決する 5 つのステップ] SCNotification が動作を停止しました [問題を解決する 5 つのステップ] May 17, 2023 pm 09:35 PM

Windows ユーザーは、コンピュータを起動するたびに「SCNotification は動作を停止しました」というエラーに遭遇する可能性があります。 SCNotification.exe は Microsoft システム通知ファイルであり、アクセス許可エラーやネットワーク障害が原因で PC を起動するたびにクラッシュします。このエラーは、問題のあるイベント名でも知られています。したがって、これは SCNotification が動作を停止したということではなく、バグ clr20r3 として認識される可能性があります。この記事では、SCNotification が動作を停止した問題を修正して再び悩まされないようにするために必要なすべての手順を説明します。 SCNotification.eとは何ですか

Microsoft .NET Framework 4.5.2、4.6、および 4.6.1 は 2022 年 4 月にサポートを終了します Microsoft .NET Framework 4.5.2、4.6、および 4.6.1 は 2022 年 4 月にサポートを終了します Apr 17, 2023 pm 02:25 PM

Microsoft.NET バージョン 4.5.2、4.6、または 4.6.1 をインストールしている Microsoft Windows ユーザーが、将来の製品更新を通じて Microsoft にフレームワークをサポートさせることを希望する場合は、新しいバージョンの Microsoft Framework をインストールする必要があります。 Microsoft によると、3 つのフレームワークはすべて 2022 年 4 月 26 日にサポートを終了します。サポート期限が終了すると、製品は「セキュリティ修正またはテクニカル サポート」を受けられなくなります。ほとんどのホーム デバイスは、Windows アップデートを通じて最新の状態に保たれます。これらのデバイスには、.NET Framework 4.8 などの新しいバージョンのフレームワークがすでにインストールされています。自動的に更新されないデバイスは、

Windows 11 の KB5012643 により .NET Framework 3.5 アプリが中断される Windows 11 の KB5012643 により .NET Framework 3.5 アプリが中断される May 09, 2023 pm 01:07 PM

Windows 11 に KB5012643 をインストールしたユーザーに影響を与える新しいセーフ モードのバグについてお話ししてから 1 週間が経過しました。このやっかいな問題は、Microsoft が発売日に投稿した既知の問題のリストには載っていなかったので、誰もが驚きました。さて、事態がこれ以上悪化するはずはないと思ったそのとき、Microsoft は、この累積的な更新プログラムをインストールしたユーザーに別の爆弾を投下します。 Windows 11 Build 22000.652 はさらなる問題を引き起こす そこで同社は、Windows 11 ユーザーに対し、一部の .NET Framework 3.5 アプリケーションの起動と使用に問題が発生する可能性があると警告しています。おなじみですね?でも驚かないでください

PHP フレームワーク Yii を使用して可用性の高いクラウド バックアップ システムを開発する方法 PHP フレームワーク Yii を使用して可用性の高いクラウド バックアップ システムを開発する方法 Jun 27, 2023 am 09:04 AM

クラウド コンピューティング テクノロジの継続的な発展により、データのバックアップはすべての企業が行う必要のあるものになりました。この文脈では、可用性の高いクラウド バックアップ システムを開発することが特に重要です。 PHP フレームワーク Yii は、開発者が高性能の Web アプリケーションを迅速に構築できる強力なフレームワークです。ここでは、Yii フレームワークを使用して可用性の高いクラウド バックアップ システムを開発する方法を紹介します。データベースモデルの設計 Yii フレームワークでは、データベースモデルは非常に重要な部分です。データ バックアップ システムには多くのテーブルとリレーションシップが必要なため、

Symfony と Yii2: 大規模な Web アプリケーションの開発にはどちらのフレームワークが適していますか? Symfony と Yii2: 大規模な Web アプリケーションの開発にはどちらのフレームワークが適していますか? Jun 19, 2023 am 10:57 AM

Web アプリケーションの需要が高まるにつれ、開発者が開発フレームワークを選択する選択肢はますます増えています。 PHP フレームワークとして人気のある Symfony と Yii2 は、どちらも強力な機能とパフォーマンスを備えていますが、大規模な Web アプリケーションを開発する必要がある場合、どちらのフレームワークがより適しているのでしょうか。次に、より良い選択を行うために、Symphony と Yii2 の比較分析を行います。基本概要 Symphony は、PHP で書かれたオープンソースの Web アプリケーション フレームワークであり、上に構築されています。

Yii フレームワークでのデータクエリ: データに効率的にアクセスする Yii フレームワークでのデータクエリ: データに効率的にアクセスする Jun 21, 2023 am 11:22 AM

Yii フレームワークは、Web アプリケーション開発のプロセスを簡素化するための多数のツールとコンポーネントを提供するオープンソースの PHP Web アプリケーション フレームワークであり、その重要なコンポーネントの 1 つがデータ クエリです。 Yii フレームワークでは、SQL に似た構文を使用してデータベースにアクセスし、データを効率的にクエリおよび操作できます。 Yii フレームワークのクエリビルダーには主に次の種類があります: ActiveRecord クエリ、QueryBuilder クエリ、コマンド クエリ、独自の SQL クエリ

See all articles