婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > ASP.NET(C#)實(shí)現(xiàn)一次性動(dòng)態(tài)上傳多張圖片的代碼(多個(gè)文件)

ASP.NET(C#)實(shí)現(xiàn)一次性動(dòng)態(tài)上傳多張圖片的代碼(多個(gè)文件)

熱門(mén)標(biāo)簽:銀行信貸電話機(jī)器人 天津電銷外呼系統(tǒng)違法嗎 上海400客服電話怎么申請(qǐng) 滄州電銷外呼系統(tǒng)價(jià)格 溫州外呼系統(tǒng)招商 400電話個(gè)人能不能辦理 凱立德地鐵站地圖標(biāo)注 手機(jī)外呼系統(tǒng)什么原理 合肥ai電銷機(jī)器人費(fèi)用
在做asp.net的Web開(kāi)發(fā)的時(shí)候,我們經(jīng)常會(huì)遇到一次性上傳多個(gè)文件的需求。通常我們的解決方法是固定放多個(gè)上傳文件框,這樣的解決辦法顯然是不合理的,因?yàn)橐淮紊蟼鞫鄠€(gè),就意味著數(shù)量不確定。因此我們就要讓這些文件上傳框動(dòng)態(tài)添加,下面我以我做的一個(gè)圖庫(kù)管理中的上傳圖片的功能為例

先看效果:
打開(kāi)的初始界面:

默認(rèn)是上傳一個(gè)圖片,但當(dāng)我們點(diǎn)“增加圖片”按鈕時(shí)可以實(shí)現(xiàn)選擇多個(gè)圖片及其描述同時(shí)上傳,本功能限制一次最多只能上傳8張,且每張圖片大小不超過(guò)1M,這個(gè)大家可根據(jù)實(shí)際情況更改!
如圖:


下面來(lái)看實(shí)現(xiàn)過(guò)程:
第一步,使用javascript代碼實(shí)現(xiàn)動(dòng)態(tài)添加文件上傳框和描述文本框,關(guān)鍵代碼如下:
復(fù)制代碼 代碼如下:

script type="text/javascript">
var i=1
function addFile()
...{
if (i8)
...{var str = 'BR> input type="file" name="File" runat="server" style="width: 300px"/>描述:input name="text" type="text" style="width: 150px" maxlength="20" />'
document.getElementById('MyFile').insertAdjacentHTML("beforeEnd",str)
}
else
...{
alert("您一次最多只能上傳8張圖片!")
}
i++
}
/script>HTML調(diào)用代碼為:
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" />
第二步:服務(wù)器端代碼實(shí)現(xiàn)
就上傳單個(gè)文件或圖片來(lái)說(shuō),使最普通不過(guò)的了,但是對(duì)于這樣的一次性上傳多個(gè)文件以及它們相應(yīng)的描述的問(wèn)題,就要費(fèi)點(diǎn)周折
首先,通過(guò)System.Web.HttpContext.Current.Request.Files方法獲取客戶端的文件集合,然后通過(guò)Request.Form方法獲得描述文本框集合,最后利用一個(gè)循環(huán)將文件上傳,并將相應(yīng)的信息保存到數(shù)據(jù)庫(kù)
關(guān)鍵代碼如下:
復(fù)制代碼 代碼如下:

System.Web.HttpFileCollection files = System.Web.HttpContext.Current.Request.Files;
string[] rd = Request.Form[1].Split(',');//獲得圖片描述的文本框字符串?dāng)?shù)組,為對(duì)應(yīng)的圖片的描述
string albumid=ddlAlbum.SelectedValue.Trim();
int ifile;
for (ifile = 0; ifile files.Count; ifile++)
...{
if (files[ifile].FileName.Length > 0)
...{
.......................... //上傳單個(gè)文件并保存相關(guān)信息
}
}

最后給出上述功能的全部代碼:
HTML代碼:
復(fù)制代碼 代碼如下:

%...@ Page Language="C#" CodeFile="UploadImg.aspx.cs" Inherits="NetAdmin_APicture_UploadImg" %>
!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>無(wú)標(biāo)題頁(yè)/title>
script type="text/javascript">...
var i=1
function addFile()
...{
if (i8)
...{var str = 'BR> input type="file" name="File" runat="server" style="width: 300px"/>描述:input name="text" type="text" style="width: 150px" maxlength="20" />'
document.getElementById('MyFile').insertAdjacentHTML("beforeEnd",str)
}
else
...{
alert("您一次最多只能上傳8張圖片!")
}
i++
}
/script>
link 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">
說(shuō)明:點(diǎn)增加圖片按鈕可一次上傳多張圖片,可為每張圖片寫(xiě)上一句不超過(guò)20個(gè)字的描述。單張圖片大小不大于1024k/td>
/tr>
tr>
td align="right" style="width: 100px">
請(qǐng)選擇圖片: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">
上傳到的圖庫(kù):/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="開(kāi)始上傳" 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>

后臺(tái)代碼:
復(fù)制代碼 代碼如下:

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
...{
protected void Page_Load(object sender, EventArgs e)
...{
}
protected void btnUpload_Click(object sender, EventArgs e)
...{
lblMessage.Text = "";
lblMessage.Visible = false;
System.Web.HttpFileCollection files = System.Web.HttpContext.Current.Request.Files;
System.Text.StringBuilder strmsg = new System.Text.StringBuilder("");
string[] rd = Request.Form[1].Split(',');//獲得圖片描述的文本框字符串?dāng)?shù)組,為對(duì)應(yīng)的圖片的描述
string albumid=ddlAlbum.SelectedValue.Trim();
int ifile;
for (ifile = 0; ifile files.Count; ifile++)
...{
if (files[ifile].FileName.Length > 0)
...{
System.Web.HttpPostedFile postedfile = files[ifile];
if (postedfile.ContentLength / 1024 > 1024)//單個(gè)文件不能大于1024k
...{
strmsg.Append(Path.GetFileName(postedfile.FileName) + "---不能大于1024kbr>");
break;
}
string fex = Path.GetExtension(postedfile.FileName);
if (fex != ".jpg" fex != ".JPG" fex != ".gif" fex != ".GIF")
...{
strmsg.Append(Path.GetFileName(postedfile.FileName) + "---圖片格式不對(duì),只能是jpg或gifbr>");
break;
}
}
}
if (strmsg.Length = 0)//說(shuō)明圖片大小和格式都沒(méi)問(wèn)題
...{
//以下為創(chuàng)建圖庫(kù)目錄
string dirname = "pic00" + ddlAlbum.SelectedValue.Trim();
string dirpath = Server.MapPath("http://www.cnblogs.com/PicBase");
dirpath = dirpath + "\" + dirname;
if (Directory.Exists(dirpath) == false)
...{
Directory.CreateDirectory(dirpath);
}
Random ro = new Random();
int name = 1;
for (int i = 0; i files.Count; i++)
...{
System.Web.HttpPostedFile myFile = files[i];
string FileName = "";
string FileExtention = "";
string PicPath = "";
FileName = System.IO.Path.GetFileName(myFile.FileName);
string stro=ro.Next(100,100000000).ToString()+name.ToString();//產(chǎn)生一個(gè)隨機(jī)數(shù)用于新命名的圖片
string NewName =DateTime.Now.Minute.ToString() + DateTime.Now.Second.ToString()+DateTime.Now.Millisecond.ToString()+stro;
if (FileName.Length > 0)//有文件才執(zhí)行上傳操作再保存到數(shù)據(jù)庫(kù)
...{
FileExtention = System.IO.Path.GetExtension(myFile.FileName);
string ppath = dirpath + "\" + NewName + FileExtention;
myFile.SaveAs(ppath);
string FJname = FileName;
PicPath = "PicBase" + "\" + dirname + "\" + NewName + FileExtention;
}
AddPicture(PicPath, rd[i], albumid);//將圖片信息保存到數(shù)據(jù)庫(kù)
if (name == 1)//如果為每次更新的第一張圖片,則將它更新為象冊(cè)的封面
...{
upFirstimg(albumid, PicPath);
}
name = name + 1;//用來(lái)重命名規(guī)則的變量
}
}
else
...{
lblMessage.Text = strmsg.ToString();
lblMessage.Visible = true;
}
}
private void AddPicture(string imgpath,string imgnote,string albumid)
...{
string sql = "insert WB_AlbumImges(ImgPath,ImgNote,AlbumID) values('"+imgpath+"','"+imgnote+"','"+albumid+"')";
DB mydb = new DB();
mydb.RunProc(sql);
}
private void upFirstimg(string albumid,string firstimg)
...{
string sql = "update WB_Album set FirstImg='"+firstimg+"' where AlbumID="+albumid;
DB mydb = new DB();
mydb.RunProc(sql);
}
}
您可能感興趣的文章:
  • asp.net(C#)使用QRCode生成圖片中心加Logo或圖像的二維碼實(shí)例
  • Asp.net(C#)讀取數(shù)據(jù)庫(kù)并生成JS文件制作首頁(yè)圖片切換效果(附demo源碼下載)
  • asp.net(c#)實(shí)現(xiàn)從sqlserver存取二進(jìn)制圖片的代碼
  • asp.net(C#)壓縮圖片,可以指定圖片模板高寬
  • asp.net(c#)獲取內(nèi)容第一張圖片地址的函數(shù)
  • asp.net(c#)判斷遠(yuǎn)程圖片是否存在
  • C# 將字節(jié)流轉(zhuǎn)換為圖片的實(shí)例方法
  • C#識(shí)別出圖片里的數(shù)字和字母
  • C#圖片按比例縮放的實(shí)現(xiàn)代碼
  • c#實(shí)現(xiàn)圖片二值化例子(黑白效果)
  • c#圖片縮放圖片剪切功能實(shí)現(xiàn)(等比縮放)
  • asp.net(c#)編程實(shí)現(xiàn)將彩色圖片變灰階圖片的方法示例

標(biāo)簽:怒江 洛陽(yáng) 金華 白城 赤峰 溫州 酒泉 七臺(tái)河

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ASP.NET(C#)實(shí)現(xiàn)一次性動(dòng)態(tài)上傳多張圖片的代碼(多個(gè)文件)》,本文關(guān)鍵詞  ASP.NET,實(shí)現(xiàn),一次性,動(dòng)態(tài),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《ASP.NET(C#)實(shí)現(xiàn)一次性動(dòng)態(tài)上傳多張圖片的代碼(多個(gè)文件)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于ASP.NET(C#)實(shí)現(xiàn)一次性動(dòng)態(tài)上傳多張圖片的代碼(多個(gè)文件)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 卓资县| 武汉市| 淮阳县| 泗水县| 富宁县| 乐山市| 旬邑县| 武安市| 吉木乃县| 哈密市| 西安市| 乐至县| 平乐县| 柘城县| 黄大仙区| 白银市| 双柏县| 都昌县| 青海省| 甘德县| 景东| 乌兰浩特市| 拉孜县| 靖州| 大丰市| 广元市| 巫溪县| 浏阳市| 万宁市| 灌阳县| 永康市| 彰武县| 青河县| 交城县| 通江县| 宿迁市| 正阳县| 平陆县| 安化县| 保亭| 连山|