现在的位置: 首页 > 综合 > 正文

Server.MapPath()不为人知的秘密

2013年10月25日 ⁄ 综合 ⁄ 共 1168字 ⁄ 字号 评论关闭

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了,前几天看到一个朋友关于的困惑,于是我整理了一下,查了一点资料并自己试验了一番,如有错误,欢迎指正。

抱歉!评论已关闭.