您的位置:首页 > 编程语言 > ASP

ASP.NET(C#)实现一次性上传多张图片(多个文件)

2007-09-06 12:53 1046 查看
在做asp.net的Web开发的时候,我们经常会遇到一次性上传多个文件的需求。通常我们的解决方法是固定放多个上传文件框,这样的解决办法显然是不合理的,因为一次上传多个,就意味着数量不确定。因此我们就要让这些文件上传框动态添加,下面我以我做的一个图库管理中的上传图片的功能为例

先看效果:

打开的初始界面:

<script type="text/javascript">

var i=1

function addFile()

</script>

HTML调用代码为:

<P id="MyFile"><INPUT onclick="addFile()" type="button" value="增加图片(Add)"><br />

<input type="file" name="File" runat="server" style="width: 300px"/>

描述:<input name="text" type="text" style="width: 150px" maxlength="20" />

第二步:服务器端代码实现

就上传单个文件或图片来说,使最普通不 过的了,但是对于这样的一次性上传多个文件以及它们相应的描述的问题,就要费点周折

首先,通过System.Web.HttpContext.Current.Request.Files方法获取客户端的文件集合,然后通过Request.Form方法获得描述文本框集合,最后利用一个循环将文件上传,并将相应的信息保存到数据库

关键代码如下:

System.Web.HttpFileCollection files = System.Web.HttpContext.Current.Request.Files;

string[] rd = Request.Form[1].Split(',');//获得图片描述的文本框字符串数组,为对应的图片的描述

string albumid=ddlAlbum.SelectedValue.Trim();

int ifile;

for (ifile = 0; ifile < files.Count; ifile++)

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >

<head runat="server">

<title>无标题页</title>

<link href="../../NetAdmin/Site.Css" rel="stylesheet" type="text/css" />

</head>

<body style="background-image: url(../images/bg.jpg); text-align: center">

<form id="form1" runat="server">

<div>

<table id="Table1" align="center" border="0" cellpadding="1" cellspacing="1" class="table"

style="height: 58px" width="620">

<tr>

<td align="center" background="../images/topbg1.jpg">

<font color="#0000ff" face="宋体" size="3"><strong>上传图片</strong></font></td>

</tr>

<tr>

<td align="center">

 </td>

</tr>

<tr>

<td align="center">

<asp:Panel ID="Panel5" runat="server" Width="608px">

   <table width="100%">

<tr>

<td align="right" style="width: 100px">

</td>

<td align="left">

说明:点增加图片按钮可一次上传多张图片,可为每张图片写上一句不超过20个字的描述。单张图片大小不大于1024k</td>

</tr>

<tr>

<td align="right" style="width: 100px">

请选择图片:<br />

</td>

<td align="left"><P id="MyFile"><INPUT onclick="addFile()" type="button" value="增加图片(Add)"><br />

<input type="file" name="File" runat="server" style="width: 300px"/>

描述:<input name="text" type="text" style="width: 150px" maxlength="20" />

</td>

</tr>

<tr>

<td align="right" style="width: 100px">

上传到的图库:</td>

<td align="left">

<asp:DropDownList ID="ddlAlbum" runat="server" DataSourceID="SqlDataSource1"

DataTextField="AlbumName" DataValueField="AlbumID">

</asp:DropDownList><asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:WebJakeCS %>"

SelectCommand="SELECT [AlbumID], [AlbumName] FROM [WB_Album] ORDER BY [AlbumID] DESC">

</asp:SqlDataSource>

</td>

</tr>

<tr>

<td align="right" style="width: 100px">

</td>

<td align="left">

<asp:Button ID="btnUpload" runat="server" Text="开始上传" OnClick="btnUpload_Click" />

</td>

</tr>

<tr>

<td align="right" style="width: 100px">

</td>

<td align="left">

<asp:Label ID="lblMessage" runat="server" Font-Bold="True" ForeColor="Red"></asp:Label></td>

</tr>

</table>

</asp:Panel>

 

</td>

</tr>

<tr>

<td align="center">

<font face="宋体"></font><font face="宋体"> </font>

</td>

</tr>

<tr>

<td align="center">

<font face="宋体"></font>

</td>

</tr>

</table>

</div>

</form>

</body>

</html>

后台代码:

using System;

using System.Data;

using System.Configuration;

using System.Collections;

using System.Web;

using System.Web.Security;

using System.Web.UI;

using System.Web.UI.WebControls;

using System.Web.UI.WebControls.WebParts;

using System.Web.UI.HtmlControls;

using System.IO;

public partial class NetAdmin_APicture_UploadImg : System.Web.UI.Page
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐