CASSINI源代码分析
(1)
2004-11-10
为什么要分析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下运行一样。
(待续)