明凯博客

关注网站技术,一个特立独行的程序员

Asp中Server.MapPath()不支持的路径名字详解

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

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

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

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

例子:

1
< %=Server.MapPath("Yes,I do.txt")%>  '(Yes,I do.txt是一个合法的文件名)

这样的文件名可能来自于用户上传、输入、或者网站程序自身。
看到出错信息的之后,很容易知道,逗号不能用在MapPath参数里。

那么,到底哪些字符不能被用在MapPath参数里呢?
答案可能出乎你的预料:

星号 (*)
问号 (?)
尖括号,即大于小于号 (< 或 >)
逗号 (,)
冒号 (:)
分号 (;)
单引号、双引号 (‘ 或 “)
右方括号 (])
连续斜杠,无论正斜线还是反斜线 (// 或 \\ 或 /\ 或 \/)

这还意味着,MapPath参数里允许有:

换行符
回车符
制表符
竖线(|)

虽然MapPath允许,但这些是文件名、目录名所不允许的,健壮的程序要考虑这个情况。

2. 路径参数超过了最大允许长度。 ASP 0214 (0x80004005)
简单的例子:

1
 < %=Server.MapPath("XXXXXXXXXXX...(此处省略300字)...")%>

上面这句一定出错,因为太长了。那么再看下面一句:

1
< %=Server.MapPath("XXXXXXXXXXX")%>

看似没有问题,但在特定环境下会出错,比如你的ASP放在很深的目录里,或者名字很长的目录里。

结论:

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

为什么是259呢,我实验验证出来的。盘符路径(如C:\)占了3个字符,剩下的刚好是256个字符,也就是说,ASP的设计者为中间结果分配了一个512字节的存储空间(256个字符,每字符占2个字节,无论中英文,Unicode编码字符一律占2字节),再用盘符路径加上这个结果。

个别极品同学,把盘符Z都用光了,可能会用出两位字母的盘符,那个什么情形我就不知道了。
话说为什么要限制256个字符呢?也许是考虑到Windows系统下,路径+文件名(不含前面的C:\)的长度的极限就是256。

, , ,

相关文章

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注