婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > tp5框架使用composer實現日志記錄功能示例

tp5框架使用composer實現日志記錄功能示例

熱門標簽:兼職做地圖標注好賺錢嗎 蘇州外呼系統有效果嗎 亳州企業外呼系統 400 電話 辦理 地圖標注怎么做商戶驗證 智能電銷語音機器人資訊 海南外呼系統方案 打開百度地圖標注 山東電銷卡外呼系統原理是什么

本文實例講述了tp5框架使用composer實現日志記錄功能。分享給大家供大家參考,具體如下:

tp5實現日志記錄

1.安裝 psr/log

composer require psr/log

它的作用就是提供一套接口,實現正常的日志功能!

我們可以來細細的分析一下,LoggerInterface.php

?php
namespace Psr\Log;
/**
 * Describes a logger instance.
 *
 * The message MUST be a string or object implementing __toString().
 *
 * The message MAY contain placeholders in the form: {foo} where foo
 * will be replaced by the context data in key "foo".
 *
 * The context array can contain arbitrary data. The only assumption that
 * can be made by implementors is that if an Exception instance is given
 * to produce a stack trace, it MUST be in a key named "exception".
 *
 * See https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-3-logger-interface.md
 * for the full interface specification.
 */
interface LoggerInterface
{
  /**
   * System is unusable.
   *
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function emergency($message, array $context = array());
  /**
   * Action must be taken immediately.
   *
   * Example: Entire website down, database unavailable, etc. This should
   * trigger the SMS alerts and wake you up.
   *
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function alert($message, array $context = array());
  /**
   * Critical conditions.
   *
   * Example: Application component unavailable, unexpected exception.
   *
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function critical($message, array $context = array());
  /**
   * Runtime errors that do not require immediate action but should typically
   * be logged and monitored.
   *
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function error($message, array $context = array());
  /**
   * Exceptional occurrences that are not errors.
   *
   * Example: Use of deprecated APIs, poor use of an API, undesirable things
   * that are not necessarily wrong.
   *
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function warning($message, array $context = array());
  /**
   * Normal but significant events.
   *
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function notice($message, array $context = array());
  /**
   * Interesting events.
   *
   * Example: User logs in, SQL logs.
   *
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function info($message, array $context = array());
  /**
   * Detailed debug information.
   *
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function debug($message, array $context = array());
  /**
   * Logs with an arbitrary level.
   *
   * @param mixed $level
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function log($level, $message, array $context = array());
}

這是一套日志正常的接口,有層級,有消息,有具體的內容。

LogLevel.php

?php
namespace Psr\Log;
/**
 * Describes log levels.
 */
class LogLevel
{
  const EMERGENCY = 'emergency';
  const ALERT   = 'alert';
  const CRITICAL = 'critical';
  const ERROR   = 'error';
  const WARNING  = 'warning';
  const NOTICE  = 'notice';
  const INFO   = 'info';
  const DEBUG   = 'debug';
}

定義一些錯誤常量。

AbstractLogger.php實現接口

?php
namespace Psr\Log;
/**
 * This is a simple Logger implementation that other Loggers can inherit from.
 *
 * It simply delegates all log-level-specific methods to the `log` method to
 * reduce boilerplate code that a simple Logger that does the same thing with
 * messages regardless of the error level has to implement.
 */
abstract class AbstractLogger implements LoggerInterface
{
  /**
   * System is unusable.
   *
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function emergency($message, array $context = array())
  {
    $this->log(LogLevel::EMERGENCY, $message, $context);
  }
  /**
   * Action must be taken immediately.
   *
   * Example: Entire website down, database unavailable, etc. This should
   * trigger the SMS alerts and wake you up.
   *
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function alert($message, array $context = array())
  {
    $this->log(LogLevel::ALERT, $message, $context);
  }
  /**
   * Critical conditions.
   *
   * Example: Application component unavailable, unexpected exception.
   *
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function critical($message, array $context = array())
  {
    $this->log(LogLevel::CRITICAL, $message, $context);
  }
  /**
   * Runtime errors that do not require immediate action but should typically
   * be logged and monitored.
   *
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function error($message, array $context = array())
  {
    $this->log(LogLevel::ERROR, $message, $context);
  }
  /**
   * Exceptional occurrences that are not errors.
   *
   * Example: Use of deprecated APIs, poor use of an API, undesirable things
   * that are not necessarily wrong.
   *
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function warning($message, array $context = array())
  {
    $this->log(LogLevel::WARNING, $message, $context);
  }
  /**
   * Normal but significant events.
   *
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function notice($message, array $context = array())
  {
    $this->log(LogLevel::NOTICE, $message, $context);
  }
  /**
   * Interesting events.
   *
   * Example: User logs in, SQL logs.
   *
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function info($message, array $context = array())
  {
    $this->log(LogLevel::INFO, $message, $context);
  }
  /**
   * Detailed debug information.
   *
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function debug($message, array $context = array())
  {
    $this->log(LogLevel::DEBUG, $message, $context);
  }
}

Logger.php繼承AbstractLogger.php

?php
namespace Psr\Log;
use app\index\model\LogModel;
/**
 * This Logger can be used to avoid conditional log calls.
 *
 * Logging should always be optional, and if no logger is provided to your
 * library creating a NullLogger instance to have something to throw logs at
 * is a good way to avoid littering your code with `if ($this->logger) { }`
 * blocks.
 */
class Logger extends AbstractLogger
{
  /**
   * Logs with an arbitrary level.
   *
   * @param mixed $level
   * @param string $message
   * @param array $context
   *
   * @return void
   */
  public function log($level, $message, array $context = array())
  {
    // noop
    $logModel = new LogModel();
    $logModel->add($level,$message,json_encode($context));
    echo $logModel->id;
  }
}

這里面的log方法是我自己寫的!!!

我們需要把日志存儲到數據庫中!!!

這里我設計了一個log表,包含id、level、message、 context、ip、url、create_on等。

我創建了一個LogModel.php

?php
/**
 * @author: jim
 * @date: 2017/11/16
 */
namespace app\index\model;
use think\Model;
/**
 * Class LogModel
 * @package app\index\model
 *
 * 繼承Model之后,就可以使用繼承它的屬性和方法
 *
 */
class LogModel extends Model
{
  protected $pk = 'id'; // 配置主鍵
  protected $table = 'log'; // 默認的表名是log_model
  public function add($level = "error",$message = "出錯啦",$context = "") {
    $this->data([
      'level' => $level,
      'message' => $message,
      'context' => $context,
      'ip' => getIp(),
      'url' => getUrl(),
      'create_on' => date('Y-m-d H:i:s',time())
    ]);
    $this->save();
    return $this->id;
  }
}

一切都準備好了,可以在控制器中使用了!

?php
namespace app\index\controller;
use think\Controller;
use Psr\Log\Logger;
class Index extends Controller
{
  public function index()
  {
    $logger = new Logger();
    $context = array();
    $context['err'] = "缺少參數id";
    $logger->info("有新消息");
  }
  public function _empty() {
    return "empty";
  }
}

小結:

composer很好很強大!

這里是接口Interface的典型案例,定義接口,定義抽象類,定義具體類。

有了命名空間,可以很好的引用不同文件夾下的庫!

互相使用,能夠防止高內聚!即便是耦合也相對比較獨立!

有了這個日志小工具,平時接口的一些報錯信息就能很好的捕捉了!

只要

use Psr\Log\Logger;

然后

$logger = new Logger();
$logger->info("info信息");

使用非常方便!!!

附上獲取ip、獲取url的方法。

//獲取用戶真實IP
function getIp() {
  if (getenv("HTTP_CLIENT_IP")  strcasecmp(getenv("HTTP_CLIENT_IP"), "unknown"))
    $ip = getenv("HTTP_CLIENT_IP");
  else
    if (getenv("HTTP_X_FORWARDED_FOR")  strcasecmp(getenv("HTTP_X_FORWARDED_FOR"), "unknown"))
      $ip = getenv("HTTP_X_FORWARDED_FOR");
    else
      if (getenv("REMOTE_ADDR")  strcasecmp(getenv("REMOTE_ADDR"), "unknown"))
        $ip = getenv("REMOTE_ADDR");
      else
        if (isset ($_SERVER['REMOTE_ADDR'])  $_SERVER['REMOTE_ADDR']  strcasecmp($_SERVER['REMOTE_ADDR'], "unknown"))
          $ip = $_SERVER['REMOTE_ADDR'];
        else
          $ip = "unknown";
  return ($ip);
}
// 獲取url
function getUrl() {
  return 'http://'.$_SERVER['SERVER_NAME'].':'.$_SERVER["SERVER_PORT"].$_SERVER["REQUEST_URI"];
}

更多關于thinkPHP相關內容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結》、《ThinkPHP常用方法總結》、《codeigniter入門教程》、《CI(CodeIgniter)框架進階教程》、《Zend FrameWork框架入門教程》及《PHP模板技術總結》。

希望本文所述對大家基于ThinkPHP框架的PHP程序設計有所幫助。

您可能感興趣的文章:
  • Laravel框架中composer自動加載的實現分析
  • PHP管理依賴(dependency)關系工具 Composer的自動加載(autoload)
  • Laravel 解決composer相關操作提示php相關異常的問題
  • laravel 實現向公共模板中傳值 (view composer)
  • 淺談laravel 5.6 安裝 windows上使用composer的安裝過程
  • 使用composer 安裝 laravel框架的方法圖文詳解
  • 一次因composer錯誤使用引發的問題與解決
  • windows環境下使用Composer安裝ThinkPHP5
  • PHP創建自己的Composer包方法
  • 分析Composer實現自動加載原理

標簽:安康 溫州 萊蕪 金華 呼倫貝爾 綏化 清遠 紹興

巨人網絡通訊聲明:本文標題《tp5框架使用composer實現日志記錄功能示例》,本文關鍵詞  tp5,框架,使用,composer,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《tp5框架使用composer實現日志記錄功能示例》相關的同類信息!
  • 本頁收集關于tp5框架使用composer實現日志記錄功能示例的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    午夜视频一区在线观看| 国产精品妹子av| 色综合久久久久久久久| 成人免费视频免费观看| 不卡av免费在线观看| 色成人在线视频| 欧美精品日韩精品| 91.麻豆视频| 欧美电影免费观看完整版| 国产亚洲精品福利| 亚洲美女视频一区| 日韩福利电影在线| 国产成人综合亚洲91猫咪| 97久久精品人人做人人爽50路 | 色8久久人人97超碰香蕉987| 欧美理论在线播放| 国产三级久久久| 亚洲福利一二三区| 国产一区不卡精品| 色猫猫国产区一区二在线视频| 日韩天堂在线观看| 亚洲免费观看高清| 国模娜娜一区二区三区| 色婷婷亚洲婷婷| 精品国产免费一区二区三区香蕉| 中文字幕一区二区三| 免费观看在线色综合| 一本色道久久综合精品竹菊| 精品噜噜噜噜久久久久久久久试看| 国产精品久久久久7777按摩| 蜜桃久久久久久久| 欧美主播一区二区三区| 国产精品亲子伦对白| 美女性感视频久久| 欧美日韩dvd在线观看| 国产精品九色蝌蚪自拍| 久久99精品久久久久| 精品婷婷伊人一区三区三| 久久久久久久久免费| 日韩经典一区二区| 欧美亚洲一区二区在线| 国产精品久久精品日日| 国产一区在线视频| 精品久久久久久亚洲综合网| 日韩经典中文字幕一区| 欧美日本一区二区三区| 一区二区在线观看av| 99久久免费视频.com| 国产拍揄自揄精品视频麻豆| 韩国在线一区二区| 日韩一区二区电影网| 亚洲成人在线免费| 欧美日韩中字一区| 婷婷成人激情在线网| 欧洲视频一区二区| 一区二区三区日韩在线观看| 色综合中文字幕国产| 国产精品国产精品国产专区不片| 国产电影精品久久禁18| 久久久一区二区三区捆绑**| 美腿丝袜亚洲一区| 日韩欧美国产一二三区| 日韩av二区在线播放| 91精品久久久久久蜜臀| 无吗不卡中文字幕| 日韩午夜精品电影| 精品一区二区三区视频| 久久免费电影网| 国产风韵犹存在线视精品| 欧美极品少妇xxxxⅹ高跟鞋| 成人少妇影院yyyy| 亚洲柠檬福利资源导航| 欧美影院一区二区三区| 性欧美疯狂xxxxbbbb| 在线电影欧美成精品| 免费观看久久久4p| 精品不卡在线视频| 懂色中文一区二区在线播放| 最新日韩av在线| 在线视频亚洲一区| 欧美aa在线视频| 亚洲精品一区二区三区影院 | 五月婷婷另类国产| 欧美二区在线观看| 奇米综合一区二区三区精品视频| 69堂国产成人免费视频| 偷窥少妇高潮呻吟av久久免费| 欧美一三区三区四区免费在线看| 日韩电影在线一区二区三区| www欧美成人18+| 99精品视频在线播放观看| 亚洲一区二区在线播放相泽 | 国产精品护士白丝一区av| 不卡的电影网站| 亚洲欧美影音先锋| 欧美日本视频在线| 另类欧美日韩国产在线| 国产精品久久午夜| 8x8x8国产精品| 免费精品视频最新在线| 国产丝袜欧美中文另类| 欧美色偷偷大香| 日本中文在线一区| 国产精品久久三区| 6080yy午夜一二三区久久| 久草在线在线精品观看| 亚洲色图欧洲色图| 久久中文字幕电影| 欧美日韩一区二区电影| 成人丝袜18视频在线观看| 久久爱www久久做| 亚洲综合一区在线| 国产精品毛片久久久久久久| 91精品婷婷国产综合久久竹菊| 99久久夜色精品国产网站| 紧缚奴在线一区二区三区| 亚洲成人免费电影| 亚洲欧美一区二区三区久本道91| 日韩欧美电影一二三| 欧美日韩一区二区三区在线看| 99精品国产一区二区三区不卡| 国内精品在线播放| 蜜臀久久久久久久| 亚洲成人黄色影院| 一区二区高清在线| 中文字幕视频一区| 欧美国产成人在线| 久久一区二区视频| 欧美成人高清电影在线| 91麻豆精品国产91久久久更新时间 | 免费日韩伦理电影| 一区二区视频在线| 中日韩免费视频中文字幕| 亚洲精品在线免费观看视频| 日韩一区二区三区在线| 欧美日本在线看| 欧洲av在线精品| 成人avav影音| 精品在线免费观看| 美日韩一级片在线观看| 美女性感视频久久| 久久精品国产77777蜜臀| 日韩二区在线观看| 麻豆国产精品官网| 看片网站欧美日韩| 麻豆一区二区三区| 捆绑调教美女网站视频一区| 久久精品国产免费看久久精品| 日韩av中文字幕一区二区三区| 午夜精品成人在线| 免费成人深夜小野草| 激情小说亚洲一区| 国产成人自拍网| 国产成人午夜片在线观看高清观看| 国产麻豆欧美日韩一区| 国产很黄免费观看久久| 丁香六月综合激情| 成人h动漫精品| 日本高清视频一区二区| 欧美日韩精品欧美日韩精品一| 精品视频资源站| 日韩欧美的一区| 久久久久久久久久看片| 国产精品成人一区二区三区夜夜夜| 国产精品免费人成网站| 一区二区欧美视频| 日韩主播视频在线| 激情欧美日韩一区二区| 国产成人aaaa| av一本久道久久综合久久鬼色| 一本到不卡免费一区二区| 欧美日韩一区视频| 久久久久久日产精品| 中文字幕中文字幕中文字幕亚洲无线| 亚洲日本丝袜连裤袜办公室| 午夜欧美大尺度福利影院在线看| 无码av免费一区二区三区试看| 极品美女销魂一区二区三区 | 久久久久国产精品麻豆ai换脸| 国产欧美视频一区二区| 国产精品短视频| 亚洲第一主播视频| 国产一区二区福利| 欧美性猛交xxxx乱大交退制版| 欧美一级国产精品| 国产精品国产自产拍在线| 亚洲国产一区视频| 国产在线一区观看| 91丨九色丨尤物| 日韩美女视频在线| 亚洲精品视频在线看| 理论电影国产精品| 欧美视频在线观看一区| 久久久久97国产精华液好用吗| 亚洲另类中文字| 黄页视频在线91| 7777精品伊人久久久大香线蕉超级流畅| 国产精品素人一区二区| 日本美女一区二区三区| 本田岬高潮一区二区三区|