CASSINI源代码分析(1) - 中国WEB开发者网络 (http://www.webasp.net) -- 技术教程 (http://www.webasp.net/article/) --- CASSINI源代码分析(1) (http://www.webasp.net/article/15/14869.htm) |
| -- 作者:未知 -- 发布日期: 2004-11-16 |
| 为什么要分析CASSINI?
Cassini(卡西尼)是asp.net上的一个开源项目。主要给出一个脱离IIS实现asp.net执行环境。项目演示了如何自己创建一个web server,并且运行一个asp.net应用程序。 研究 Cassini可以了解: 1、.net 环境下的web server如何实现,注意那些问题 2、asp.net的执行本质 3、了解appDomain的执行概念 安装 没有什么问题,默认即可 运行 出现问题,主要是我的.net framework是1.0.3705 而 系统下载的经过编译的cassini.dll是在v1.1.4322下编译,更麻烦的是经过签名的。所以启动时候回提示找不到v1.1.4322的framework 而我的目标是想分析这个程序,该如何进行? 既然获得了整个源代码,我就应该从理论上熟悉并且可以掌握整个系统,我建立一个工程,将全部.cs文件和资源文件加入到一个项目,同时删除原有项目默认的form1,因为CassiniWebServer.cs已经有一个main入口。 调试,解决问题 1、编译OK,但是,无法启动,原来缺少.ico文件。不是已经加入到工程了么?原来,我们的编译程序在bin\debug目录下,所以我将CassiniWebServer..ico文件拷贝到bin\debug\下即可启动 2、输入asp.net应用程序根目录、端口、执行点,OK,点击Start,出现错误,好像告知我端口被占用。不可能!我的80端口 8080端口都没有被占用,难道是有木马?我用fport.exe查询端口,发现根本没有程序占用。那究竟是什么原因?好在可以启动进行调试,我跟踪到CassiniWebServer.cs的CassiniForm类的Start()函数,发现在以下代码处发生错误 try { _server = new Cassini.Server(portNumber, _virtRoot, _appPath); _server.Start(); } catch { ShowError( "Cassini Managed Web Server failed to start listening on port " + portNumber + ".\r\n" + "Possible conflict with another Web Server on the same port."); portTextBox.SelectAll(); portTextBox.Focus(); return; } 也就是在创建server的时候出错。 但是不利的是,源代码并未交待错误原因,而是武断的告诉我“Cassini Managed Web Server failed to start listening on port XXX”,显然,是不慎重的(估计作者对Exception不感冒)。 为了深入了解原因,我加入了 catch (Exception e){ MessageBox.Show(e.ToString()); …… 这样,就显示了一个错误提示。原来是,在asp.net的创建应用域需要用到的程序集在私有目录或者GAC中。之前安装后,看到.snk证书文件就是为了签名加密并拷贝到全局dll中的。但是我没有这样做,所以CLR会在启动进程的当前目录的子目录bin\下寻找需要的程序集。而我将原本是两个程序集的源码集合到一个程序集,导致执行搜索程序集失败。直到原因后,建立bin目录,并拷贝编译后的exe文件到asp.net的执行起点的bin目录后,系统启动OK. 3、测试,通过ie测试访问,发现一切正常,就好像在IIS下运行一样。 (待续) |
| webasp.net |