如何计算响应生命周期的请求?

时间:2013-08-30 20:06:14

标签: servicestack

我正在向请求对象添加一个cookie,并从响应中的当前时间中减去它,但我假设有更好的方法来执行此操作。此外,重新使用相同的Cookie密钥可能无法在实际用例中使用。

有什么想法吗?

            RequestFilters.Add((request, response, dto) =>
                               {
                                   request.Cookies.Add("Start", new Cookie("Start", DateTime.Now.ToString()));
                                   request.ResponseContentType = ContentType.Json;
                               });

        ResponseFilters.Add((request, response, dto) =>
                                {
                                    Console.WriteLine("{0} : [{1}]", request.RawUrl, DateTime.Now.Subtract(DateTime.Parse(request.Cookies["Start"].Value)).Milliseconds);
                                    request.Cookies.Clear();
                                });

1 个答案:

答案 0 :(得分:5)

不,不要乱用请求cookie。一种可能的方法是在请求过滤器中将日期时间添加到请求上下文中。

request.Items.Add("RequestTimer", DateTime.Now);

然后在响应过滤器中读出它

DateTime.Now.Subtract((DateTime) request.Items["RequestTimer"]);

但准确性取决于请求/响应过滤器的运行顺序。

您可以使用ServiceStacks built-in profiling代替