.Net學(xué)習(xí)筆記之Layui多圖片上傳功能
前言:
多圖上傳在一些特殊的需求中我們經(jīng)常會(huì)遇到,其實(shí)多圖上傳的原理大家都有各自的見(jiàn)解。對(duì)于Layui多圖上傳和我之前所說(shuō)的通過(guò)js獲取文本框中的文件數(shù)組遍歷提交的原理一樣,只不過(guò)是Layui中的upload.render方法已經(jīng)幫我們封裝好了,我們只管調(diào)用即可,也就是說(shuō)你選中了幾張圖片,那么將會(huì)向后臺(tái)請(qǐng)求與圖片張數(shù)相同的次數(shù),即為遍歷提交的方式。
Layui文件/圖片樣式地址(官方文檔):https://www.layui.com/demo/upload.html
一、引入Layui.cs和Layui.js:
需要本地項(xiàng)目中存在layui相關(guān)樣式和js,非網(wǎng)絡(luò)地址
<link rel="stylesheet" rel="external nofollow" media="all">
<script src="http://res.layui.com/layui/dist/layui.js" charset="utf-8"></script>
當(dāng)然假如你需要有彈框提示的話,你還需要引入Layer.js
二、前端代碼:
a.Html中的代碼:
<li> <h6>滾動(dòng)圖片:</h6> <div class="layui-upload"> <button type="button" class="layui-btn" id="test2">滾動(dòng)圖片上傳【推薦上傳三張】</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" style="margin-top: 10px;"> 預(yù)覽圖: <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) {
//預(yù)讀本地文件示例,不支持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>
三、服務(wù)端接口圖片文件流,并保存:
1public class FileUploadController : Controller
2{
3/// <summary>
/// 對(duì)驗(yàn)證和處理 HTML 窗體中的輸入數(shù)據(jù)所需的信息進(jìn)行封裝,如FromData拼接而成的文件
/// </summary>
/// <param name="context">FemContext對(duì)驗(yàn)證和處理html窗體中輸入的數(shù)據(jù)進(jìn)行封裝</param>
/// <returns></returns>
[HttpPost]
public ActionResult FileLoad(FormContext context)
{
HttpPostedFileBase httpPostedFileBase = Request.Files[0];//獲取二進(jìn)制圖片文件流
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);//文件擴(kuò)展名
byte[] fileData = ReadFileBytes(httpPostedFileBase);//文件流轉(zhuǎn)化為二進(jìn)制字節(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>
/// 將文件流轉(zhuǎn)化為二進(jìn)制字節(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">文件擴(kuò)展名</param>
/// <param name="fileData">圖片二進(jìn)制文件信息</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)建一個(gè)新的文件,按照對(duì)應(yīng)的文件流寫(xiě)入,假如已存在則覆蓋
//返回完整的圖片保存地址
result="/"+basePath + "/" + saveDir + "/" + saveName;
}
catch (Exception)
{
result = "發(fā)生錯(cuò)誤";
}
return result;
}
}
四、效果圖展示:


總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
ASP.NET下使用WScript.Shell執(zhí)行命令
ASP.NET下有自己的執(zhí)行CMD命令的方式,這里用WScript.Shell似有畫(huà)蛇添足之嫌,但是我們也不能排除真的有機(jī)器禁用了.NET的相關(guān)類,未雨綢繆嘛。當(dāng)然也不僅僅局限于WScript.Shell,只要是ASP中能用的組件,統(tǒng)統(tǒng)都可以用于ASP.NET中,而且還更方便!2008-05-05
win10下vs2015配置Opencv3.1.0詳細(xì)過(guò)程
這篇文章主要為大家詳細(xì)介紹了win10下vs2015配置Opencv3.1.0的詳細(xì)過(guò)程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11
.net 中的 StringBuilder 和 TextWriter 區(qū)別詳解
這篇文章主要介紹了.net 中的 StringBuilder 和 TextWriter 區(qū)別詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
ASP.NET網(wǎng)站的創(chuàng)建與發(fā)布過(guò)程簡(jiǎn)析
這篇文章主要介紹了ASP.NET的創(chuàng)建與發(fā)布過(guò)程,過(guò)程實(shí)現(xiàn)很簡(jiǎn)單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2015-08-08
ASP.NET中利用Segments取得URL的文件名的一種方法分享
在ASP.NET中,取得請(qǐng)求頁(yè)的URL地址有多種方式,其中有一種方式取得網(wǎng)頁(yè)文件名。2011-09-09
asp.net用url重寫(xiě)URLReWriter實(shí)現(xiàn)任意二級(jí)域名
Asp.net 用url重寫(xiě)(URLReWriter)實(shí)現(xiàn)任意二級(jí)域名2008-10-10
Asp.Net FckEditor在web.config中配置的具體實(shí)例
Asp.Net FckEditor在web.config中配置的具體實(shí)例,需要的朋友可以參考一下2013-06-06

