欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > AJAX實現圖片預覽與上傳及生成縮略圖的方法

AJAX實現圖片預覽與上傳及生成縮略圖的方法

熱門標簽:騰訊地圖標注位置能用多久 個人怎樣在百度地圖標注地名 越南河內地圖標注 ai機器人電銷資源 云呼外撥網絡電話系統 地圖標注項目怎么樣 機器人電銷騙局揭秘 超級大富翁地圖標注 硅語電話機器人公司

要實現功能,上傳圖片時可以預覽,因還有別的文字,所以并不只上傳圖片,實現與別的文字一起保存,當然上來先上傳圖片,然后把路徑和別的文字一起寫入數據庫;同時為 圖片生成縮略圖,現只寫上傳圖片方法,文字在ajax里直接傳參數就可以了,若要上傳多圖,修改一下就可以了。

借鑒了網上資料,自己寫了一下,并不需要再新加頁面,只在一個頁面里就OK啦。

JS代碼:

//ajax保存數據,后臺方法里實現此方法 
function SaveData() {  
    filename = document.getElementById("idFile").value; 
    result =test_test_aspx.SaveData(filename).value; 
    if (result) { 
      alert("保存成功!");      
    } 
    return false; 
  }  
//實現預覽功能 
  function DrawImage(ImgD) { 
    var preW = 118; 
    var preH = 118; 
    var image = new Image(); 
    image.src = ImgD.src; 
    if (image.width > 0  image.height > 0) { 
      flag = true; 
      if (image.width / image.height >= preW/ preH) { 
        if (image.width > preW) { 
          ImgD.width = preW; 
          ImgD.height = (image.height * preW) / image.width; 
        } 
        else { 
          ImgD.width = image.width; 
          ImgD.height = image.height; 
        } 
        ImgD.alt = image.width + "x" + image.height; 
      } 
      else { 
        if (image.height > preH) { 
          ImgD.height = preH; 
          ImgD.width = (image.width * preH) / image.height; 
        } 
        else { 
          ImgD.width = image.width; 
          ImgD.height = image.height; 
        } 
        ImgD.alt = image.width + "x" + image.height; 
      } 
    } 
  } 
//當idFile內容改變時 
  function FileChange(Value) { 
    flag = false; 
    document.getElementById("showImg").style.display = "none";    
    document.getElementById("idImg").width = 10; 
    document.getElementById("idImg").height = 10; 
    document.getElementById("idImg").alt = ""; 
    document.getElementById("idImg").src = Value; 
  } 

以下為前臺代碼:

div class="cbs"> 
div class="l">label>圖片:/label>/div> 
div> 
  input id="idFile" name="pic" type="file" runat="server" onchange="FileChange(this.value);" /> 
/div> 
    /div>  
    div class="cbs"> 
div class="l">label>預覽:/label>/div> 
div> 
  img id="idImg" height="0" width="0" src="" alt="" onload="DrawImage(this);" /> //實現預覽 
  img id="showImg" width="118" height="118" alt="" runat="server" style="display:none"/>  //加這個主要是為了實現查看時顯示圖片,因為上面的(idImg)加上runat="server" 報錯,如有好的方法可以留言     
/div> 
/div>    

以下為AJAX方法:

[Ajax.AjaxMethod()] 
public bool SaveData(string fileNamePath) 
{ 
  string serverFileName = ""; 
  string sThumbFile = "";   
  string sSavePath = "~/Files/"; 
  int intThumbWidth = 118; 
  int intThumbHeight = 118; 
  string sThumbExtension = "thumb_"; 
  try 
  { 
 //獲取要保存的文件信息 
 FileInfo file = new FileInfo(fileNamePath); 
 //獲得文件擴展名 
 string fileNameExt = file.Extension; 
 
 //驗證合法的文件 
 if (CheckFileExt(fileNameExt)) 
 { 
   //生成將要保存的隨機文件名 
   string fileName = GetFileName() + fileNameExt; 
   //檢查保存的路徑 是否有/結尾 
   if (sSavePath.EndsWith("/") == false) sSavePath = sSavePath + "/"; 
 
   //按日期歸類保存 
   string datePath = DateTime.Now.ToString("yyyyMM") + "/" + DateTime.Now.ToString("dd") + "/"; 
   if (true) 
   { 
 sSavePath += datePath; 
   } 
   //獲得要保存的文件路徑 
   serverFileName = sSavePath + fileName; 
   //物理完整路徑 
   string toFileFullPath = HttpContext.Current.Server.MapPath(sSavePath); 
 
   //檢查是否有該路徑 沒有就創建 
   if (!Directory.Exists(toFileFullPath)) 
   { 
 Directory.CreateDirectory(toFileFullPath); 
   } 
 
   //將要保存的完整文件名  
   string toFile = toFileFullPath + fileName; 
 
   ///創建WebClient實例 
   WebClient myWebClient = new WebClient(); 
   //設定windows網絡安全認證  
   myWebClient.Credentials = CredentialCache.DefaultCredentials; 
   
   //要上傳的文件 
   FileStream fs = new FileStream(fileNamePath, FileMode.Open, FileAccess.Read); 
   //FileStream fs = OpenFile(); 
   BinaryReader r = new BinaryReader(fs); 
   //使用UploadFile方法可以用下面的格式 
   //myWebClient.UploadFile(toFile, "PUT",fileNamePath); 
   byte[] postArray = r.ReadBytes((int)fs.Length); 
   Stream postStream = myWebClient.OpenWrite(toFile, "PUT"); 
   if (postStream.CanWrite) 
   { 
 postStream.Write(postArray, 0, postArray.Length); 
   } 
   postStream.Close(); 
   //以上為原圖 
   try 
   { 
 //原圖加載  
  using (System.Drawing.Image sourceImage = System.Drawing.Image.FromFile(System.Web.HttpContext.Current.Server.MapPath(serverFileName))) 
 { 
   //原圖寬度和高度  
   int width = sourceImage.Width; 
   int height = sourceImage.Height; 
   int smallWidth; 
   int smallHeight; 
 
   //獲取第一張繪制圖的大小,(比較 原圖的寬/縮略圖的寬 和 原圖的高/縮略圖的高)  
   if (((decimal)width) / height = ((decimal)intThumbWidth) / intThumbHeight) 
   { 
  smallWidth = intThumbWidth; 
  smallHeight = intThumbWidth * height / width; 
   } 
   else 
   { 
  smallWidth = intThumbHeight * width / height; 
  smallHeight = intThumbHeight; 
   } 
 
   //判斷縮略圖在當前文件夾下是否同名稱文件存在  
  int file_append = 0; 
   sThumbFile = sThumbExtension + System.IO.Path.GetFileNameWithoutExtension(fileName) + fileNameExt; 
 
   while (System.IO.File.Exists(System.Web.HttpContext.Current.Server.MapPath(sSavePath + sThumbFile))) 
   { 
  file_append++; 
  sThumbFile = sThumbExtension + System.IO.Path.GetFileNameWithoutExtension(fileName) + 
file_append.ToString() + fileNameExt; 
   } 
   //縮略圖保存的絕對路徑  
   string smallImagePath = System.Web.HttpContext.Current.Server.MapPath(sSavePath) + sThumbFile; 
 
   //新建一個圖板,以最小等比例壓縮大小繪制原圖  
   using (System.Drawing.Image bitmap = new System.Drawing.Bitmap(smallWidth, smallHeight)) 
   { 
  //繪制中間圖  
  using (System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(bitmap)) 
  { 
//高清,平滑  
g.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.High; 
g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality; 
g.Clear(Color.Black); 
g.DrawImage( 
sourceImage, 
new System.Drawing.Rectangle(0, 0, smallWidth, smallHeight), 
new System.Drawing.Rectangle(0, 0, width, height), 
System.Drawing.GraphicsUnit.Pixel 
); 
  } 
  //新建一個圖板,以縮略圖大小繪制中間圖  
  using (System.Drawing.Image bitmap1 = new System.Drawing.Bitmap(intThumbWidth, intThumbHeight)) 
  { 
//繪制縮略圖  
using (System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(bitmap1)) 
{   
//高清,平滑  
  g.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.High; 
  g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality; 
  g.Clear(Color.Black); 
  int lwidth = (smallWidth - intThumbWidth) / 2; 
  int bheight = (smallHeight - intThumbHeight) / 2; 
  g.DrawImage(bitmap, new Rectangle(0, 0, intThumbWidth, intThumbHeight), lwidth, bheight, intThumbWidth,intThumbHeight, GraphicsUnit.Pixel); 
  g.Dispose(); 
  bitmap1.Save(smallImagePath, System.Drawing.Imaging.ImageFormat.Jpeg); 
   return true; 
   } 
  } 
   } 
 } 
   } 
   catch 
   { 
 //出錯則刪除  
 System.IO.File.Delete(System.Web.HttpContext.Current.Server.MapPath(serverFileName)); 
 return false; 
   } 

 } 
 else 
 { 
   return false; 
 } 
  } 
  catch (Exception e) 
  { 
 return false; 
  } 
} 
/// summary> 
/// 檢查是否為合法的上傳文件 
/// /summary> 
/// param name="_fileExt">/param> 
/// returns>/returns> 
private bool CheckFileExt(string _fileExt) 
{ 
  string[] allowExt = new string[] { ".gif", ".jpg", ".jpeg" }; 
  for (int i = 0; i  allowExt.Length; i++) 
  { 
 if (allowExt[i] == _fileExt) { return true; } 
  } 
  return false; 
 
} 
   //生成隨機數文件名 
public static string GetFileName() 
{ 
  Random rd = new Random(); 
  StringBuilder serial = new StringBuilder(); 
  serial.Append(DateTime.Now.ToString("yyyyMMddHHmmssff")); 
  serial.Append(rd.Next(0, 999999).ToString()); 
  return serial.ToString(); 
 
} 

以上就是小編為大家帶來的AJAX實現圖片預覽與上傳及生成縮略圖的方法的全部內容了,希望對大家有所幫助,多多支持腳本之家~

您可能感興趣的文章:
  • jQuery AjaxUpload 上傳圖片代碼
  • php+ajax無刷新上傳圖片實例代碼
  • swfupload ajax無刷新上傳圖片實例代碼
  • jquery的ajaxSubmit()異步上傳圖片并保存表單數據演示代碼
  • JQuery+ajax實現批量上傳圖片(自寫)
  • Jquery ajaxsubmit上傳圖片實現代碼
  • Ajax 上傳圖片并預覽的簡單實現
  • 基于HTML5的可預覽多圖片Ajax上傳
  • 用ajax實現預覽鏈接可以看到鏈接的內容
  • Ajax上傳圖片及上傳前先預覽功能實例代碼

標簽:洛陽 鄭州 遼源 林芝 內蒙古 海南 舟山 邢臺

巨人網絡通訊聲明:本文標題《AJAX實現圖片預覽與上傳及生成縮略圖的方法》,本文關鍵詞  AJAX,實現,圖片,預覽,與,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《AJAX實現圖片預覽與上傳及生成縮略圖的方法》相關的同類信息!
  • 本頁收集關于AJAX實現圖片預覽與上傳及生成縮略圖的方法的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    国产精品素人一区二区| 国产精品欧美久久久久无广告| 精品国内二区三区| 欧美日韩国产a| 欧美videos中文字幕| 国产日韩精品一区二区三区在线| 一区二区成人在线视频| 国产精品久久久久久久午夜片| 亚洲成在人线在线播放| 久久精品国产99久久6| 成人三级在线视频| 亚洲av成人无码一二三在线观看| 老熟妇高潮一区二区三区| 欧美在线综合视频| 久久综合视频网| 一区二区三区色| 精品一区二区国语对白| 国内偷窥港台综合视频在线播放| 手机看片国产精品| 欧美人与性囗牲恔配| 欧美性生交大片| 色综合天天综合| 日韩女优制服丝袜电影| 欧美成人精品二区三区99精品| 亚洲精品久久久蜜桃| 亚洲二区在线视频| 国产99久久久国产精品| 国产一级二级视频| 欧洲亚洲精品在线| 久久久五月婷婷| 四虎地址8848| 69p69国产精品| 中文字幕日韩精品一区| 一区二区不卡在线视频 午夜欧美不卡在 | 日韩欧美在线视频播放| 欧美亚洲尤物久久| 国产三级一区二区| 亚洲视频一二区| 激情文学综合插| a级片在线观看视频| 国产大学生自拍| 6080午夜不卡| 亚洲精品网站在线观看| 黄色小说综合网站| 草草地址线路①屁屁影院成人| 欧美亚洲另类激情小说| 久久理论电影网| 亚洲一区二区三区四区的| 国产精品一级黄| 亚洲av片不卡无码久久| 亚洲一级二级片| 久久一二三国产| 视频一区二区中文字幕| 一卡二卡三卡四卡五卡| 99久久99久久精品国产| 欧美日韩成人综合在线一区二区 | 久久日韩精品一区二区五区| 国产成人亚洲综合a∨婷婷| 国产人妻精品午夜福利免费| 91精品欧美久久久久久动漫| 久久精品国产99久久6| 91丝袜呻吟高潮美腿白嫩在线观看| 最新黄色av网址| 久久人人爽人人爽| 奇米在线7777在线精品| 日本天堂在线播放| 91黄色在线观看| 中文字幕一区二区三区精华液| 国产精品一区在线观看乱码| 在线免费视频一区二区| 欧美精品在线观看一区二区| 欧美aaaaaa午夜精品| 97久久精品人人爽人人爽蜜臀| 粉嫩在线一区二区三区视频| 欧美一卡二卡三卡四卡| 日韩欧美一级片| 欧美嫩在线观看| 在线成人av影院| 日韩欧美www| 国产欧美精品一区二区色综合朱莉| 国产精品三级久久久久三级| 国产91色综合久久免费分享| 成人免费毛片东京热| jizz中文字幕| 疯狂揉花蒂控制高潮h| 欧美日韩一区二区三区在线看| 亚洲午夜精品久久久久久久久| 五月天丁香社区| 欧美一区二区在线播放| 三级影片在线观看欧美日韩一区二区| 国产肉体xxxx裸体784大胆| 欧美日韩国产欧美日美国产精品| 亚洲一区二区三区视频在线播放| 欧美一区二区免费在线观看| 国产精品久久久久影院| av网站免费线看精品| 色综合婷婷久久| 亚洲一区二区三区自拍| av不卡一区二区三区| 色婷婷精品久久二区二区蜜臂av| 亚洲午夜免费福利视频| 欧产日产国产精品98| 日韩欧美一级在线播放| 五月天激情小说综合| 女人被狂躁c到高潮| 欧美高清精品3d| 亚洲午夜精品在线| 国产人妻精品午夜福利免费| 17c精品麻豆一区二区免费| 国产91在线|亚洲| 欧美在线观看视频在线| 天天综合色天天综合| 在线小视频你懂的| 国产精品国产精品国产专区不蜜| 亚洲成人激情小说| 欧美性一二三区| 日本欧美一区二区| 超碰人人人人人人人| 免费在线观看你懂的| 欧美日韩国产成人在线91| 麻豆91精品91久久久的内涵| 欧美精品粉嫩高潮一区二区| 国产美女在线观看一区| 少妇真人直播免费视频| 欧美综合一区二区| 喷水一区二区三区| 亚洲精品久久一区二区三区777| 欧美日韩一区二区三区高清| 国产黑丝在线一区二区三区| 日韩欧美一区在线观看| 午夜欧美一区二区三区在线播放| 4438x全国最大成人| 在线观看91精品国产入口| 一区二区三区不卡在线观看| proumb性欧美在线观看| 欧美日韩另类一区| 精品一区二区在线播放| 在线亚洲高清视频| 久久99蜜桃精品| 在线观看欧美黄色| 久久国产精品99久久久久久老狼| 色婷婷av一区二区三区大白胸| 麻豆国产欧美一区二区三区| 欧美r级在线观看| av网站免费线看精品| 欧美va在线播放| 91年精品国产| 7777精品伊人久久久大香线蕉经典版下载| 国产乱国产乱300精品| 欧美日韩中文字幕一区二区| 91美女片黄在线| 国产亚洲欧美在线| 日本69式三人交| 亚洲男人的天堂在线aⅴ视频| 久久丫精品忘忧草西安产品| 久久电影网站中文字幕| 在线观看亚洲一区| 亚洲成av人综合在线观看| 亚洲AV成人无码精电影在线| 免费看黄色91| 欧美日韩免费观看一区二区三区 | 国产精品69毛片高清亚洲| 在线电影欧美成精品| 日日操免费视频| 五月激情六月综合| 色综合久久综合网欧美综合网| 国产剧情一区二区三区| 日韩欧美一级二级| www.com日本| 一区二区在线看| 欧美在线视频第一页| 国内成人免费视频| 欧美一区二区三区在线观看| 中文字幕被公侵犯的漂亮人妻| 日韩高清不卡一区| 欧美日韩一区视频| 国产精品影视网| 欧美一区二区三区播放老司机| 亚洲麻豆一区二区三区| 一区二区三区久久久| 色综合久久六月婷婷中文字幕| 狠狠狠色丁香婷婷综合激情| 亚洲精品视频一区| www青青草原| 免费不卡的av| 麻豆传媒在线看| 亚洲香蕉中文网| 亚洲精品国产高清久久伦理二区| 国产精品老熟女一区二区| 日本不卡高清视频| 在线观看亚洲专区| 9191在线视频| 亚洲在线免费播放| 欧美亚洲国产bt| 永久免费看片在线观看| 樱桃视频在线观看一区| 亚洲精品欧美综合四区| 欧美波霸videosex极品| 日韩精品欧美成人高清一区二区| 欧美综合天天夜夜久久|