zoukankan      html  css  js  c++  java
  • 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显示的就是方法的名字。

    就说这些吧。

    待对我记录有了更多的心得,再来和大家分享。 

  • 相关阅读:
    jquery操作checkbox方法(全选、全不选、至少选择一个、选择值/文本)
    如何设置tomcat服务器编码为utf-8编码
    eclipse创建文件package,source folder和folder区别及相互转换
    git常用命令
    Java程序员最常犯的错误盘点之Top 10
    最有用的java面试题
    Java面试进阶部分集合
    Java面试基础部分合集
    python作为计算器(数学用法)
    phthon入门介绍
  • 原文地址:https://www.cnblogs.com/xchsp/p/2258956.html
Copyright © 2011-2022 走看看