Sea*_*een 9 mvc-mini-profiler asp.net-web-api angularjs asp.net-web-api2
在MiniProfiler社区上交叉发布.
我正在尝试将MiniProfiler放入我当前的堆栈中.我认为我主要是设置,但我错过了UI方法,并希望得到关于最佳方法的建议.
所以,目前的方法RenderIncludes()是我无法获得的.
包含JS文件并将其设置为从SQL Server存储中检索信息的最佳方法是什么?我知道这些文件包含在UI repo中,但我没有看到用于显式配置的文档.
MiniProfiler和MiniProfiler.EF6包.(不确定是否有必要):
<add name="MiniProfiler" path="mini-profiler-resources/*" verb="*" type="System.Web.Routing.UrlRoutingModule" resourceType="Unspecified" preCondition="integratedMode" />
Run Code Online (Sandbox Code Playgroud)
public class AddMiniProfilerCORSHeaderFilter : ActionFilterAttribute
{
public override void OnActionExecuted(HttpActionExecutedContext actionExecutedContext)
{
actionExecutedContext.Response.Headers.Add("Access-Control-Expose-Headers", "X-MiniProfiler-Ids");
}
}
Run Code Online (Sandbox Code Playgroud)
config.Filters.Add(new AddMiniProfilerCORSHeaderFilter());`
Run Code Online (Sandbox Code Playgroud)
var connectionString = ConfigurationReader.GetConnectionString(Constants.ConfigSettings.CONNECTION_STRING_NAME);
MiniProfiler.Settings.Storage = new SqlServerStorage(connectionString);
MiniProfilerEF6.Initialize();
Run Code Online (Sandbox Code Playgroud)
protected void Application_BeginRequest()
{
if (Request.IsLocal || ConfigurationReader.GetAppSetting(Constants.ConfigSettings.USE_PROFILER, false))
{
var sessionId = Guid.NewGuid().ToString();
MiniProfiler.Start(sessionId);
}
}
protected void Application_EndRequest()
{
MiniProfiler.Stop();
}
Run Code Online (Sandbox Code Playgroud)
<link rel="stylesheet" href="js/lib/miniprofiler/includes.css" />
Run Code Online (Sandbox Code Playgroud)
<script async type="text/javascript"
id="mini-profiler"
src="js/lib/miniprofiler/includes.js?v=1.0.0.0"
data-current-id=""
data-path="https://localhost:44378/api/profiler/"
data-children="true"
data-ids=""
data-version="1.0.0.0"
data-controls="true"
data-start-hidden="false"
data-trivial-milliseconds="5">
</script>
Run Code Online (Sandbox Code Playgroud)
当我做这些事情时,看起来它找不到合适的WebAPI控制器来呈现结果.如果我能弄清楚控制器的位置或复制它(正如我现在试图做的那样),我想我会做生意.
该RenderIncludes函数会将<script>标签输出到页面。它在 UI Repo 中定义为include.partial.html,目前如下所示:
<script async type="text/javascript" id="mini-profiler"
src="{path}includes.js?v={version}" data-version="{version}"
data-path="{path}" data-current-id="{currentId}"
data-ids="{ids}" data-position="{position}"
data-trivial="{showTrivial}" data-children="{showChildren}"
data-max-traces="{maxTracesToShow}" data-controls="{showControls}"
data-authorized="{authorized}" data-toggle-shortcut="{toggleShortcut}"
data-start-hidden="{startHidden}" data-trivial-milliseconds="{trivialMilliseconds}">
</script>
Run Code Online (Sandbox Code Playgroud)
这是运行渲染的 Javascript 片段。
该RenderIncludes函数在这里定义。它执行以下操作:
<script>因此,如果您无法调用RenderIncludes,那么您应该没有理由不能将脚本文件放在适当的位置,检索未查看的 ID,而是将它们与您想要的任何其他设置值一起放入标签中<script>,然后输出标签。
检索 Id 值的关键代码行是:
var ids = authorized
? MiniProfiler.Settings.Storage.GetUnviewedIds(profiler.User)
: new List<Guid>();
ids.Add(profiler.Id);
Run Code Online (Sandbox Code Playgroud)
其中是(在当前请求上运行profiler的当前实例。MiniProfiler
您可能还需要确保可以处理脚本对 /mini-profiler-resources/results 进行的调用(将id探查器作为参数传递)。其核心位于函数GetSingleProfilerResult(HttpContext context)中
| 归档时间: |
|
| 查看次数: |
1166 次 |
| 最近记录: |