本文整理汇总了C#中IHttpContext.FinalizeResponse方法的典型用法代码示例。如果您正苦于以下问题:C# IHttpContext.FinalizeResponse方法的具体用法?C# IHttpContext.FinalizeResponse怎么用?C# IHttpContext.FinalizeResponse使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类IHttpContext
的用法示例。
在下文中一共展示了IHttpContext.FinalizeResponse方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: FinalizeRequestProcessing
private void FinalizeRequestProcessing(IHttpContext ctx, Stopwatch sw, bool ravenUiRequest)
{
LogHttpRequestStatsParams logHttpRequestStatsParam = null;
try
{
logHttpRequestStatsParam = new LogHttpRequestStatsParams(
sw,
ctx.Request.Headers,
ctx.Request.HttpMethod,
ctx.Response.StatusCode,
ctx.Request.Url.PathAndQuery);
}
catch (Exception e)
{
logger.WarnException("Could not gather information to log request stats", e);
}
ctx.FinalizeResponse();
if (ravenUiRequest || logHttpRequestStatsParam == null || sw == null)
return;
sw.Stop();
LogHttpRequestStats(logHttpRequestStatsParam);
ctx.OutputSavedLogItems(logger);
}
示例2: HandleActualRequest
public void HandleActualRequest(IHttpContext ctx)
{
var isReadLockHeld = disposerLock.IsReadLockHeld;
if (isReadLockHeld == false)
{
if (disposerLock.TryEnterReadLock(TimeSpan.FromSeconds(10)) == false)
{
ctx.SetStatusToNotAvailable();
ctx.FinalizeResponse();
logger.Warn("Could not enter disposer lock, probably disposing server, aborting request");
return;
}
}
try
{
if (disposed)
return;
var sw = Stopwatch.StartNew();
bool ravenUiRequest = false;
try
{
ravenUiRequest = DispatchRequest(ctx);
}
catch (Exception e)
{
ExceptionHandler.TryHandleException(ctx, e);
if (ShouldLogException(e))
logger.WarnException("Error on request", e);
}
finally
{
try
{
FinalizeRequestProcessing(ctx, sw, ravenUiRequest);
}
catch (Exception e)
{
logger.ErrorException("Could not finalize request properly", e);
}
}
}
finally
{
if (isReadLockHeld == false)
disposerLock.ExitReadLock();
}
}