本文整理匯總了TypeScript中on-finished.default方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript on-finished.default方法的具體用法?TypeScript on-finished.default怎麽用?TypeScript on-finished.default使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類on-finished
的用法示例。
在下文中一共展示了on-finished.default方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: default
export default (core: Core) => (req: Request, res: Response, next) => {
const ip = proxyaddr(req, () => true);
const ctx = core.capture({
date: new Date(),
url: `${req.protocol}://${req.hostname}${req.originalUrl}`,
ip: ip,
httpVersion: req.httpVersion,
method: req.method,
headers: req.headers
}, (status, body) => {
if (body == null || body == '') {
res.sendStatus(status);
} else {
res.status(status).send(body);
}
}, next);
onFinished(res, () => {
ctx.done(res.statusCode);
});
};
示例2: return
return (req: IExpressRequest, res: IExpressResponse, next: NextFn) => {
let startTime = new Date().getTime();
let ctx = new HttpContext(req, res);
req.access_uuid = uuid.v4();
// tslint:disable-next-line
logger.info(`[${req.access_uuid}] <== '${ctx.method()} ${ctx.url()}' ${ctx.remoteAddr()} HTTP/${ctx.httpVersion()} ${ctx.userAgent()}`);
onFinished(res, (err) => {
let reqTime = ((new Date().getTime()) - startTime) / 1000;
// tslint:disable-next-line
// _debugger.info(`${ctx.remoteAddr()}- '${ctx.method()} ${ctx.url()} HTTP/${ctx.httpVersion()}' ${ctx.status()} ${ctx.resHeader('content-length')} ${ctx.userAgent()}`);
// tslint:disable-next-line
logger.info(`[${req.access_uuid}] ==> ${ctx.status()} length:${ctx.resHeader('content-length')} time:${reqTime}s`);
if (err) {
logger.warn(`detected error coming from 'onFinished' on logger.middleware module: ${err.message}`);
logger.error(err);
}
});
next();
};
示例3: request
// Request Logging
// --------------------------------------------------------------------------------------------
request(request: http.IncomingMessage, response: http.ServerResponse) {
const start = process.hrtime();
onFinished(response, () => {
const line = buildRequestLine(request, response, since(start), this.fOptions.request);
this.logToConsole(line, ConsoleStream.info);
});
}
示例4: send
// HELPER FUNCTIONS
// =================================================================================================
function send(request: IncomingMessage, response: ServerResponse, status: number, headers: { [index: string]: string; }, body: string) {
function write () {
// response status
response.statusCode = status;
// response.statusMessage = STATUS_CODES[status];
// response headers
if (headers) {
for (let key in headers) {
response.setHeader(key, headers[key]);
}
}
// standard headers
response.setHeader('Content-Type', 'application/json; charset=utf-8')
response.setHeader('Content-Length', Buffer.byteLength(body, 'utf8').toString(10));
if (request.method === 'HEAD') {
response.end();
}
else {
response.end(body, 'utf8');
}
}
if (onFinished.isFinished(request)) {
write();
}
else {
// unpipe everything from the request
request.unpipe();
// flush the request
onFinished(request, write);
request.resume();
}
}
示例5: HttpLogMiddleware
export function HttpLogMiddleware(req, res, next) {
// request data
req._startAt = undefined
req._startTime = undefined
req._remoteAddress = getIP(req)
// response data
res._startAt = undefined
res._startTime = undefined
// record request start
recordStartTime.call(req)
// record response start
onHeaders(res, recordStartTime)
// log when response finished
onFinished(res, () => {
doLog(req, res)
})
next()
}