日期:2008-05-06  浏览次数:20532 次

为什么要分析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下运行一样。



(待续)