一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - ASP.NET教程 - c#多圖片上傳并生成縮略圖的實例代碼

c#多圖片上傳并生成縮略圖的實例代碼

2019-11-01 13:40c#教程網(wǎng) ASP.NET教程

今天寫了一個上傳多張圖片并生成縮略圖的小程序。當然因為是菜鳥,所以寫的一般。但還是學到了不少東西。現(xiàn)在上代碼。

前臺代碼:

 

復制代碼代碼如下:


 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="upload.aspx.cs" Inherits="upload" %>

 <!DOCTYPE html>

 <html xmlns="http://www.w3.org/1999/xhtml">
 <head runat="server">
     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
     <title></title>
     <style type="text/css">
         li
         {
             list-style: none;
             padding-top: 10px;
         }
     </style>
     <script type="text/javascript" src="js/jquery-1.6.2.min.js"></script>
     <script type="text/javascript">
         function ValidImage(id, msg) {
             $(id).parent().append("<span>" + msg + "</span>");
             return false;
         }
     </script>
 </head>
 <body>
     <form id="form1" runat="server" enctype="multipart/form-data" method="post">
         <div>
                       <ul>
                 <li>
                     <input type="file" id="upload1" name="upload" />
                 </li>
                 <li>
                     <input type="file" id="upload2" name="upload" />
                 </li>
                 <li>
                     <input type="file" id="upload3" name="upload" />
                 </li>
                 <li>
                     <input type="file" id="upload4" name="upload" /></li>
                 <li>
                     <input type="file" id="upload5" name="upload" />

                 </li>
                 <li>
                     <input type="submit" id="btnPostFile" runat="server" onserverclick="btnPostFile_ServerClick" value="開始上傳" />
                 </li>
             </ul>
         </div>
     </form>
 </body>
 </html>


前臺就是幾個控件和一個ValidImage方法。

 

后臺代碼:

 

#3f716ae75cf8cc3cc12059865defefbc#代碼如下:


  protected void btnPostFile_ServerClick(object sender, EventArgs e)
     {
         string filePath = Server.MapPath("/uploadImg");
         const int size = 5242880;
         if (!Directory.Exists(filePath))
         {
             Directory.CreateDirectory(filePath);
         }
         if (Request.Files.Count > 0)
         {
             for (int i = 0; i < Request.Files.Count; i++)
             {
                 HttpPostedFile postFile = Request.Files[i];
                 string uploadFileID = string.Format("#upload{0}", i + 1);  //當前的上傳控件ID,因為jquery要調(diào)用就加了#
                 string msg = null;                 //提示信息
                 if (postFile.FileName.Trim().Length <= 0)
                 {
                     continue;
                 }
                 if (postFile.ContentLength > size)
                 {
                     msg = "文件太大";
                     Page.ClientScript.RegisterStartupScript(GetType(), "", "ValidImage(" + uploadFileID + "," + msg + ")", true);//將提示信息發(fā)送到客戶端
                     continue;
                 }
                 string savePath = Path.Combine(filePath, postFile.FileName);        //圖片的保存地址
                 if (!File.Exists(savePath))
                 {
                     postFile.SaveAs(Path.Combine(filePath, postFile.FileName));     //如果文件不存在就保存
                 }
                 else
                 {
                     msg = "文件" + postFile.FileName + "已經(jīng)存在";
                     Page.ClientScript.RegisterStartupScript(GetType(), "", "ValidImage(" + uploadFileID + "," + msg + ")", true);//將提示信息發(fā)送到客戶端
                     continue;
                 }
                 if (IsImg(savePath))            //通過IsImg方法驗證文件是否是圖片,或者格式是否正確
                 {
                     SmallImg(postFile.InputStream, postFile.FileName);
                 }
                 else
                 {
                     msg = "只能上傳JGP、PNG類型的圖片,請檢查文件格式是否正確";
                     Page.ClientScript.RegisterStartupScript(GetType(), "", "ValidImage(" + uploadFileID + "," + msg + ")", true);//將提示信息發(fā)送到客戶端
                     File.Delete(savePath);  //如果不是圖片就刪除
                 }
             }
         }
     }

 

 

復制代碼代碼如下:

 

  #region 驗證上傳文件的格式
     /// <summary>
     /// 驗證上傳文件是否是圖片
     /// </summary>
     /// <param name="FilePath">文件的保存路徑</param>
     /// <returns></returns>
     private bool IsImg(string FilePath)
     {
         using (FileStream fs = new FileStream(FilePath, FileMode.Open, FileAccess.Read))
         {
             bool result = false;
             BinaryReader br = new BinaryReader(fs, System.Text.Encoding.UTF8);
             string strImg = "";
             byte buffer;
             try
             {
                 buffer = br.ReadByte();
                 strImg = buffer.ToString();
                 buffer = br.ReadByte();
                 strImg += buffer.ToString();
             }
             catch
             {
                 fs.Close();
                 br.Close();

             }
             if (strImg == "255216" || strImg == "13780")//說明255216是jpg;7173是gif;6677是BMP,13780是PNG;7790是exe,8297是rar
             {
                 result = true;
             }
             return result;
         }
     }
     #endregion

 

 

復制代碼代碼如下:


   #region 將圖片生成縮略圖
     /// <summary>
     /// 生成縮略圖
     /// </summary>
     private void SmallImg(Stream oStream, string FileName)
     {
         using (System.Drawing.Image img = System.Drawing.Image.FromStream(oStream))
         {
             int newWidth = 100;
             int newHeight = 80;
             int oldWidth = img.Width;
             int oldHeight = img.Height;
             if (oldWidth > oldHeight)
             {
                 newHeight = (int)Math.Floor((double)oldHeight * (double)newWidth / (double)oldWidth);
             }
             else
             {
                 newWidth = (int)Math.Floor((double)oldWidth * (double)newHeight / (double)oldHeight);
             }
             using (Bitmap bmp = new Bitmap(newWidth, newHeight))
             {
                 using (Graphics g = Graphics.FromImage(bmp))
                 {
                     g.Clear(Color.Transparent);
                     g.InterpolationMode = InterpolationMode.High;
                     g.CompositingQuality = CompositingQuality.HighQuality;
                     g.SmoothingMode = SmoothingMode.HighQuality;
                     g.DrawImage(img, new Rectangle(0, 0, newWidth, newHeight), new Rectangle(0, 0, oldWidth, oldHeight), GraphicsUnit.Pixel);
                     string newFileName = Path.GetFileNameWithoutExtension(FileName) + "_small" + Path.GetExtension(FileName);   //縮略圖名稱
                     string filePath = Server.MapPath("/uploadImg/") + newFileName;
                     bmp.Save(filePath);
                 }
             }

         }
     }
     #endregion

 

代碼有很多需要改進的地方,希望大家多多指點。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 色综合久久天天综合观看 | 国产欧美日韩精品高清二区综合区 | 欧美同性video| 日本一二线不卡在线观看 | 91久久国产成人免费观看资源 | 四虎欧美| 日本高清在线看 | 国产成人久久久精品一区二区三区 | 玩乳h文奶水和尚 | 国产在线视频在线观看 | 日韩亚洲人成网站在线播放 | 亚洲欧美综合在线观看 | 521色香蕉网在线观看免费 | 国产新疆成人a一片在线观看 | 9 1 视频在线 | 亚洲欧美日韩成人 | 手机看片自拍自自拍日韩免费 | 亚洲天堂免费 | 国产草草 | 精品日韩一区二区三区 | 国产大胆歌舞团网站 | 香蕉精品国产高清自在自线 | 国产高清国内精品福利 | 青青青国产精品国产精品久久久久 | 欧美亚洲国产精品久久第一页 | 日本高清视频网站 | 欧美亚洲高清日韩成人 | 无敌在线视频观看免费 | 国产免费一区二区三区 | 女人肮脏的交易中文字幕未删减版 | 亚洲男人天堂影院 | 国产一区二区三区欧美精品 | 精品久久久久久综合网 | 性xxxx18学生第一次出血 | 欧美a大片| 亚洲AV精品无码喷水直播间 | 成人永久免费福利视频网站 | 日本视频高清 | 国产精品自拍一区 | 国产一区二区在线观看视频 | 日本一区二区三区在线 视频 |