IE浏览器上传文件时本地路径变成”C:fakepath”的问题 - TOMMYHU - 专注互联网开发及运营技术,提供相关资料及软件下载,奇趣网络时事评论!
Dec 6

IE浏览器上传文件时本地路径变成”C:fakepath”的问题 不指定

tommyhu , 20:59 , ASP.NET , Comments(0) , Trackbacks(0) , Reads(4490) , Via Original Large | Medium | Small

在使用<input id="file_upl" type="file" />控件上传文件时,有时会需要获取文件本地路径展示给客户,这时可以通过这样的方式获取文件本地路径:

document.getElementById('file_upl').value

这在IE7及以前的IE浏览器版本上都没有问题,但是到IE8上面,就不行了,在IE8中你只会获取到这样的路径:"C:\fakepath\xxx”,其中xxx是你的文件名。

这是怎么回事呢?

原来,IE8出于安全性的考虑,上传文件时屏蔽了真实的本地文件路径,而以“C:\fakepath\”取代之。

但是我们就是想要获取真实的本地文件路径怎么办呢?

你可以通过设置浏览器安全选项得到真实路径:

http://www.iefans.net/wp-content/themes/philna/img/blockquote.gif); background-color: rgb(238, 248, 255); border: 1px dashed rgb(221, 221, 221); color: rgb(70, 70, 70); font-family: Verdana, 'BitStream vera Sans', Helvetica, sans-serif; font-size: 13px; line-height: 20px; background-position: 0% 0%; background-repeat: no-repeat no-repeat;">

Internet选项 -> 安全 -> 自定义级别 -> 将本地文件上载至服务器时包含本地目录路径 -> 选“启动” -> 确定

但是,作为开发者,我们不能指望客户去这么做,所以我们必须通过代码解决这个问题。

例如我的上传文件控件的HTML代码是:

http://www.iefans.net/wp-content/themes/philna/img/blockquote.gif); background-color: rgb(238, 248, 255); border: 1px dashed rgb(221, 221, 221); color: rgb(70, 70, 70); font-family: Verdana, 'BitStream vera Sans', Helvetica, sans-serif; font-size: 13px; line-height: 20px; background-position: 0% 0%; background-repeat: no-repeat no-repeat;">

<input id="file_upl" type="file" />

那么在JS代码中我就可以这样来获取真实的文件路径:

http://www.iefans.net/wp-content/themes/philna/img/blockquote.gif); background-color: rgb(238, 248, 255); border: 1px dashed rgb(221, 221, 221); color: rgb(70, 70, 70); font-family: Verdana, 'BitStream vera Sans', Helvetica, sans-serif; font-size: 13px; line-height: 20px; background-position: 0% 0%; background-repeat: no-repeat no-repeat;">

var file_upl = document.getElementById('file_upl');
file_upl.select();

var realpath = document.selection.createRange().text;

如果我们用的是Ext,那么我们会使用Ext.ux.form.FileField组件,假设我们赋给它的id是"file_upl",这时同样会产生上面的问题,解决的办法也是一样,但是我们获取到type为file的input才行,而根据"file_upl"获取到的元素根本不是我们所需要的,Ext是自动生成了一个type为file的input,你可以通过DebugBar或其他类似工具看到这个input,它的id是赋给Ext.ux.form.FileField的id加上"-file"的后缀,也就是"file_upl-file",所以获取真实文件路径的JS代码就是:

http://www.iefans.net/wp-content/themes/philna/img/blockquote.gif); background-color: rgb(238, 248, 255); border: 1px dashed rgb(221, 221, 221); color: rgb(70, 70, 70); font-family: Verdana, 'BitStream vera Sans', Helvetica, sans-serif; font-size: 13px; line-height: 20px; background-position: 0% 0%; background-repeat: no-repeat no-repeat;">

var file_upl = document.getElementById('file_upl-file');
file_upl.select();

var realpath = document.selection.createRange().text;

此方案只针对IE浏览器,对其他浏览器暂时未作探讨。


▲返回顶部
Last modified by tommyhu on2012/12/09 20:14
Tags:

Add a comment

Nickname

emotemotemotemotemotemotemotemotemotemotemotemotemotemotemotemot