日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

js+php在线截图 jquery fileupload.js,另一种图片上传 jquery.fileupload.js

發布時間:2023/12/3 php 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 js+php在线截图 jquery fileupload.js,另一种图片上传 jquery.fileupload.js 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

今天遇到另外一種上傳圖片方法

用jquery.fileupload.js

一個文件類型的元素

$("#fileupload").fileupload({

datatype:"json",

url: "/File/UploadFiles",

done: function (e, data) { //上傳結束的操作

if (data.result[0].result != "OK") //不成功的時候 彈出消息

{

alert(data.result[0].result);

}

else

{

$("#imgshow").attr("src", data.result[0].thumbnail_url); //成功的時候顯示圖片

}

}

})

上面的url 處理當選擇完成圖片后進行的上傳操作

public string path = "~/Files";

[HttpPost]

public ActionResult UploadFiles()

{

var r = new List();

foreach (string file in Request.Files)

{

var statuses = new List();

var headers = Request.Headers;

if (string.IsNullOrEmpty(headers["X-File-Name"]))

{

UploadWholeFile(Request, statuses);

}

else

{

UploadPartialFile(headers["X-File-Name"], Request, statuses);

}

JsonResult result = Json(statuses);

result.ContentType = "text/plain";

return result;

}

return Json(r);

}

上面是uploadfiles方法。

ViewDataUploadFilesResult是定義的文件類

public class ViewDataUploadFilesResult

{

public string name { get; set; }

public int size { get; set; }

public string type { get; set; }

public string url { get; set; }

public string delete_url { get; set; }

public string thumbnail_url { get; set; }

public string delete_type { get; set; }

public string result { set; get; }

}

有名字尺寸類型等屬性

UploadWholeFile上傳整個文件

private void UploadWholeFile(HttpRequestBase request, List statuses)

{

for (int i = 0; i < request.Files.Count; i++)

{

string result = ISValid(request.Files[i], "image");

if (result!= "OK")

{

statuses.Add(new ViewDataUploadFilesResult() { result=result});

}

}

if (statuses.Count > 0) return;

for (int i = 0; i < request.Files.Count; i++)

{

var file = request.Files[i];

if (!Directory.Exists(StorageRoot))

{

Directory.CreateDirectory(StorageRoot);

}

string fileExt = Path.GetExtension(file.FileName).ToLower();

string newFileName = DateTime.Now.ToString("yyyyMMddHHmmss_ffff", DateTimeFormatInfo.InvariantInfo) + fileExt;

var fullPath = Path.Combine(StorageRoot, newFileName);

file.SaveAs(fullPath);

statuses.Add(new ViewDataUploadFilesResult()

{

result = "OK",

name = newFileName,

size = file.ContentLength,

type = file.ContentType,

url = Path.Combine(path, Path.GetFileName(newFileName)),

delete_url = "/Home/Delete/" + newFileName,

thumbnail_url = @"data:image/png;base64," + EncodeFile(fullPath),

delete_type = "GET",

});

}

}

private void UploadPartialFile(string fileName, HttpRequestBase request, List statuses)

{

if (request.Files.Count != 1) throw new HttpRequestValidationException("Attempt to upload chunked file containing more than one fragment per request");

var file = request.Files[0];

string result = ISValid(file, "image");

if (result != "OK")

{

statuses.Add(new ViewDataUploadFilesResult() { result = result });

}

if (statuses.Count > 0) return;

var inputStream = file.InputStream;

if (!Directory.Exists(StorageRoot))

{

Directory.CreateDirectory(StorageRoot);

}

string fileExt = Path.GetExtension(file.FileName).ToLower();

string newFileName = DateTime.Now.ToString("yyyyMMddHHmmss_ffff", DateTimeFormatInfo.InvariantInfo) + fileExt;

var fullName = Path.Combine(StorageRoot, newFileName);

using (var fs = new FileStream(fullName, FileMode.Append, FileAccess.Write))

{

var buffer = new byte[1024];

var l = inputStream.Read(buffer, 0, 1024);

while (l > 0)

{

fs.Write(buffer, 0, l);

l = inputStream.Read(buffer, 0, 1024);

}

fs.Flush();

fs.Close();

}

statuses.Add(new ViewDataUploadFilesResult()

{

result="OK",

name = newFileName,

size = file.ContentLength,

type = file.ContentType,

url = Path.Combine(path, Path.GetFileName(newFileName)),

delete_url = "/Home/Delete/" + newFileName,

thumbnail_url = @"data:image/png;base64," + EncodeFile(fullName),

delete_type = "GET",

});

}

上傳部分文件

private string ISValid(HttpPostedFileBase file,string dirName)

{

//定義允許上傳的文件擴展名

Hashtable extTable = new Hashtable();

extTable.Add("image", "gif,jpg,jpeg,png,bmp");

extTable.Add("flash", "swf,flv");

extTable.Add("media", "swf,flv,mp3,wav,wma,wmv,mid,avi,mpg,asf,rm,rmvb");

extTable.Add("file", "doc,docx,xls,xlsx,ppt,htm,html,txt,zip,rar,gz,bz2");

//最大文件大小

int maxSize = 1000000;

String fileName = file.FileName;

String fileExt = Path.GetExtension(fileName).ToLower();

if (file.InputStream == null || file.InputStream.Length > maxSize)

{

return "上傳文件大小超過限制。";

}

if (String.IsNullOrEmpty(fileExt) || Array.IndexOf(((String)extTable[dirName]).Split(','), fileExt.Substring(1).ToLower()) == -1)

{

return "上傳文件擴展名是不允許的擴展名。\n只允許" + ((String)extTable[dirName]) + "格式。";

}

return "OK";

}

isvalid驗證上傳文件是否合理

private string EncodeFile(string fileName)

{

return Convert.ToBase64String(System.IO.File.ReadAllBytes(fileName));

}

[HttpGet]

public void Delete(string id)

{

var filename = id;

var filePath = Path.Combine(Server.MapPath("~/Files"), filename);

if (System.IO.File.Exists(filePath))

{

System.IO.File.Delete(filePath);

}

}

來源:https://www.cnblogs.com/jiangyou-lz/p/5707542.html

總結

以上是生活随笔為你收集整理的js+php在线截图 jquery fileupload.js,另一种图片上传 jquery.fileupload.js的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。