相信很多人都运用 过<input type="file"/> 这样的HTML控件,它看起来非常普通,是我们在做Web运用 程序中用于上传客户端本地文件时不可缺少的控件,然而最近我发觉 这个控件在最新的FireFox阅读 器(或者最新的IE8中也会存在这个疑问 ,我没有尝试过,读者可以试一下)中却失去了效果,导致我们在通过这个控件的value属性得到的值中只包含了文件名而没有文件路径,这个在IE7 中是可以正常获取到全文件名的(即文件完整路径+文件名)。在IE中我们可以直接通过request.getParamter("file");就 ok 了。可是在firefox 中不行,它认为这是不安全的。
下面的这一个html可以帮助我们解决在firefox中获取不到file的路径的问题 :
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Page</title>
<script type="text/javascript">
function readFile(fileBrowser) {
if (navigator.userAgent.indexOf("MSIE")!=-1) {
readFileIE(fileBrowser);
} else if (navigator.userAgent.indexOf("Firefox")!=-1 || navigator.userAgent.indexOf("Mozilla")!=-1) {
readFileFirefox(fileBrowser);
} else {
return;
}
}
function readFileFirefox(fileBrowser) {
try {
netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
} catch (e) {
return;
}
var fileName=fileBrowser.value;
alert(fileName);
}
</script>
</head>
<body>
<form name="form1">
Browse to select a file
<input type="file" name="fileBrowser" size="125" οnchange="readFile(this)" />
</form>
</body>
</html>
IE中那个方法我给删掉了。在IE中直接获取就行了。希望能帮助大家。