{"id":4191,"date":"2020-10-07T19:31:26","date_gmt":"2020-10-07T10:31:26","guid":{"rendered":"https:\/\/akamist.com\/blog\/?p=4191"},"modified":"2021-06-05T19:53:50","modified_gmt":"2021-06-05T10:53:50","slug":"laravel-%e3%83%ad%e3%82%b0%e3%81%ab%e3%83%95%e3%82%a1%e3%82%a4%e3%83%ab%e5%90%8d%e3%81%a8%e8%a1%8c%e7%95%aa%e5%8f%b7%e3%82%92%e8%bf%bd%e5%8a%a0%e3%81%99%e3%82%8b","status":"publish","type":"post","link":"https:\/\/akamist.com\/blog\/archives\/4191","title":{"rendered":"[Laravel] \u30ed\u30b0\u306b\u30d5\u30a1\u30a4\u30eb\u540d\u3068\u884c\u756a\u53f7\u3092\u8ffd\u52a0\u3059\u308b"},"content":{"rendered":"<h2>app\/Logging\/CustomFormatter.php<\/h2>\n<pre><code class=\"language-php\">&lt;?php\n\ndeclare(strict_types=1);\n\nnamespace App\\Logging;\n\nuse Monolog\\Formatter\\LineFormatter;\nuse Monolog\\Logger;\nuse Monolog\\Processor\\IntrospectionProcessor;\n\nclass CustomizeFormatter\n{\n    public function __invoke($monolog)\n    {\n        $fields = [\n            \"%datetime%\",\n            \"%level_name%\",\n            \"%extra.class%::%extra.function%#%extra.line%\",\n            \"%message%\",\n        ];\n        $logFormat = implode(\"\\t\", $fields) . PHP_EOL;\n        $formatter = new LineFormatter($logFormat, 'ymd-His.v');\n\n        $ip = new IntrospectionProcessor(Logger::DEBUG, ['Illuminate\\\\']);\n        foreach ($monolog-&gt;getHandlers() as $handler) {\n            $handler-&gt;setFormatter($formatter);\n            $handler-&gt;pushProcessor($ip);\n        }\n    }\n}\n<\/code><\/pre>\n<h2>app\/config\/logging.php<\/h2>\n<p>default\u306e\u5909\u66f4\u306f\u3001\u8aac\u660e\u3092\u308f\u304b\u308a\u3084\u3059\u304f\u3059\u308b\u305f\u3081\u76f4\u63a5\u5909\u66f4\u3057\u3066\u3044\u307e\u3059\u3002\u672c\u5f53\u306f.env\u306eLOG_CHANNEL\u3092\u5909\u66f4\u3057\u305f\u307b\u3046\u304c\u826f\u3044\u3067\u3059\u3002<\/p>\n<pre><code class=\"language-php\"><br \/>    \/\/ 'default' =&gt; env('LOG_CHANNEL', 'stack'),\n    'default' =&gt; 'mylog',\n\n    'channels' =&gt; [\n        'mylog' =&gt; [\n            'driver' =&gt; 'single',\n            'tap' =&gt; [App\\Logging\\CustomFormatter::class], \/\/ \u3053\u3053\u3092\u8ffd\u52a0\u3059\u308b\n            'path' =&gt; storage_path('logs\/laravel.log'),\n            'level' =&gt; 'debug',\n        ],\n<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>app\/Logging\/CustomFormatter.php &lt;?php declare(strict_types=1); namespace App\\Logging; use Monolog\\Formatter [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":985,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[1],"tags":[],"aioseo_notices":[],"jetpack_featured_media_url":"https:\/\/akamist.com\/blog\/wp-content\/uploads\/2017\/11\/icon_laravel.png","jetpack-related-posts":[{"id":4025,"url":"https:\/\/akamist.com\/blog\/archives\/4025","url_meta":{"origin":4191,"position":0},"title":"[Laravel] barryvdh\/laravel-cors\u30d1\u30c3\u30b1\u30fc\u30b8\u3067CORS\u5bfe\u5fdc\u3059\u308b","date":"2020\u5e743\u670829\u65e5","format":false,"excerpt":"Laravel\u3067CORS\u51e6\u7406\u3092\u884c\u3044\u305f\u3044\u5834\u5408\u3001barryvdh\/laravel-cors\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u4f7f\u2026","rel":"","context":"Laravel","img":{"alt_text":"","src":"https:\/\/i0.wp.com\/akamist.com\/blog\/wp-content\/uploads\/2017\/11\/icon_laravel.png?resize=350%2C200&ssl=1","width":350,"height":200},"classes":[]},{"id":4175,"url":"https:\/\/akamist.com\/blog\/archives\/4175","url_meta":{"origin":4191,"position":1},"title":"Laravel\u3067docker-compose\u3067\u4f5c\u3063\u305fMySQL\u306esakila DB\u306b\u30a2\u30af\u30bb\u30b9\u3059\u308b","date":"2020\u5e749\u670830\u65e5","format":false,"excerpt":"PHP\u306e\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30afLaravel\u3092\u4f7f\u3063\u3066\u3001Eloquent\u306eModel\u30af\u30e9\u30b9\u304b\u3089MySQL\u306esa\u2026","rel":"","context":"\u672a\u5206\u985e","img":{"alt_text":"","src":"https:\/\/i0.wp.com\/akamist.com\/blog\/wp-content\/uploads\/2020\/09\/4175_2.png?resize=350%2C200&ssl=1","width":350,"height":200},"classes":[]},{"id":5478,"url":"https:\/\/akamist.com\/blog\/archives\/5478","url_meta":{"origin":4191,"position":2},"title":"Laravel Lighthouse\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u3066PHP\u304b\u3089\u30af\u30a8\u30ea\u3092\u8fd4\u3059","date":"2022\u5e745\u67081\u65e5","format":false,"excerpt":"PHP\u3067\u306fLaravel Lighthouse\u3092\u4f7f\u3046\u3053\u3068\u3067\u7c21\u5358\u306bGraphQL\u306e\u30b5\u30fc\u30d0\u3092\u69cb\u7bc9\u3059\u308b\u3053\u3068\u2026","rel":"","context":"\u672a\u5206\u985e","img":{"alt_text":"","src":"https:\/\/i0.wp.com\/akamist.com\/blog\/wp-content\/uploads\/2022\/05\/5478_1.png?resize=350%2C200&ssl=1","width":350,"height":200},"classes":[]},{"id":4123,"url":"https:\/\/akamist.com\/blog\/archives\/4123","url_meta":{"origin":4191,"position":3},"title":"Laravel Socialite\u3067\u8907\u6570SNS\u306e\u30bd\u30fc\u30b7\u30e3\u30eb\u30ed\u30b0\u30a4\u30f3\u3092\u884c\u3046\u65b9\u6cd5","date":"2020\u5e749\u67086\u65e5","format":false,"excerpt":"Laravel\u3067\u306fSocialite\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u4f7f\u7528\u3057\u3066\u30bd\u30fc\u30b7\u30e3\u30eb\u30ed\u30b0\u30a4\u30f3\u3092\u884c\u3046\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002 \u30bd\u2026","rel":"","context":"\u672a\u5206\u985e","img":{"alt_text":"","src":"https:\/\/i0.wp.com\/akamist.com\/blog\/wp-content\/uploads\/2017\/11\/icon_laravel.png?resize=350%2C200&ssl=1","width":350,"height":200},"classes":[]},{"id":3267,"url":"https:\/\/akamist.com\/blog\/archives\/3267","url_meta":{"origin":4191,"position":4},"title":"gcp\u306ef1-micro\u30a4\u30f3\u30b9\u30bf\u30f3\u30b9\u306bLaravel\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb","date":"2018\u5e7411\u67083\u65e5","format":false,"excerpt":"\u4eca\u56de\u306f\u3001\u524d\u56de\u4f5c\u6210\u3057\u305fnginx + php\u306e\u74b0\u5883\u306bLaravel\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u3066\u307f\u307e\u3059\u3002 - [C\u2026","rel":"","context":"Laravel","img":{"alt_text":"","src":"https:\/\/i0.wp.com\/akamist.com\/blog\/wp-content\/uploads\/2017\/11\/icon_laravel.png?resize=350%2C200&ssl=1","width":350,"height":200},"classes":[]},{"id":4696,"url":"https:\/\/akamist.com\/blog\/archives\/4696","url_meta":{"origin":4191,"position":5},"title":"Laravel 8.x\u306esail up\u3067\u30dd\u30fc\u30c8\u756a\u53f7\u304c\u88ab\u308b\u3068\u304d","date":"2021\u5e7410\u670820\u65e5","format":false,"excerpt":"Laravel 8.x\u3067\u306f\u3001Laravel sail\u306b\u3088\u308bdocker\u74b0\u5883\u304c\u6e96\u5099\u3055\u308c\u3066\u304a\u308a\u3001`.\/v\u2026","rel":"","context":"\u672a\u5206\u985e","img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]}],"jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/akamist.com\/blog\/wp-json\/wp\/v2\/posts\/4191"}],"collection":[{"href":"https:\/\/akamist.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/akamist.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/akamist.com\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/akamist.com\/blog\/wp-json\/wp\/v2\/comments?post=4191"}],"version-history":[{"count":3,"href":"https:\/\/akamist.com\/blog\/wp-json\/wp\/v2\/posts\/4191\/revisions"}],"predecessor-version":[{"id":4194,"href":"https:\/\/akamist.com\/blog\/wp-json\/wp\/v2\/posts\/4191\/revisions\/4194"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/akamist.com\/blog\/wp-json\/wp\/v2\/media\/985"}],"wp:attachment":[{"href":"https:\/\/akamist.com\/blog\/wp-json\/wp\/v2\/media?parent=4191"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/akamist.com\/blog\/wp-json\/wp\/v2\/categories?post=4191"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/akamist.com\/blog\/wp-json\/wp\/v2\/tags?post=4191"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}