非常感谢 Brettle 的开源

支持.net 1.1 .NET 2.0

这里是 live demo

很不容易发现的,在.net下面要找个开源的东西真是难也。

当然大文件上传有很多组件比如ABCUPLOAD SlickUpload不过都不是开源都是商业代码带来的就是N多的$,所以。。。

安装办法

下载地址:http://www.brettle.com/neatupload#Download

 

1.在工具箱中添加Brettle.Web.NeatUpload.dll,可以看到工具箱中出现InputFile等控件。
2.复制文件夹NeatUpload到根目录.
3.拖放使用上传控件InputFile和进度条ProgressBar,添加上传文件的按钮.aspx页面代码如下:

 

asp.net 上传大文件 开源控件<body>
asp.net 上传大文件 开源控件  
<form id="form1" runat="server">
asp.net 上传大文件 开源控件  
<div>
asp.net 上传大文件 开源控件       
<upload:InputFile id="AttachFile" runat="server"></upload:InputFile>
asp.net 上传大文件 开源控件      
<asp:Button ID="Upload" runat="server" Text="Upload"  OnClientClick="ToggleVisibility('ProgressBar','on')" OnClick="Upload_Click"/>
asp.net 上传大文件 开源控件        
<div id="ProgressBar"  style="display:none;">
                   <upload:progressbar id="pbProgressBar" runat="server" Inline="true" Width="500px" Height="100"> </upload:progressbar>
asp.net 上传大文件 开源控件      
</div>
asp.net 上传大文件 开源控件 
</div>
asp.net 上传大文件 开源控件 
</form>
asp.net 上传大文件 开源控件
</body>

 

4.添加脚本代码ToggleVisiblity函数到页面上如下:

 

asp.net 上传大文件 开源控件<script type="text/javascript" language="javascript">
asp.net 上传大文件 开源控件       
function ToggleVisibility(id, type) 
asp.net 上传大文件 开源控件       {
asp.net 上传大文件 开源控件         el 
= document.getElementById(id);
asp.net 上传大文件 开源控件         
if(el.style)
asp.net 上传大文件 开源控件            {
asp.net 上传大文件 开源控件               
if(type == 'on')
asp.net 上传大文件 开源控件
                {
asp.net 上传大文件 开源控件                    
asp.net 上传大文件 开源控件                    el.style.display 
= 'block';
asp.net 上传大文件 开源控件
                } 
asp.net 上传大文件 开源控件                
else 
asp.net 上传大文件 开源控件                {
asp.net 上传大文件 开源控件                   
asp.net 上传大文件 开源控件                    el.style.display 
= 'none';
asp.net 上传大文件 开源控件
                }
asp.net 上传大文件 开源控件            } 
asp.net 上传大文件 开源控件            
else 
asp.net 上传大文件 开源控件            {
asp.net 上传大文件 开源控件               
if(type == 'on')
asp.net 上传大文件 开源控件
               {
asp.net 上传大文件 开源控件                     
asp.net 上传大文件 开源控件                    el.display 
= 'block';
asp.net 上传大文件 开源控件
               } 
asp.net 上传大文件 开源控件               
else 
asp.net 上传大文件 开源控件               {
asp.net 上传大文件 开源控件                   
asp.net 上传大文件 开源控件                    el.display 
= 'none';
asp.net 上传大文件 开源控件
               }
asp.net 上传大文件 开源控件            }
asp.net 上传大文件 开源控件       }
asp.net 上传大文件 开源控件 
</script>

 

5.给上传文件的按钮添加事件Upload_Click

 

asp.net 上传大文件 开源控件 protected void Upload_Click(object sender, EventArgs e)
        }

 

6.在配置文件web.config中添加http模块声明:

 

asp.net 上传大文件 开源控件 <httpModules useFullyQualifiedRedirectUrl="true">
asp.net 上传大文件 开源控件      
<add name="UploadHttpModule" type="Brettle.Web.NeatUpload.UploadHttpModule, Brettle.Web.NeatUpload" />
asp.net 上传大文件 开源控件 
</httpModules>

 

7.需要在web.config进行其他一些设置才能保证完美
在<configuration>里面加入

 

asp.net 上传大文件 开源控件<configSections>
asp.net 上传大文件 开源控件        
<sectionGroup name="system.web">
asp.net 上传大文件 开源控件          
<section name="neatUpload" type="Brettle.Web.NeatUpload.ConfigSectionHandler, Brettle.Web.NeatUpload" allowLocation="true" />
asp.net 上传大文件 开源控件        
</sectionGroup>
asp.net 上传大文件 开源控件      
</configSections>

 

在 <system.web>加入

 

asp.net 上传大文件 开源控件<neatUpload useHttpModule="false" maxNormalRequestLength="4096" maxRequestLength="2097151" defaultProvider="FilesystemUploadStorageProvider">
asp.net 上传大文件 开源控件          
<providers>
asp.net 上传大文件 开源控件            
<add name="FilesystemUploadStorageProvider"
asp.net 上传大文件 开源控件         type
="Brettle.Web.NeatUpload.FilesystemUploadStorageProvider, Brettle.Web.NeatUpload" />
asp.net 上传大文件 开源控件          
</providers>
    </neatUpload>

 

在<configuration>里面的后面位置加入

 

asp.net 上传大文件 开源控件<location path="Default.aspx" >
asp.net 上传大文件 开源控件        
<system.web>
asp.net 上传大文件 开源控件          
<neatUpload useHttpModule="true" />
asp.net 上传大文件 开源控件          
<httpRuntime maxRequestLength="2097151" executionTimeout="3600" useFullyQualifiedRedirectUrl="true" />
asp.net 上传大文件 开源控件        
</system.web>
asp.net 上传大文件 开源控件      
</location>
asp.net 上传大文件 开源控件
</configuration>

相关文章: