ホームページ > PHPフレームワーク > ThinkPHP > ThinkPHP のデバッグ手段と方法を分析する

ThinkPHP のデバッグ手段と方法を分析する

藏色散人
リリース: 2021-12-14 15:27:32
転載
1736 人が閲覧しました

次の thinkphp フレームワーク チュートリアル コラムでは、ThinkPHP を使用する際にマスターすべきデバッグ方法を分析します。

ThinkPHP を使用する際にマスターすべきデバッグ方法の分析

ThinkPHP を使用する際にマスターすべきデバッグ方法

よく質問されるのを見かけます。 findAll の戻りデータ型にはどのような種類の問題があるのでしょうか?また、何か問題が発生し、その理由がわからない場合は? 実際、私はデバッグ方法や ThinkPHP に組み込まれているメソッドにまだ慣れていません。開発に ThinkPHP を使用している、または使用する予定がある場合は、IDE 自体が付属しています。その場合は、次のデバッグ関連の方法を理解して習得する必要があります:

1. プロジェクトでデバッグ モード DEBUG_MODE をオンにします。設定ファイルを使用すると、エラーの原因のほとんどを見つけることができます。検証コードの出力に影響を与える可能性があります。

2. デバッグ モードを使用したくない場合は、ページ トレース表示を個別にオンにすることができます。多くの人がデバッグモードを使いたくない理由は、実はページトレース情報の出力にあることが分かりました。実は、デバッグモードにはページトレースが必要であると誤解されていますが、実際には、デバッグ モードとページ トレースは必ずしも関連しているわけではありません。デバッグ モードをオンにすると、システムのデフォルトのデバッグ構成ファイルによってページ トレースの表示が有効になるため、プロジェクトに対して別のデバッグ構成ファイルを定義できます。

3. システム定義のダンプ関数を使用します。このメソッドは、var_dump などのあらゆる種類の変数情報を出力でき、ブラウザで表示するのに便利です。例:

コードは次のとおりです。

$User = D("User");
$list = $User->findAll();
dump($list);
ログイン後にコピー

4. ページのトレース情報は、現在のページで実行された SQL ステートメントのみを表示できますが、ajax モードで実行されたバックグラウンド操作の SQL ステートメントを表示することはできないため、SQL ログを有効にすることもできます。 SQL_DEBUG_LOG を使用して、実行された各 SQL ステートメントを記録し、各 SQL ステートメントの実行時間を表示できます。SQL ログ ファイルは Logs ディレクトリの下にあり、毎日の SQL ログは日付によって自動的に区別されます。

5. もう 1 つは、特定のデータ操作を実行した後の SQL 実行にエラーがあると思われる場合、モデル クラスの getLastSql メソッドを使用して、最後に実行された SQL ステートメントを表示して、特定のデータ操作を分析することができます。エラーの原因。例:

コードは次のとおりです:

$User = D("User");
$User->id = 3;
$User->name = 'ThinkPHp';
$User->save();
echo $User->getLastSql();
// 输出 update think_user set where id=3;
ログイン後にコピー

6. コードの特定の部分の実行時間をデバッグする必要がある場合は、debug_start($label) と debug_end を使用できます。システムによって提供される ($label) メソッド例:

コードは次のとおりです:

debug_start('demo');
// 这里是你的代码段.......
debug_end('demo');
ログイン後にコピー

以上がThinkPHP のデバッグ手段と方法を分析するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:aliyun.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート