在ASP.NET中实现多文件上传

在以前的Web应用中,上传文件是个很麻烦的事,现在有了.NET,文件上传变得轻而易举。下面的这个例子实现了多文件上传功能。可以动态添加输入表单,上传的文件数量没有限制。代码如下:

MultiUpload.aspx

< %@ Page Language = " vb "  AutoEventWireup = " false "  Codebehind = " MultiUpload.aspx.vb "
 
Inherits = " aspxWeb.MultiUpload "  % >
< !DOCTYPE HTML  PUBLIC   " -//W3C//DTD HTML 4.0 Transitional//EN "   >
< HTML >
  
< HEAD >
    
< title > 多文件上传 </ title >
    
< script language = " JavaScript " >
    
function addFile()
    {
        var 
str = '<INPUT type="file" size="50" NAME="File">'
        document.getElementById('MyFile').insertAdjacentHTML("beforeEnd",str)
    }
    
</script>
  
</HEAD>
  
<body>
    
<form id="form1" method="post" runat="server" enctype="multipart/form-data">
      
<center>
        
<asp:Label Runat="server" ID="MyTitle"></asp:Label>
        
<P id="MyFile"><INPUT type="file" size="50" NAME="File"></P>
        
<P>
          
<input type="button" value="增加(Add)" onclick="addFile()">
          
<asp:Button Runat="server" Text="上传" ID="Upload"></asp:Button>
          
<input onclick="this.form.reset()" type="button" value="重置(ReSet)">
        
</P>
      
</center>
      
<P align="center">
        
<asp:Label id="strStatus" runat="server" Font-Names="宋体" Font-Bold="True"
         Font
-Size="9pt" Width="500px" BorderStyle="None" BorderColor="White"></asp:Label>
      
</P>
    
</form>
  
</body>
</HTML>
 后代码:MultiUpload.aspx.vb

 

 

Public   Class MultiUpload
    
Inherits System.Web.UI.Page
  
Protected WithEvents Upload As System.Web.UI.WebControls.Button
  
Protected WithEvents MyTitle As System.Web.UI.WebControls.Label
  
Protected WithEvents strStatus As System.Web.UI.WebControls.Label

Web Form Designer Generated Code

  
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
    MyTitle.Text 
= "<h3>多文件上传</h3>"
    Upload.Text 
= "开始上传"
    
If (Me.IsPostBack) Then Me.SaveImages()
  
End Sub


  
Private Function SaveImages() As System.Boolean
    
'遍历File表单元素
    Dim files As System.Web.HttpFileCollection = System.Web.HttpContext.Current.Request.Files

    
'状态信息
    Dim strMsg As New System.Text.StringBuilder("上传的文件分别是:<hr color=red>")
    
Dim iFile As System.Int32
    
Try
      
For iFile = 0 To files.Count - 1
        
'检查文件扩展名字
        Dim postedFile As System.Web.HttpPostedFile = files(iFile)
        
Dim fileName, fileExtension As System.String
        fileName 
= System.IO.Path.GetFileName(postedFile.FileName)
        
If Not (fileName = String.Empty) Then
          fileExtension 
= System.IO.Path.GetExtension(fileName)
          strMsg.Append(
"上传的文件类型:" + postedFile.ContentType.ToString() + "<br>")
          strMsg.Append(
"客户端文件地址:" + postedFile.FileName + "<br>")
          strMsg.Append(
"上传文件的文件名:" + fileName + "<br>")
          strMsg.Append(
"上传文件的扩展名:" + fileExtension + "<br><hr>")
          
'可根据扩展名字的不同保存到不同的文件夹
          postedFile.SaveAs(System.Web.HttpContext.Current.Request.MapPath("images/"+ fileName)
        
End If
      
Next
      strStatus.Text 
= strMsg.ToString()
      
Return True
    
Catch Ex As System.Exception
      strStatus.Text 
= Ex.Message
      
Return False
    
End Try
  
End Function

End Class

C# 版本

UpLoad.aspx

 

<% @ Page language = " c# "  Codebehind = " UpLoad.aspx.cs "  AutoEventWireup = " false "  Inherits = " WebPortal.Upload "   %>
<! DOCTYPE HTML PUBLIC  " -//W3C//DTD HTML 4.0 Transitional//EN "   >
< HTML >
  
< HEAD >
    
< title > 多文件上传 </ title >
    
< script language = " JavaScript " >
    function addFile()
    
{
        var str 
= '<INPUT type="file" size="50" NAME="File">'
        document.getElementById(
'MyFile').insertAdjacentHTML("beforeEnd",str)
    }

    
</ script >
  
</ HEAD >
  
< body >
    
< form id = " form1 "  method = " post "  runat = " server "  enctype = " multipart/form-data " >
      
< div align = " center " >
        
< h3 > 多文件上传 </ h3 >
        
< P id = " MyFile " >< INPUT type = " file "  size = " 50 "  NAME = " File " ></ P >
        
< P >
          
< input type = " button "  value = " 增加(Add) "  onclick = " addFile() " >
          
< input onclick = " this.form.reset() "  type = " button "  value = " 重置(ReSet) " >
          
< asp:Button Runat = " server "  Text = " 开始上传 "  ID = " UploadButton " ></ asp:Button >
        
</ P >
        
< P >
        
< asp:Label id = " strStatus "  runat = " server "  Font - Names = " 宋体 "  Font - Bold = " True "  Font - Size = " 9pt "  
          Width
= " 500px "  BorderStyle = " None "  BorderColor = " White " ></ asp:Label >
        
</ P >  
      
</ div >
    
</ form >
  
</ body >
</ HTML >

UpLoad.aspx.cs

 

using  System;
using  System.Collections;
using  System.ComponentModel;
using  System.Data;
using  System.Drawing;
using  System.Web;
using  System.Web.SessionState;
using  System.Web.UI;
using  System.Web.UI.WebControls;
using  System.Web.UI.HtmlControls;

namespace  WebPortal
{
  
/// <summary>
  
/// UpLoad 的摘要说明。
  
/// 实现多文件上传
  
/// </summary>

  public class Upload : System.Web.UI.Page
  
{
    
protected System.Web.UI.WebControls.Button UploadButton;
    
protected System.Web.UI.WebControls.Label strStatus;

    
private void Page_Load(object sender, System.EventArgs e)
    
{
      
/// 在此处放置用户代码以初始化页面
      if (this.IsPostBack) this.SaveImages();
    }


    
private Boolean SaveImages()
    
{
      
///'遍历File表单元素
      HttpFileCollection files  = HttpContext.Current.Request.Files;

      
/// '状态信息
      System.Text.StringBuilder strMsg = new System.Text.StringBuilder();
      strMsg.Append(
"上传的文件分别是:<hr color=red>");
      
try
      
{
        
for(int iFile = 0; iFile < files.Count; iFile++)
        
{
          
///'检查文件扩展名字
          HttpPostedFile postedFile = files[iFile];
          
string fileName, fileExtension;
          fileName 
= System.IO.Path.GetFileName(postedFile.FileName);
          
if (fileName != "")
          
{
            fileExtension 
= System.IO.Path.GetExtension(fileName);
            strMsg.Append(
"上传的文件类型:" + postedFile.ContentType.ToString() + "<br>");
            strMsg.Append(
"客户端文件地址:" + postedFile.FileName + "<br>");
            strMsg.Append(
"上传文件的文件名:" + fileName + "<br>");
            strMsg.Append(
"上传文件的扩展名:" + fileExtension + "<br><hr>");
            
///'可根据扩展名字的不同保存到不同的文件夹
            
///注意:可能要修改你的文件夹的匿名写入权限。

            postedFile.SaveAs(System.Web.HttpContext.Current.Request.MapPath("images/"+ fileName);
          }

        }

        strStatus.Text 
= strMsg.ToString();
        
return true;
      }

      
catch(System.Exception Ex)
      
{
        strStatus.Text 
= Ex.Message;
        
return false;
      }

    }

  
Web 窗体设计器生成的代码
  }

}

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
东南亚位于我国倡导推进的“一带一路”海陆交汇地带,作为当今全球发展最为迅速的地区之一,近年来区域内生产总值实现了显著且稳定的增长。根据东盟主要经济体公布的最新数据,印度尼西亚2023年国内生产总值(GDP)增长5.05%;越南2023年经济增长5.05%;马来西亚2023年经济增速为3.7%;泰国2023年经济增长1.9%;新加坡2023年经济增长1.1%;柬埔寨2023年经济增速预计为5.6%。 东盟国家在“一带一路”沿线国家的总体GDP经济规模、贸易总额与国外直接投资均为最大,因此有着举足轻重的地位和作用。当前,东盟与国已互相成为双方最大的交易伙伴。国-东盟贸易总额已从2013年的443亿元增长至 2023年合计超逾6.4万亿元,占国外贸总值的15.4%。在过去20余年,东盟国家不断在全球多变的格局里面临挑战并寻求机遇。2023东盟国家主要经济体受到国内消费、国外投资、货币政策、旅游业复苏、和大宗商品出口价企稳等方面的提振,经济显现出稳步增长态势和强韧性的潜能。 本调研报告旨在深度挖掘东南亚市场的增长潜力与发展机会,分析东南亚市场竞争态势、销售模式、客户偏好、整体市场营商环境,为国内企业出海开展业务提供客观参考意见。 本文核心内容: 市场空间:全球行业市场空间、东南亚市场发展空间。 竞争态势:全球份额,东南亚市场企业份额。 销售模式:东南亚市场销售模式、本地代理商 客户情况:东南亚本地客户及偏好分析 营商环境:东南亚营商环境分析 本文纳入的企业包括国外及印尼本土企业,以及相关上下游企业等,部分名单 QYResearch是全球知名的大型咨询公司,行业涵盖各高科技行业产业链细分市场,横跨如半导体产业链(半导体设备及零部件、半导体材料、集成电路、制造、封测、分立器件、感器、光电器件)、光伏产业链(设备、硅料/硅片、电池片、组件、辅料支架、逆变器、电站终端)、新能源汽车产业链(动力电池及材料、电驱电控、汽车半导体/电子、整车、充电桩)、通信产业链(通信系统设备、终端设备、电子元器件、射频前端、光模块、4G/5G/6G、宽带、IoT、数字经济、AI)、先进材料产业链(金属材料、高分子材料、陶瓷材料、纳米材料等)、机械制造产业链(数控机床、工程机械、电气机械、3C自动化、工业机器人、激光、工控、无人机)、食品药品、医疗器械、农业等。邮箱:market@qyresearch.com

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值