{"id":3067,"date":"2018-10-25T22:50:12","date_gmt":"2018-10-25T13:50:12","guid":{"rendered":"http:\/\/taitan916.info\/blog\/?p=3067"},"modified":"2024-02-20T18:23:34","modified_gmt":"2024-02-20T09:23:34","slug":"post-3067","status":"publish","type":"post","link":"https:\/\/taitan916.info\/blog\/archives\/3067","title":{"rendered":"Composer\u81ea\u4f53\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3068monolog\u53ca\u3073Twig\u3092Composer\u7d4c\u7531\u3067\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b\u65b9\u6cd5"},"content":{"rendered":"<p>\u300cComposer\u3067\u25cb\u25cb\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u300d\u3068\u3044\u3046\u306e\u3092\u3088\u304f\u898b\u304b\u3051\u308b\u304cComposer\u3059\u3089\u4f55\u306a\u306e\u304b\u5206\u304b\u3063\u3066\u3044\u306a\u304b\u3063\u305f\u3002\u4eca\u5f8c\u4f7f\u3046\u304b\u3069\u3046\u304b\u306f\u7f6e\u3044\u3066\u304a\u3044\u3066Composer\u81ea\u4f53\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u65b9\u6cd5\u3068monolog\u53ca\u3073Twig\u3092Composer\u7d4c\u7531\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b\u65b9\u6cd5\u306e\u30e1\u30e2\u3002<\/p>\n<p>&nbsp;<\/p>\n<h2>Composer\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/h2>\n<p>\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u30eb\u30fc\u30c8(\/var\/www\/html\u3067\u60f3\u5b9a)\u3068\u304b\u3067\u4ee5\u4e0b\u30b3\u30de\u30f3\u30c9\u3067\u5c0e\u5165\u53ef\u80fd\u3002<\/p>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\">wget https:\/\/getcomposer.org\/download\/1.0.0-alpha11\/composer.phar<\/pre>\n<p>&nbsp;<\/p>\n<h2>monolog<\/h2>\n<h3>\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u65b9\u6cd5<\/h3>\n<p>\u540c\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3067\u4ee5\u4e0b\u30b3\u30de\u30f3\u30c9\u3067\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b\u3002<\/p>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\">php composer.phar require monolog\/monolog<\/pre>\n<p>\/var\/www\/html\/vendor\/monolog\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306b\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3055\u308c\u308b\u3002<\/p>\n<h3>\u4f7f\u7528\u65b9\u6cd5<\/h3>\n<p>\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u5f62\u3067\u4f7f\u7528\u3059\u308b\u3002<\/p>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\">&lt;?php\r\nini_set( 'display_errors', 1 );\r\n\r\nrequire('.\/vendor\/autoload.php');\r\n\r\nuse Monolog\\Logger;\r\nuse Monolog\\Handler\\StreamHandler;\r\nuse Monolog\\Formatter\\LineFormatter;\r\n\r\n$logging_path = 'log\/error.log';\r\n$log = new Logger('test');\r\n\r\n$output = \"[%datetime%] %level_name% %message% %file% %line%\\n\";\r\n\r\n$formatter = new LineFormatter($output);\r\n$stream = new StreamHandler($logging_path, Logger::DEBUG);\r\n$stream-&gt;setFormatter($formatter);\r\n$log-&gt;pushHandler($stream);\r\n\r\n$log-&gt;pushProcessor(function ($record) {\r\n    $record['file'] = $record['context']['file'];\r\n    $record['line'] = $record['context']['line'];\r\n    return $record;\r\n});\r\n\r\nfunction debug($message, $depth=''){\r\n    global $log;\r\n    $backtrace = debug_backtrace();\r\n    $key = isset($backtrace[$depth]) ? $depth : 0;\r\n    $file = $backtrace[$key]['file'];\r\n    $line = $backtrace[$key]['line'];\r\n    $context = array('file' =&gt; $file, 'line' =&gt; $line);\r\n    $log-&gt;addInfo($message, $context);\r\n}\r\n\r\ndebug('debug message!!');<\/pre>\n<p>\u5c1a\u3001\u30d5\u30a1\u30a4\u30eb\u306e\u30d1\u30fc\u30df\u30c3\u30b7\u30e7\u30f3\u3084\u30e6\u30fc\u30b6\u30fc\u306f\u9069\u5b9c\u5909\u66f4\u3059\u308b(root\u3067\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u305f\u3089vendor\/autoload.php\u304c\u8aad\u307f\u8fbc\u3081\u306a\u304b\u3063\u305f)\u3002<\/p>\n<p>&nbsp;<\/p>\n<h2>Twig<\/h2>\n<h3>\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u65b9\u6cd5<\/h3>\n<p>\u540c\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u3067\u4ee5\u4e0b\u30b3\u30de\u30f3\u30c9\u3067\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b\u3002<\/p>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\">php composer.phar require twig\/twig:1.*<\/pre>\n<p>*\u306e\u30ef\u30a4\u30eb\u30c9\u30ab\u30fc\u30c9\u306f1.*\u7cfb\u3067\u6700\u65b0\u306e\u3082\u306e\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u3066\u304f\u308c\u308b\u3089\u3057\u3044\u3002\/var\/www\/html\/vendor\/twig\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306b\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3055\u308c\u308b\u3002<\/p>\n<h3>\u4f7f\u7528\u65b9\u6cd5<\/h3>\n<p>\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u5f62\u3067\u4f7f\u7528\u3059\u308b\u3002<\/p>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"generic\">&lt;?php\r\nrequire_once '.\/vendor\/autoload.php';\r\n\r\n$loader = new Twig_Loader_String();\r\n$twig = new Twig_Environment($loader);\r\n\r\necho $twig-&gt;render('Hello {{ name }}!', array('name' =&gt; 'hoge'));<\/pre>\n<p>\u3053\u3061\u3089\u3082monolog\u3068\u540c\u69d8\u3001\u30d5\u30a1\u30a4\u30eb\u306e\u30d1\u30fc\u30df\u30c3\u30b7\u30e7\u30f3\u3068\u30e6\u30fc\u30b6\u30fc\u306b\u6ce8\u610f\u3059\u308b\u3002<\/p>\n<p>&nbsp;<\/p>\n<h2>composer\u3068\u306f<\/h2>\n<p>PHP\u306e\u30d1\u30c3\u30b1\u30fc\u30b8\u7ba1\u7406\u30b7\u30b9\u30c6\u30e0\u3089\u3057\u3044\u3002yum\u3068\u304b\u3060\u3068\u4f9d\u5b58\u95a2\u4fc2\u306b\u3088\u308a\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3067\u304d\u306a\u3044\u3053\u3068\u304c\u3042\u308b\u304c\u3001\u305d\u3046\u3044\u3063\u305f\u554f\u984c\u304c\u89e3\u6c7a\u3067\u304d\u308b\u3089\u3057\u3044\u3002\u307e\u3060\u8a66\u3057\u305f\u3070\u304b\u308a\u3067\u5b9f\u611f\u3067\u304d\u306a\u3044\u304c\u672c\u5f53\u306b\u89e3\u6c7a\u3067\u304d\u308b\u306e\u3067\u3042\u308c\u3070\u975e\u5e38\u306b\u3042\u308a\u304c\u305f\u3044\u3002<\/p>\n<p>&nbsp;<\/p>\n<h2>\u53c2\u8003\u30b5\u30a4\u30c8<\/h2>\n<p><a href=\"https:\/\/qiita.com\/tomk79\/items\/5ab61b4b24fb80fe8a90\" target=\"_blank\" rel=\"noopener\">https:\/\/qiita.com\/tomk79\/items\/5ab61b4b24fb80fe8a90<\/a><\/p>\n<p><a href=\"http:\/\/kzhishu.hatenablog.jp\/entry\/2015\/10\/04\/200000\" target=\"_blank\" rel=\"noopener\">http:\/\/kzhishu.hatenablog.jp\/entry\/2015\/10\/04\/200000<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u300cComposer\u3067\u25cb\u25cb\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u300d\u3068\u3044\u3046\u306e\u3092\u3088\u304f\u898b\u304b\u3051\u308b\u304cComposer ... <\/p>\n","protected":false},"author":1,"featured_media":1085,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[2],"tags":[],"class_list":["post-3067","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-php"],"acf":[],"aioseo_notices":[],"_links":{"self":[{"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/posts\/3067","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/comments?post=3067"}],"version-history":[{"count":2,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/posts\/3067\/revisions"}],"predecessor-version":[{"id":4780,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/posts\/3067\/revisions\/4780"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/media\/1085"}],"wp:attachment":[{"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/media?parent=3067"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/categories?post=3067"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/taitan916.info\/blog\/wp-json\/wp\/v2\/tags?post=3067"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}