CASSINI源代码分析(1)

类别:.NET开发 点击:0 评论:0 推荐:

 

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下运行一样。

 

 (待续)

本文地址:http://com.8s8s.com/it/it42916.htm