溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在.Net中使用Layui實現(xiàn)多圖片上傳功能

發(fā)布時間:2021-06-08 16:28:00 來源:億速云 閱讀:168 作者:Leah 欄目:開發(fā)技術

本篇文章給大家分享的是有關怎么在.Net中使用Layui實現(xiàn)多圖片上傳功能,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

一、引入Layui.cs和Layui.js:

需要本地項目中存在layui相關樣式和js,非網絡地址

 <link rel="stylesheet" href="//res.layui.com/layui/dist/css/layui.css" rel="external nofollow"   media="all">

 <script src="//res.layui.com/layui/dist/layui.js" charset="utf-8"></script>

當然假如你需要有彈框提示的話,你還需要引入Layer.js

二、前端代碼:

a.Html中的代碼:

<li>
<h7>滾動圖片:</h7>
 <div class="layui-upload">
<button type="button" class="layui-btn" id="test2">滾動圖片上傳【推薦上傳三張】</button> <button type="button" class="layui-btn layui-btn-danger" onclick="clearAll()"><i class="layui-icon"></i></button>
<input type="hidden" name="ScrollingGraph" id="ScrollingGraph"/>
<blockquote class="layui-elem-quote layui-quote-nm" >
預覽圖:
<div class="layui-upload-list" id="demo2"></div>
</blockquote>
</div>
</li>

b.js中的代碼:

<script>
layui.use('upload',
function () {
var $ = layui.jquery, upload = layui.upload;
//多圖片上傳
upload.render({
 elem: '#test2',
 url: '/FileUpload/FileLoad/',
 multiple: true,//允許選擇多張圖片
before: function (obj) {
//預讀本地文件示例,不支持ie8
obj.preview(function (index, file, result) {
$('#demo2').append(
'<img src="' + result + '" alt="' + file.name + '" class="layui-upload-img">');
});
},
done: function (res) {
if (res.isSuccess == true) {
layer.msg("上傳成功");
var scrollingGraph = $("#ScrollingGraph").val();
if (scrollingGraph == "") {
$("#ScrollingGraph").val(res.path);
} else {
scrollingGraph += ',' + res.path;
$("#ScrollingGraph").val(scrollingGraph);
}
console.log(scrollingGraph);
} else {
return layer.msg('上傳失敗');
}
}
});
});


//清空所有圖片
function clearAll() {
layer.confirm("確定要全部清空嗎?", {
icon: 3,
btn: ["確定", "取消"],
yes: function (index) {
$("#demo2").html("");
$("#ScrollingGraph").val("");
layer.close(index);
}
});
}

</script>

三、服務端接口圖片文件流,并保存:

1public class FileUploadController : Controller
 2{
 3/// <summary>
/// 對驗證和處理 HTML 窗體中的輸入數(shù)據(jù)所需的信息進行封裝,如FromData拼接而成的文件
/// </summary>
/// <param name="context">FemContext對驗證和處理html窗體中輸入的數(shù)據(jù)進行封裝</param>
/// <returns></returns>
[HttpPost]
public ActionResult FileLoad(FormContext context)
 {
HttpPostedFileBase httpPostedFileBase = Request.Files[0];//獲取二進制圖片文件流
if (httpPostedFileBase != null)
{
try
{
ControllerContext.HttpContext.Request.ContentEncoding = Encoding.GetEncoding("UTF-8");
ControllerContext.HttpContext.Response.Charset = "UTF-8";

string fileName = Path.GetFileName(httpPostedFileBase.FileName);//原始文件名稱
string fileExtension = Path.GetExtension(fileName);//文件擴展名

byte[] fileData = ReadFileBytes(httpPostedFileBase);//文件流轉化為二進制字節(jié)

string result = SaveFile(fileExtension, fileData);//文件保存
if (string.IsNullOrEmpty(result))
{
return Json(new { isSuccess = false, path = "",errorMsg= "上傳文件失敗"});
}

return Json(new { isSuccess = true, path = result });
}
catch (Exception ex)
{
return Json(new { isSuccess = false, path = "" });
}
}
else
{
return Json(new { isSuccess = false, path = "" });
}
}


/// <summary>
/// 將文件流轉化為二進制字節(jié)
/// </summary>
/// <param name="fileData">圖片文件流</param>
/// <returns></returns>
private byte[] ReadFileBytes(HttpPostedFileBase fileData)
{
byte[] data;
using (Stream inputStream = fileData.InputStream)
{
MemoryStream memoryStream = inputStream as MemoryStream;
if (memoryStream == null)
{
memoryStream = new MemoryStream();
inputStream.CopyTo(memoryStream);
}
data = memoryStream.ToArray();
}
return data;
}

/// <summary>
/// 保存文件
/// </summary>
/// <param name="fileExtension">文件擴展名</param>
/// <param name="fileData">圖片二進制文件信息</param>
/// <returns></returns>
private string SaveFile(string fileExtension, byte[] fileData)
{
string result;
try
{

string saveName = Guid.NewGuid().ToString()+ fileExtension; //保存文件名稱

// 文件上傳后的保存路徑
string basePath = "UploadFile";
string saveDir = DateTime.Now.ToString("yyyy-MM-dd");
string savePath = System.IO.Path.Combine(saveDir, saveName);

string serverDir = System.IO.Path.Combine(Server.MapPath("~/"), basePath, saveDir);
if (!System.IO.Directory.Exists(serverDir))
{
System.IO.Directory.CreateDirectory(serverDir);
}
string fileNme = System.IO.Path.Combine(serverDir, saveName);//保存文件完整路徑
System.IO.File.WriteAllBytes(fileNme, fileData);//WriteAllBytes創(chuàng)建一個新的文件,按照對應的文件流寫入,假如已存在則覆蓋
//返回完整的圖片保存地址
result="/"+basePath + "/" + saveDir + "/" + saveName;
}
catch (Exception)
{
result = "發(fā)生錯誤";
}
return result;
}
}

以上就是怎么在.Net中使用Layui實現(xiàn)多圖片上傳功能,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。

AI