wojilu源码简析---如何跟踪调试wojilu
以下是我简单看了看wojilu源码的一点心得,wojilu的源码非常庞大,没有还没有仔细深入研究,说的不对的地方还请蛋神指正,以免误人。
wojilu框架服务器端简单地来说就是[进去的是url,出来的是html]。
代码在这里:[wojilu1.8\wojilu\Web\Mvc\ProcessContext.cs]
public static void Begin( MvcContext ctx ) {
WebStopwatch.Start();
MvcEventPublisher.Instance.BeginProcessMvc( ctx );
List<ProcessorBase> processorList = initProcessor();
ProcessContext context = new ProcessContext( ctx );
foreach (ProcessorBase p in processorList) {
if (context.isEnd()) break; // showEnd 会跳过下面所有处理器,除了 RenderProcessor
if (context.ctx.utils.GetCancelMvcProcessor().Contains( p.GetType() )) continue; // cancelProcessor 会跳过指定处理器
p.Process( context );
context.ctx.utils.skipCurrentProcessor( false ); // 重置状态 // skipCurrentProcessor 会跳过当前处理器的剩余部分
}
// 呈现页面内容
if (skinRender( ctx ) == false) new RenderProcessor().Process( context );
ctx.web.CompleteRequest();
}
这里用到的似乎是设计模式里讲到的职责链模式。即各个processor依次对用户请求进行处理,并将自己处理的结果放入ProcessContext,后面的processor依赖前面的processor的处理结果。
全部的processor在这里:
private static List<ProcessorBase> initProcessor() {
List<ProcessorBase> list = new List<ProcessorBase>();
list.Add( new RouteProcessor() );
list.Add( new InitContextProcessor() );
list.Add( new ActionMethodChecker() );
list.Add( new ForbiddenActionChecker() );
list.Add( new LoginActionChecker() );
list.Add( new HttpMethodChecker() );
list.Add( new PermissionChecker() );
list.Add( new ActionProcessor() );
list.Add( new LayoutProcessor() );
list.Add( new NsLayoutProcessor() );
return list;
}
在加上最后的页面呈现RenderProcessor。
wojilu代码庞大,controller有数百之多,有时候我们不知道一个链接点击之后,会走到哪个controller里,不好跟踪调试。这里我发现一个简单的办法,就是在上面的 ActionProcessor里面的Process方法中[wojilu1.8\wojilu\Web\Mvc\Processors\ActionProcessor.cs] ,有一行代码, setControllerView( controller, actionMethod );
在这里打上断点,controller参数显示的就是controller的名字, actionMethod显示的就是方法的名字。
就说这些吧。
待对我记录有了更多的心得,再来和大家分享。