美文网首页
tp框架内自定义日志文件写入

tp框架内自定义日志文件写入

作者: hddd | 来源:发表于2019-03-21 14:49 被阅读0次

不会吹牛不会坎天的phper,仅以代码呈上,谢谢阅读!

/**

* 打印log日志

* @param 文件名 第几行 日志内容

*/

function wx_log($basename=null,$num=null,$msg=null){

    if(is_array($msg)){

        $msg = json_encode($msg,JSON_UNESCAPED_UNICODE);

    }

    //$msg = [2018-04-11 09:22:56]文件名:wxpay,第29行,[info]:日志信息

    $msg = '['.date("Y-m-d H:i:s").']'.'文件名:'.$basename.',第'.$num.'行,'.'[info]:'.$msg;

    $rootpath = ROOT_PATH.DS.'public'. DS .'logs'. DS;

    makedir($rootpath);

    // 日志文件名:日期.txt

    $path = $rootpath.date("Ymd").'.txt';

    file_put_contents($path, $msg.PHP_EOL,FILE_APPEND);

}

/**

* [makedir  迭代创建级联目录]

* @param  [type] $path [目录路径]

* @return [type]      [Boolean]

*/

function makedir($path){

    $arr=array();

    while(!is_dir($path)){

        array_push($arr,$path);//把路径中的各级父目录压入到数组中去,直接有父目录存在为止(即上面一行is_dir判断出来有目录,条件为假退出while循环)

        $path=dirname($path);//父目录

    }

    if(empty($arr)){//arr为空证明上面的while循环没有执行,即目录已经存在

        // echo $path,'已经存在';

        return true;

    }

    while(count($arr)){

        $parentdir=array_pop($arr);//弹出最后一个数组单元

        mkdir($parentdir);//从父目录往下创建

    }

}

相关文章

  • tp框架内自定义日志文件写入

    不会吹牛不会坎天的phper,仅以代码呈上,谢谢阅读! /** * 打印log日志 * @param 文件名 第几...

  • Filebeat占用文件句柄

    背景 平台使用整套的ELK日志框架:服务写本地文件日志,由Filebeat监控本地日志,并写入ES。本地Fileb...

  • 工具类之LogUtils

    安卓开发离不开记录log日志,封装了一份简单的日志工具类,具有设置日志总开关,是否写入文件,日志过滤器和自定义标签...

  • MySQL相关

    一、查询日志开启 方式1 通过命令 日志写入到文件 日志写入到数据表 方式2 通过配置文件 注意:对应配置的日志文...

  • 本地环境域名重定向

    当下载好的TP5框架放到www下面tp5文件内,当需要访问这个项目时在输入localhoust时 需要到www/t...

  • Call to a member function displa

    TP自定义类文件构造方法,没有引入父类构造方法。

  • bat 检测网络

    bat检测网络并将具体时间写入日志文件

  • Replaykit 日志/文件获取问题

    关于Replaykit日志/写入文件的问题的问题. 1.replaykit写入的文件怎么获取... 思路:利用Ap...

  • ThinkPHP学习

    ThinkPHP ThinkPHP的开发模式 TP框架的配置文件 TP表达式中运算符 创建Model模型

  • Gin日志处理

    日志文件的写入 package mainimport ( "io" "os" "github.c...

网友评论

      本文标题:tp框架内自定义日志文件写入

      本文链接:https://www.haomeiwen.com/subject/ofnqvqtx.html