动网论坛,站长建站首选,国内使用量最多的论坛软件 动网论坛官方技术讨论区 站长工具 申请属于您自己的免费论坛
首页 | 新闻资讯 | 网站运营 | 网络编程 | 数据库 | 服务器 | 网页设计 | 图像媒体 | 网络应用 | 搜索优化 | 资源下载 | 动网主机 | DVBOX
    本站内  互联网 ASP论坛  ASP.Net论坛  PHP论坛
   .Net → 阅读文章

 ASP.NET虚拟主机的重大安全隐患(六)

作者:秦海鹏 来源:天极Yesky 
阅读 数 393 人次 , 2004-7-30 11:03:00 

  程序三:显示文件属性和内容的程序showfile.aspx

  在显示属性和内容时需要用到的两个主要的类:

  System.IO.FileInfo:提供创建、复制、删除、移动和打开文件的实例方法,并且帮助创建 FileStream 对象。

  System.IO.StreamReader:实现一个 TextReader,使其以一种特定的编码从字节流中读取字符。除非另外指定,StreamReader的默认编码为 UTF-8,而不是当前系统的 ANSI 代码页。UTF-8 可以正确处理 Unicode 字符并在操作系统的本地化版本上提供一致的结果。

  Showfile.aspx页面主要代码:

<asp:Label id="FileDetail" runat="server"/>

  我们只是将文件的属性信息和部分内容显示在此Label上。所以没有其他复杂的代码。

  获取文件信息和内容的主要代码都在Page_Load方法中(代码在showfile.aspx.cs文件中):

//接收传入的参数,确定需要操作的文件名称
strFile2Show = Request.QueryString["file"];
//根据文件名实例化一个FileInfo对象
FileInfo fi = new FileInfo(strFile2Show);
FileDetail.Text = "文件名:";
FileDetail.Text += strFile2Show+"<br>";
FileDetail.Text += "文件大小";
//获得文件的大小,然后变换单位为KB
FileDetail.Text += (fi.Length/1024).ToString()+"K<br>";
FileDetail.Text += "创建文件时间:";
//获得文件的创建日期
FileDetail.Text += fi.CreationTime.ToString();
FileDetail.Text += "上次访问时间:";
//获得文件的上次访问日期
FileDetail.Text += fi.LastAccessTime.ToString()+"<br>";
FileDetail.Text += "上次写入时间:";
//获得文件的上次写入日期
FileDetail.Text += fi.LastWriteTime.ToString()+"<br>";
//实例化一个StreamReader对象,用于读取此FileInfo的内容
StreamReader FileReader = fi.OpenText();
//定义一个长度为1000的字符数组作为缓冲区
char[] theBuffer = new char[1000];
/*ReadBlock方法:从当前流中读取最大数量的字符并从索引开始将该数据写入缓冲区。
参数:
char[] buffer:方法返回时,包含指定的字符数组
int index:buffer 中开始写入的位置
int count:最多读取的字符数
*/
int nRead = FileReader.ReadBlock(theBuffer,0,1000);
FileDetail.Text += new String(theBuffer,0,nRead);
//关闭此 StreamReader 并释放与之关联的所有系统资源
FileReader.Close();

  到目前为止,我们实现了一个简单的web页面的服务器磁盘管理应用程序,可以查看、删除目录和文件。如果需要修改文件、新建文件和文件夹等功能,只需稍作修改,添加上相应的代码就可以。由于我们只是通过这个程序说明服务器中存在的安全隐患,所以在这里就不再实现这些功能了。

  通过这三个简单的程序,我想大家已经能够清楚的认识到这一漏洞的危害性了,如果我们不加防范的话,其他用户的程序就能被恶意使用此功能的用户查看、删除,服务器的系统日志、系统文件也没有任何安全可言了。

  
 本文Tags安全  C#  
 收藏本文  打印本文  论坛讨论  关闭窗口
· 上一篇:微软的站点搜索引擎内幕 (zt)
· 下一篇:ASP.NET虚拟主机的重大安全隐患(五)
· Application事件的执行顺序
· 通过指定IP地址得到当前的网络上的主机的域名
· VB6 中 善用 ByRef 提升速度
· 认识.NET的集合
· 使用 ADO.NET 解锁 Microsoft Access 数据(1)


关于本站 | 联系我们 | 业务合作 | 客户案例 | 诚聘英才 | 广告合作 | 收藏本站
海口动网先锋网络科技有限公司版权所有
Copyright © 2000 - 2006 Cndw.Com
中华人民共和国电信与信息服务业务经营许可证编号 琼 ICP 020077