日期:2014-05-17  浏览次数:21036 次

散分: Server.MapPath()不为人知的秘密
ASP中,常用Server.MapPath()来获取文件或文件夹路径,但是你可能碰到过这个方法出错的情况,而在手册或者教程中根本找不到相应的说明,只能从网上搜索到问题的答案,本文是我的经验分享,希望对大家有用。

看过本文,才敢说你懂得用Server.MapPath()

1. 为MapPath方法指定的Path参数中包含无效字符。 ASP 0214 (0x80004005)

   这个错误,不能说很常见,但也有很多人遇见过,绝大多数情况因为没有出错而被我们所忽略了。

   例子:
   <%=Server.MapPath("Yes,I do.txt")%>  (Yes,I do.txt是一个合法的文件名)
   这样的文件名可能来自于用户上传、输入、或者网站程序自身。
   看到出错信息的之后,很容易知道,逗号不能用在MapPath参数里。

   那么,到底哪些字符不能被用在MapPath参数里呢?
   答案可能出乎你的预料:
        星号 (*)
        问号 (?)
        尖括号,即大于小于号 (< 或 >)
        逗号 (,)
        冒号 (:)
        分号 (;)
        单引号、双引号 (' 或 ")
        右方括号 (])
        连续斜杠,无论正斜线还是反斜线 (// 或 \\ 或 /\ 或 \/)

   这还意味着,MapPath参数里允许有:
        换行符
        回车符
        制表符
        竖线(|)
   虽然MapPath允许,但这些是文件名、目录名所不允许的,健壮的程序要考虑这个情况。

   可以参考的官方说明

2. 路径参数超过了最大允许长度。 ASP 0214 (0x80004005)
   简单的例子:
   <%=Server.MapPath("XXXXXXXXXXX...(此处省略300字)...")%>
      上面这句一定出错,因为太长了。那么再看下面一句,
   <%=Server.MapPath("XXXXXXXXXXX")%>
      看似没有问题,但在特定环境下会出错,比如你的ASP放在很深的目录里,或者名字很长的目录里。

   结论:
       Server.MapPath(path)的返回值的总长度是限制在不超过259个字符的。

   我的分析:
       为什么是259呢,我实验验证出来的。盘符路径(如C:\)占了3个字符,剩下的刚好是256个字符,也就是说,ASP的设计者为中间结果分配了一个512字节的存储空间(256个字符,每字符占2个字节,无论中英文,Unicode编码字符一律占2字节),再用盘符路径加上这个结果。
       个别极品同学,把盘符Z都用光了,可能会用出两位字母的盘符,那个什么情形我就不知道了。
       话说为什么要限制256个字符呢?也许是考虑到Windows系统下,路径+文件名(不含前面的C:\)的长度的极限就是256。不信自己试试,或者去找比尔盖茨理论。



除了某个旧ASP站点的维护,我这几年已经没接触ASP了,前几天看到一个朋友关于的困惑,于是我整理了一下,查了一点资料并自己试验了一番,如有错误,欢迎指正。
------最佳解决方案--------------------
支持LZ,有空去驗證下,還沒太留意過
------其他解决方案--------------------
支持楼主,进来拿点分
------其他解决方案--------------------
http://topic.csdn.net/u/20100824/17/c26d37f3-46cd-432a-83f9-0b3aa10af308.html曾经就为此问题研究过。楼主论文太迟发表啦
------其他解决方案--------------------
http://msdn.microsoft.com/en-us/library/ms524632%28VS.90%29.aspx
------其他解决方案--------------------
引用:
http://topic.csdn.net/u/20100824/17/c26d37f3-46cd-432a-83f9-0b3aa10af308.html曾经就为此问题研究过。楼主论文太迟发表啦

他这个帖子只能说是发现了错误1,很单一和偶然,谈不上研究,更没有整理、归纳。
------其他解决方案--------------------
该回复于2012-09-06 08:42:35被版主删除
------其他解决方案--------------------
该回复于2012-09-06 08:27:04被版主删除