質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.31%
Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

1回答

901閲覧

LaravelのLogでchannelを毎回書きたくない 簡潔に書けないのか?

landy77

総合スコア1616

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2022/12/07 14:58

前提

Laravel9

Laravel9でシステムを作成しています。
今まで不勉強だったのでLogはDailyにしただけで特別な事はしていませんでしたが、システムが大きくなるにつれてLogが肥大化していくのでいよいよカスタムしてせめて機能別に書き出ししようと思いました。

現状

現状、チャンネルを機能別に作成して書き出せる事自体はコードが正解かはともかく、下記手順で実現できています。

config/logging.phpにログを吐き出したい機能別にチャンネルを作成

コントローラーのコード内でLog::channel('original-channel')->info('test');の様な感じでログ自体は想定通りに取れています。

実現したいこと

今まではLog::info('ログ');の少量で書けていたわけです。

そこで毎回channel("original-channel")を書かずに最初に宣言したらその後はそこに書かれるように出来ないかと思いました。
そこでネットを探してみて下記コードを見つけたのですが(変更していますが基本はそのままです)

$log = Log::channel('original-channel')->getLogger(); $log->info("TEST LOG");

実行してみると。$logオブジェクト?自体はMonolog\Logger Objectが作成できているようですが$log->info("TEST")$log::info("TEST");も通らない状況です。

発生しているエラーメッセージ

上記のコードでは下記のエラーが発生しています。

Non-static method Monolog\Logger::info()

考え

staticが云々というかそもそもgetLogger()で作成したオブジェクトMonolog\Loggerが間違えているのか?という気はします。
マニュアルのログページの下の方に少し「ファクトリによるカスタムチャンネルの生成」というのに触れていますがこれが正解かもわからないので保留して質問しました。

よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

複数のchannelを使い分けたいならLog::channel('original-channel')で書くしかない。
省略時はconfigで指定したデフォルトのchannelが使われているだけ。

短くしたいなら自分で工夫すればいい。
app/Support/Log.phpでも作って

php

1namespace App\Support; 2 3use Illuminate\Support\Facades\Log as Logger; 4 5class Log 6{ 7 public static function custom($message, array $context = []) 8 { 9 Logger::channel('custom')->info($message, $context); 10 } 11 12 public static function test($message, array $context = []) 13 { 14 Logger::channel('test')->info($message, $context); 15 } 16}

使うときは

php

1use App\Support\Log; 2 3Log::custom('test');

投稿2022/12/08 02:22

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.31%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問