Asp.net实现同页面内多图片自动上传并带预览显示

FileUpload控件实现单按钮图片自动上传并带预览显示

1.实现原理:

此方法适合针对有后台生成的图片相关内容,例如购物网站商品展示页面中的封面图片,图片的数量由后台访问数据库,并加载到页面。这种情况下,将会有x个FileUpload控件调用__doPostBack方法来用LinkButton的OnClick事件模拟一个事件触发的过程,由于上传控件的数量不固定,不可能使用多个用LinkButton的OnClick事件模拟事件触发的过程。也就是说只能有多个FileUpload控件调用一个LinkButton的OnClick事件模拟事件触发的过程。
多个FileUpload控件调用一个LinkButton的OnClick事件模拟事件触发的过程,由于上传每个图片后都需要显示相应的图片预览,就需要区分出来是每一次都是哪个FileUpload控件进行的上传操作,要加载哪一个图片。 __doPostBack(‘lbtnUpload1‘,‘‘)后面‘‘的地方可以传递参数,我们可以从此处着手,对每一个图片相关的上传控件,图片预览框进行统一标识。
如何获取参数:
这个两个值在后台可以通过下边方法得到:
Request["__EVENTTARGET"] :获取得到引发页面PostBack的控件ID
Request["__EVENTARGUMENT"]: 获取参数。

2.关键代码:

页面代码:

1 <asp:FileUpload ID="fuPhoto1" onchange="javascript:__doPostBack(‘lbUploadPhoto‘,‘1‘)"  runat="server" ToolTip="选择图片" ForeColor="White" Width="68"/><br />
2 <img id="img" runat="server" src="" /><br />
3 <asp:FileUpload ID="fuPhoto2" onchange="javascript:__doPostBack(‘lbUploadPhoto‘,‘2‘)"  runat="server" ToolTip="选择图片" ForeColor="White" Width="68"/><br />
4 <asp:LinkButton ID="lbUploadPhoto" runat="server" OnClick="lbUploadPhoto_Click"></asp:LinkButton>

注意: __doPostBack(‘lbUploadPhoto‘,‘2‘),第一个参数为LinkButton的名称,即name值。

后台代码:

 1  /// <param name="e"></param>
 2         protected void lbUploadPhoto_Click(object sender, EventArgs e)
 3         {
 4             fileUpload(Request["__EVENTARGUMENT"]);
 5         }
 6         //从控件上传文件
 7         public void fileUpload(string number)
 8         {
 9             FileUpload fu = FindControl("fuPhoto"+number) as FileUpload;
10             if (fu.PostedFile != null && fu.PostedFile.ContentLength > 0)
11             {
12                 //1. 验证文件格式
13                 string ext = System.IO.Path.GetExtension(fu.PostedFile.FileName).ToLower();
14                 if (ext != ".jpg" && ext != ".gif" && ext != ".png")
15                 {
16                     Response.Write("文件非法!");
17                     return;
18                 }
19                 string savePath = Server.MapPath("~/upload/");//指定上传文件在服务器上的保存路径
20                 //2. 检查服务器上是否存在这个物理路径,如果不存在则创建
21                 if (!System.IO.Directory.Exists(savePath))
22                 {
23                     System.IO.Directory.CreateDirectory(savePath);
24                 }
25                 Random random = new Random(DateTime.Now.Millisecond);
26                 string fileName = DateTime.Now.ToString("yyMMddhhmmss") + random.Next(10000) + ext;
27                 string path = savePath + fileName;
28                 fu.PostedFile.SaveAs(path);
29                 Image img=FindControl("img"+number) as Image;
30                 img.Src = "upload/" + fileName;
31             }
32             else
33             {
34                 //没有图片的情况处理
35             }
36         }
时间: 2024-10-05 12:34:43

Asp.net实现同页面内多图片自动上传并带预览显示的相关文章

FileUpload控件实现单按钮图片自动上传并带预览显示

FileUpload控件实现单按钮图片自动上传并带预览显示 1.实现原理: FileUpload控件默认不支持服务端的ONCHANGE事件,此时用一种变通的方法借用客户端的onchange事件,调用__doPostBack方法来用LinkButton的OnClick事件模拟一个事件触发的过程,可以在LinkButton的OnClick事件中进行图片的上传,和预览加载. 2.关键代码:      页面代码: 1 <asp:FileUpload ID="fuPhoto" onchan

Asp.net中FileUpload控件实现图片上传并带预览显示

单一图片上传——“选择”+“上传”,.NET默认模式: 1.实现原理: 采用FileUpload控件默认的使用方式,先由“选择”按钮选择图片,然后单击“上传”按钮完成上传,并可在“上传”按钮的单击事件中加载已上传图片. 2.关键代码:     页面代码: 1 <asp:FileUpload ID="FileUpload" runat="server" /> 2 <asp:Button ID="BtnUp" runat="

[Asp.net]常见word,excel,ppt,pdf在线预览方案(转)

引言 之前项目需要,查找了office文档在线预览的解决方案,顺便记录一下,方便以后查询. 方案一 直接在浏览器中打开Office文档在页面上的链接.会弹出如下窗口: 优点:主流浏览器都支持. 缺点:Office文档链接在浏览器中打开,会有如上图的提示,需用户自己选择打开或者保存功能,如果客户电脑上安装迅雷下载软件,会启动迅雷下载,用户体验不好. 方案二 office文档转html,首先引入com组件中office库,然后在程序集扩展中引入word,excel,ppt的dll. 然后F6生成,会

html之file标签 --- 图片上传前预览 -- FileReader

记得以前做网站时,曾经需要实现一个图片上传到服务器前,先预览的功能.当时用html的<input type="file"/>标签一直实现不了,最后舍弃了这个标签,使用了其他方式来实现了这个功能. 今天无意发现了一个知识点,用html的file标签就能实现图片上传前预览,感觉很棒,记录一下!就是通过file标签和js的FileReader接口,把选择的图片文件调用readAsDataURL方法,把图片数据转成base64字符串形式显示在页面上. 1.闲话少说,测试一下,图片上

HTML5 jQuery图片上传前预览

HTML5实现表单内的上传文件框,上传前预览图片,针刷新预览images,本例子主要是使用HTML5 的File API,建立一個可存取到该file的url,一个空的img标签,ID为img0,把选择的文件显示在img标签中,实现图片预览功能.请选择支持HTML API的浏览器,比如谷歌Chrome和火狐等. <!DOCTYPE html><html> <head> <title>HTML5上传图片预览</title> <meta char

[转]html之file标签 --- 图片上传前预览 -- FileReader

记得以前做网站时,曾经需要实现一个图片上传到服务器前,先预览的功能.当时用html的<input type="file"/>标签一直实现不了,最后舍弃了这个标签,使用了其他方式来实现了这个功能. 今天无意发现了一个知识点,用html的file标签就能实现图片上传前预览,感觉很棒,记录一下!就是通过file标签和js的FileReader接口,把选择的图片文件调用readAsDataURL方法,把图片数据转成base64字符串形式显示在页面上. 1.闲话少说,测试一下,图片上

MUI 图片上传剪切预览,可选(拍照+系统相册)

整合网上的例子..麻蛋.没跑通..没办法.自己就拿他们的例子完善了一下..已经可以使用了! 准备工作: 这几个文件要引入.特别是JS 文件!!! <link href="../css/mui.min.css" rel="stylesheet" /> <link href="../css/cropper.css" rel="stylesheet" /> <script src="../js

【转】HTML5 jQuery图片上传前预览

hTML5实现表单内的上传文件框,上传前预览图片,针刷新预览images,本例子主要是使用HTML5 的File API,建立一個可存取到该 file的url,一个空的img标签,ID为img0,把选择的文件显示在img标签中,实现图片预览功能.请选择支持HTML API的浏览器,比如 谷歌Chrome和火狐等. <!DOCTYPE html> <html> <head> <title>HTML5上传图片预览</title> <meta h

js实现图片上传及预览----------------------&gt;&gt;兼容ie6-8 火狐以及谷歌

<head runat="server"> <title>图片上传及预览(兼容ie6/7/8 firefox/chrome)</title> <script src="../Scripts/jquery-1.4.2.min.js" type="text/javascript"></script> </head> <body> <form id="f