asp.net(c#)一次預覽並上傳多張圖片

用asp.net開發網站時,經常要上傳圖片,現在IE7出現,原來的img.src='xxx.jpg'這種預覽方式已經失效。本文介紹新的上傳前預覽圖片的處理方式。代碼很簡單,直接貼代碼了。

aspx文件代碼:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="UploadPicture._Default" %>

<!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="http://www.svnhost.cn/style/public.css" rel="stylesheet" type="text/css" />
</head>
<body>
<script language="javascript">
function $(o){return document.getElementById(o);}
function CheckImgCss(o,img)
{
if (!/\.((jpg)|(bmp)|(gif)|(png))$/ig.test(o.value))
{
alert('只能上傳jpg,bmp,gif,png格式圖片!');
o.outerHTML = o.outerHTML;
}
else
{
$(img).filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src=o.value;
//$('Image1').src = o.value;//這裏IE7已經不支持了。所以纔有上面的方法。
}
}
</script>
<form id="form1" runat="server">
<div><h1>一次上傳多個圖片並預覽,請選擇圖片:</h1>
<asp:FileUpload ID="FileUpload1" οnchange="CheckImgCss(this, 'img');" runat="server" />
<asp:FileUpload ID="FileUpload2" οnchange="CheckImgCss(this, 'img');" runat="server" />
<asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="上傳" />
<div id="img" style="filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src=<%= pic%>,sizingMethod=scale);width:102px;height:100px;"></div>
</div>
</form>
<div>
<iframe src="http://www.svnhost.cn" width="1000" height="1800" frameborder="0" scrolling="no"></iframe>
</body>
</html>


cs文件代碼:



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;

namespace UploadPicture
{
public partial class _Default : System.Web.UI.Page
{
//該變量用來修改的的時候的默認值。例如上傳自己的頭像,如果用戶修改頭像,這裏可以顯示他原來的頭像。
public string pic = "http://www.svnhost.cn/images/logo.gif";
protected void Page_Load(object sender, EventArgs e)
{

}

protected void Button1_Click(object sender, EventArgs e)
{
Random r = new Random();
//這樣循環,可以同時上傳多個文件。前臺已經有文件格式的判斷,有錯誤提示了。這裏只要過濾掉非法文件即可,無需提示了。
for (int i = 0; i < Request.Files.Count; i++)
{
if (Request.Files[i].ContentLength > 0)
{
string ex = System.IO.Path.GetExtension(Request.Files[i].FileName).ToLower();
if (".jpg.gif.png.bmp".Contains(ex))
{
string newFileName = DateTime.Now.ToString("yyyyMMddHHmmss") + r.Next(100, 999).ToString() + ex;
//保存文件名到數據庫
//xxxxxxxxxxxxxxxx
//xxxxxxxxxxxxxxxx

Request.Files[i].SaveAs(Server.MapPath(newFileName));
pic = newFileName;
}
}
}
}
}
}
發佈了45 篇原創文章 · 獲贊 0 · 訪問量 2527
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章