Skip to content

Latest commit

 

History

History
183 lines (143 loc) · 3.33 KB

README.md

File metadata and controls

183 lines (143 loc) · 3.33 KB

think-logger

log4js middleware for thinkjs

Getting start

npm install think-log

在 think.js 2.x 中使用

编辑 config/hook.js 增加三个 hook

export default {
    request_begin: ['prepend', 'reqstart'],
    route_parse: ['append', 'routestart'],
    response_end: ['append', 'resend']
}

register middleware在src/common/bootstrap/middleware.js 文件中

import log from 'think-log';

think.middleware('reqstart', log.reqStart(think));

think.middleware('routestart', log.routeParse(think));

think.middleware('resend', log.responseEnd(think));

增加配置在src/common/config/config.js文件中

export default {
    logs: {
        level: 'TRACE', // TRACE  DEBUG INFO WARN ERROR FATAL
        path: think.ROOT_PATH + '/logs/',
        recordConsole: ["SQL"], // 选择要记录的think.log()相关类型的数据
        format: 'logId[%logId] ip[%ip] xRealIp[%xRealIp] time[%time] method[%method] host[%host] ' +
        'uri[%uri] refer[%refer] - [%S] - module[%module] controller[%controller] action[%action] ua[%ua]'
    }
};

接口

在 req 的 http 中怎加了

this.http.logger('trace', ' xxxxx')
this.http.addLog('xxxxxxx') // 对应 Info 日志,其值可为字符串、数组和对象
'use strict';

import Base from './base.js';

export default class extends Base {
  /**
   * index action
   * @return {Promise} []
   */
  indexAction(){
    this.http.logger('ggggggggg');

    this.http.logger(['aaa','bbbb']);

    this.http.logger({
        'a': 11111111,
        'b': 11111111,
        'c': 11111111
    });

    this.http.logger({
        'a': {
            'b': 1111111,
            'c': 1111111,
        },
        'b': 2222222,
        'c': 3333333
    });

    this.http.logger({
        'a': [111,2222,33333],
        'b': 2222222,
        'c': 3333333
    });

    this.http.logger({
        'a': [111,2222,[333,44444]],
        'b': 2222222,
        'c': 3333333
    });

    this.http.logger({
        'a': [111,2222,{
            'd': 111,
            'e': 222
        }],
        'b': 2222222,
        'c': 3333333
    });


    this.http.logger({
        'a': [111,[{
            'h': 4444,
            'i': 5555
        },{
            'k': 4444,
            'l': 5555
        }],{
            'd': 111,
            'e': {
                'f': 3333,
                'g': 4444
            }
        }],
        'b': 2222222,
        'c': 3333333
    });



    this.http.addLog({
        'a': [111,2222,{
            'd': 111,
            'e': 222
        }],
        'b': 2222222,
        'c': 3333333
    });


    this.http.addLog({
        'a': [111,[{
            'h': 4444,
            'i': 5555
        },{
            'k': 4444,
            'l': 5555
        }],{
            'd': 111,
            'e': {
                'f': 3333,
                'g': 4444
            }
        }],
        'b': 2222222,
        'c': 3333333
    });

    this.http.addLog('config', {
        'a': [111,[{
            'h': 4444,
            'i': 5555
        },{
            'k': 4444,
            'l': 5555
        }],{
            'd': 111,
            'e': {
                'f': 3333,
                'g': 4444
            }
        }],
        'b': 2222222,
        'c': 3333333
    })

    this.http.logger('info', "testdemo");

    //auto render template file index_index.html
    return this.display();
  }
}