跟大家一起学习,一起进步 2005 坚强 努力 整洁

导航

DotNetNuke3.0.8文件管理器的错误及解决方法

错误描述:
    以host登录DNN3.0.8网站,点击“常规任务”上的“文件”图标,会出现如下错误:

错误: 文件管理器 当前无效.

DotNetNuke.Services.Exceptions.ModuleLoadException: 未找到路径“F:\My Projects\Asp.NET Source\DotNetNuke\DotNetNuke_3.0.8\DNN3\Portals\0\”的一部分。 ---> System.IO.DirectoryNotFoundException: 未找到路径“F:\My Projects\Asp.NET Source\DotNetNuke\DotNetNuke_3.0.8\DNN3\Portals\0\”的一部分。 at System.IO.__Error.WinIOError(Int32 errorCode, String str) at System.IO.Directory.InternalGetFileDirectoryNames(String fullPath, String userPath, Boolean file) at System.IO.Directory.InternalGetDirectories(String path, String userPath, String searchPattern) at System.IO.Directory.GetDirectories(String path, String searchPattern) at DotNetNuke.Modules.Admin.FileSystem.FileManager.PopulateTree(TreeNodeCollection objNodes, String strPath) at DotNetNuke.Modules.Admin.FileSystem.FileManager.BindFolderTree() at DotNetNuke.Modules.Admin.FileSystem.FileManager.Page_Load(Object sender, EventArgs e) --- 内部异常堆栈跟踪的结尾 ---

解决过程:
    先查看了一下路径“F:\My Projects\Asp.NET Source\DotNetNuke\DotNetNuke_3.0.8\DNN3\Portals\0\”是存在的,所以问题不是路径不存在。
    接着查看DotNetNuke.Modules.Admin.FileSystem.FileManager.BindFolderTree() 函数,发现有这么关键的一句:
    _CurRootFolder = PortalSettings.HomeDirectoryMapPath
    跟踪到PortalSettings类Component\PortalSettings.vb)文件里的第122行,有下面一句:
    Return objFolderController.GetMappedDirectory(ApplicationPath & "/" & HomeDirectory)
    原来问题就在此处,ApplicationPath是“当前应用程序的虚拟路径”,原来FileManager.BindFolderTree() 函数里面要的路径是物理路径,而这句代码得到的却是一个虚拟路径+物理路径,看来是一个Bug啊!将代码进行如下修改:
   Return objFolderController.GetMappedDirectory(HomeDirectory)
重新编译后,再运行网站,问题解决!

一点心得:
    调试ASP.NET程序时应当善于利用错误信息,逐步分析,当然前题是要有程序本身要有良好的错误捕捉机制。

posted on 2005-01-03 17:37  icfarmer  阅读(506)  评论(0编辑  收藏  举报