file input 在ie9浏览器的拒绝访问错误

Posted sz_zzm

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了file input 在ie9浏览器的拒绝访问错误相关的知识,希望对你有一定的参考价值。

此文转载至 http://lililucky1211.iteye.com/blog/1916129

 

1. label  for 绑定元素响应事件,例如 点击label可以执行绑定的input 的button的事件,

 

html代码  技术分享
  1. <label for="large_icon_url" class="btn_up file-up-btn">上传大图标</label>  
  2. <input type="file" accept="image/*" class="input_f pics" maxnums="1" name="large_icon_url" id="large_icon_url">  

 label实现了好看的效果,但是由于ie安全限制问题,会拒绝非file浏览上传文件的访问,所以处理方法应该是让file附在lable的上面,然后是透明处理,直接点击file即可。

 

2. 转上传文件的隐藏处理:

IE input file隐藏不能上传文件解决方法

HTML/CSS 2013-05-30 上传,IE,input,file

又是IE的一个问题,近来是跟IE浏览器磕上了,这个问题发现不少人也遇到过,实在蛋疼。但今天这个不能算是一个bug,因为IE可能是从安全角度上考虑结果导致的。一步步来解读。

普通上传例子

首先普通的文件上传呢,很简单,前端代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title>file标签隐藏</title>
 
    </head>
    <body>
        <form action="http://192.168.1.99/upload/upload.php" method="post" enctype="multipart/form-data">
            <input onchange="document.forms[0].submit();" type="file" name="file" />
        </form>
    </body>
</html>

upload.php代码:

1
2
3
echo ‘<pre>‘;
print_r($_FILES["file"]);
echo ‘</pre>‘;

其实就是打印获取到的文件信息。我们测试一下,选择文件后,提交到PHP页面结果如下:

Array
(
    [name] => 7.jpg
    [type] => image/jpeg
    [tmp_name] => /tmp/php0VkjPG
    [error] => 0
    [size] => 36297
)

能正确获取文件信息,只需要cp下就能保存。

用别的按钮替代file标签

但是默file标签很难看,而且每个浏览器下都有很大差距。因此我们基本都把真正的file标签给隐藏,然后创建一个标签来替代它,比如我们创建一个a标签来替代它,隐藏file标签,单击a标签时触发file标签click弹出选择文件窗口。最终页面代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title>file标签隐藏</title>
 
    </head>
    <body>
        <form action="http://192.168.1.99/upload/upload.php" method="post" enctype="multipart/form-data" style="display:none;">
            <input onchange="document.forms[0].submit();" type="file" name="file"  />
        </form>
 
        <a onclick="document.forms[0].file.click();" href="javascript:void(0);" >上传文件</a>
    </body>
</html>

页面上就只看见a标签

技术分享

点击“上传文件”弹开选择文件的窗口

技术分享

选择文件后,正确传送文件信息到服务器

技术分享

这样就完成文件上传了,这个操作在Chrome,FireFox下都正常,IE下有问题。

IE不能上传文件

IE下也能正常弹开选择文件的窗口

技术分享

但选择文件后,却不能上传,同时还报一个“拒绝访问”错误,如截图中红圈部分

技术分享

解决IE下不能上传文件的问题

其实这是IE安全限制问题,没有点击file的浏览按钮选择文件都不让上传,既然IE非得要亲自点击,我们可以变通一下,让自定义按钮存在又能真正点击到file标签。解决方案是让file标签盖在a标签上,但file是透明的,这样用户看到的是a标签的外观,实际点击是file标签。如图:

技术分享

最终页面代码如下:

1
2
3
4
5
<a style="position:relative;display:block;width:100px;height:30px;background:#EEE;border:1px solid #999;text-align:center;"  href="javascript:void(0);" >上传文件
    <form action="http://192.168.1.99/upload/upload.php" method="post" enctype="multipart/form-data">
        <input style="position:absolute;left:0;top:0;width:100%;height:100%;z-index:999;opacity:0;" onchange="document.forms[0].submit();" type="file" name="file"  />
    </form>
</a>

页面:

技术分享

需要注意几个问题
1、取消a标签onclick事件,因为实际上已经不需要a标签的onclick触发file的click了,而是直接就点击到file;
2、file标签不需要再设置display:none隐藏,而是通过opacity:0让它完全透明,实际它是浮在a标签之上
3、file标签设置position:absolute后要给left:0、top:0,否则file标签不会吻合覆盖a标签导致点击按钮的时候点不到file标签

我们再来测试一下:

点击按钮:

技术分享

选择文件:

技术分享

上传成功!











以上是关于file input 在ie9浏览器的拒绝访问错误的主要内容,如果未能解决你的问题,请参考以下文章

从 onchange 触发 .click() 时 IE9 上出现“SCRIPT5 访问被拒绝”错误

IE9:设置 document.domain 时访问被拒绝

带有 AngularJS CORS 的 IE9、IE8 返回“访问被拒绝” - ASP.NET WebApi

无法批量加载,因为无法打开文件“ File.csv”。操作系统错误代码5(访问被拒绝。)

SCRIPT5:在 IE9 中对 xmlhttprequest 的访问被拒绝

同一域的 IE9 中的 Script5 访问被拒绝