ASP.NET应用实例(一)
ASP.NET是微软.NET宏大战略的一部分。我们不能仅仅将它看成是ASP语言的进化版本,它所能发挥的威力将使开发人员激动与惊喜,更快、更好地实现梦想!本文就介绍ASP.NET的几个常用实例,通过与ASP语言实现方式的对比,让我们对它的强大眼见为实!实例内容(包括下载代码)如下: ● 在ASP.NET中实现目录浏览 ● 在ASP.NET中随意创建图形信息 ● 在ASP.NET中显示事件日志记录 要运行这些例程,需要在Web服务器上安装Microsoft .NET Framework SDK。要理解代码的含义,需要对C# 编程语言有一定程度的了解。 在ASP.NET中实现目录浏览 在用ASP语言编程的"美好旧时光"中,我们应该不会忘记FileSystemObject对象。它允许对文件系统进行读、写以及目录浏览。但是这个对象模型并不十分完善,比如对于二进制文件来说,还没有开始操作就已经到达范围的结尾了。另外,还有一些希望的函数和属性在ASP中也没有具备。 但是出现了ASP.NET,这些愿望就都能在System.IO 名称空间中被 .NET Framework 类所实现。你会发现,文件处理从没有这么容易过,而且最重要的是从没有这么强大过。 这里,我们将演示文件处理的一个部分:文件和目录列表。我们创建了一些脚本程序,你可以将其应用在自己的应用程序中。 列举驱动器 首先,我们要知道在计算机上有哪些可浏览的驱动器,这些代码保存在文件listdrives.aspx中: <% @Page Language="C#" %> <% @Import Namespace="System.IO" %> <% string[] achDrives = Directory.GetLogicalDrives(); int nNumOfDrives = achDrives.Length; Response.Write("<ul>"); for (int i=0; i < nNumOfDrives; i++) { Response.Write("<li><a href=\"listdir.aspx?dir="); Response.Write(Server.UrlEncode(achDrives)); Response.Write("\">" + achDrives); Response.Write("</a><br>"); } Response.Write("</ul>"); %> 根据 @Import 名称空间标识,在System.IO 名空间中有一个类叫做Directory,它包含了一些可用于目录上的功能。这个类中还包含静态(不需要对象例示就能调用的)方法GetLogicalDrives,它提供了包含驱动器字母的一个字符串数列。 当然,不能只有一个从GetLogicalDrives 获取的驱动器简单列表,还需要增加了一个页面,在这个页面中提供有关驱动器根目录的信息。 列出目录和文件 有了目录,我们就可以进一步探索子目录、文件以及目录本身的属性(如创建的日期等)了。文件 listdir.aspx 演示了如何执行这些功能: <% @Page Language="C#" %> <% @Import Namespace="System.IO" %> <% string strDir2List = Request.QueryString.Get("dir"); Directory thisOne = null; try { thisOne = new Directory(strDir2List); // Reading the directory properties Response.Write("<p>Creation: " + thisOne.CreationTime.ToString() + "</p>"); Directory[] subDirectories = thisOne.GetDirectories(); Response.Write("<ul>"); for (int i=0; i < subDirectories.Length; i++) { Response.Write("<li><a href=\"listdir.aspx?dir="); Response.Write(Server.UrlEncode(subDirectories.FullName)); Response.Write("\">" + subDirectories.Name); Response.Write("</a><br>"); } Response.Write("</ul>"); File[] theFiles = thisOne.GetFiles(); Response.Write("<ul>"); for (int i=0; i < theFiles.Length; i++) { Response.Write("<li><a href=\"showfile.aspx?file="); Response.Write(Server.UrlEncode(theFiles.FullName)); Response.Write("\">" + theFiles.Name); Response.Write("</a><br>"); } Response.Write("</ul>"); } catch (Exception e) { Response.Write("Access not possible, error: <i>"); Response.Write(e.ToString() + "</i>"); Response.End(); } %> 我们使用GetDirectories方法实现目录信息的读取。这个方法返回一个目录对象数组,我们可以用这个数组来建立想要的功能,比如说建立一个更深入的链接。这同样适用于GetFiles方法,它返回一个文件对象数组。 你可能注意到这里使用了try-catch语句。是的,这是为了防止例外情况的发生。比如,当用户试图访问一些不允许他访问的内容时。 显示文件信息 现在到了文件这一级。一个文件有许多属性,为了缩短脚本,下面的例程(文件showfile.aspx)只显示了其中的一些: <% @Page Language="C#" %> <% @Import Namespace="System.IO" %> <html> <head><title>File Info</title></head> <body> <% string strFile2Show = Request.QueryString.Get("file"); File thisOne = new File(strFile2Show); %> <table> <tr><td>Name:</td><td><%=thisOne.Name%></td></tr> <tr><td>Path:</td><td><%=thisOne.FullName%></td></tr> <tr><td>Directory:</td><td><%=thisOne.DirectoryName%></td></tr> <tr> <td>Date created:</td> <td><%=thisOne.CreationTime.ToString()%></td> </tr> <tr> <td>Size:</td> <td><%=thisOne.Length.ToString()%> Bytes</td> </tr> <tr> <td>Last access:</td> <td><%=thisOne.LastAccessTime.ToString()%></td> </tr> <tr> <td>Last modified:</td> <td><%=thisOne.LastWriteTime.ToString()%></td> </tr> </table> <% StreamReader theReader = thisOne.OpenText(); char[] theBuffer = new char[255]; int nRead = theReader.ReadBlock(theBuffer, 0, 255); Response.Write("<pre>"); Response.Write(Server.HtmlEncode(new String(theBuffer,0,nRead))); Response.Write("</pre>"); %> </body> </html> 为了演示实现的简单性,在这段脚本代码的结尾处抄了个近路执行文件的读取。首先,打开一个 StreamReader 对象,创建一个缓冲器,用ReadBlock方法来填充缓冲器,并且将 HTML编码段传递给客户;然后很快地就形成了一个小型的"文件预览"。没有费多大周折,你看操作文件的内容是多么得简单 :-) 递归循环以显示目录列表 最后,我们还要编写一个创建目录树的程序recursivelisting.aspx。在其中,我们使用函数RecursiveDump来生成目录树。请看具体代码: <% @Page Language="C#" %> <% @Import Namespace="System.IO" %> <% string strDir2List = Request.QueryString.Get("dir"); Directory thisOne = new Directory(strDir2List); Response.Write("<pre>"); RecursiveDump(thisOne, 0); Response.Write("</pre>"); %> <script language="C#" runat="server"> void RecursiveDump(Directory theDir, int nLevel) { Directory[] subDirectories = theDir.GetDirectories(); for (int i=0; i < subDirectories.Length; i++) { Response.Write(new String(' ',nLevel)); Response.Write(subDirectories.Name + "\r\n"); RecursiveDump(subDirectories, nLevel+1); } } </script> 为了简单起见,这里只使用了空格来生成目录树结构。为使空格在HTML中可以生效,我们必须使用<PRE>标记,否则这些空格就会被忽视。 函数本身有两个参数:一个是目录对象,一个是整数变量以指示当前级别。在当前级别中,用 GetDirectories读取子目录信息,然后在一个 for循环中显示它。对于每个Directory对象, 都调用 RecursiveDump函数,然后级别加1。 注意:列举整个驱动器会花费很多时间。最后,让我们来看看浏览器中的执行结果: 小 结 本文介绍了System.IO 名称空间中的两个对象:Directory和 File。虽然"只"用它们简单显示了目录和文件信息,但我们要知道:这两个对象是执行文件处理的基础。 |