1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > AJAX实现图片预览与上传及生成缩略图办法

AJAX实现图片预览与上传及生成缩略图办法

时间:2023-10-31 19:05:36

相关推荐

AJAX实现图片预览与上传及生成缩略图办法

web前端|js教程

AJAX,上传,预览

web前端-js教程

下面小编就为大家带来一篇AJAX实现图片预览与上传及生成缩略图的方法。小编觉得挺不错的,现在就分享ajax等源码给大家,也给大家做个参考。一起跟随小编过来看看AJAX实现图片预览与上传及生成缩略图的方法吧

惠农网源码,vscode中beauty,ubuntu 衍生,tomcat路径查看,c# sqlite orm,网页导出word文档插件下载,前端框架的树是什么,游戏爬虫什么意思,php 文件夹下所有文件,seo培训一年赚多少seo顾问,焊接设备器材网站源码,网页状态栏特效 失效,织梦手机模板不存在lzw

要实现功能,上传图片时可以预览,因还有别的文字,所以并不只上传图片,实现与别的文字一起保存,当然上来先上传图片,然后把路径和别的文字一起写入数据库;同时为图片生成缩略图,现只写上传图片方法,文字在ajax里直接传参数就可以了,若要上传多图,修改一下就可以了。

基于web的网上购物系统源码,安装vscode如何配置,ubuntu更换命令,tomcat监听外网端口,春天爬虫,php上个月最后一天,零距离seo广告,微信大秀网站源码,通用导入模板lzw

借鉴了网上资料,自己写了一下,并不需要再新加页面,只在一个页面里就OK啦。

微转金 源码,vscode最大化了,arp ubuntu,tomcat 存放图片,sqlite 自动,珠宝首饰网页设计配色,mysql数据库关闭远程访问,503服务器,jquery三级联动菜单插件,前端框架,我用爬虫,php文档管理系统,赶集网seo,springboot限制并发,dede图片集标签,qq教程网站源码带整站,网页弹窗,bootstrap 微信 内容 模板下载,网站后台无法更新缓存,购物网页中商品展示页面源码,开源维修管理系统,程序php源码怎么用lzw

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; }

以下为前台代码:

//实现预览//加这个主要是为了实现查看时显示图片,因为上面的(idImg)加上runat="server"报错,如有好的方法可以留言

以下为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; } } /// /// /// private bool CheckFileExt(string _fileExt) { string[] allowExt = new string[] { ".jpg" alt="AJAX实现图片预览与上传及生成缩略图办法" title="AJAX实现图片预览与上传及生成缩略图办法", ".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(); }

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。