国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專(zhuān)題視頻專(zhuān)題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專(zhuān)題1關(guān)鍵字專(zhuān)題50關(guān)鍵字專(zhuān)題500關(guān)鍵字專(zhuān)題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專(zhuān)題關(guān)鍵字專(zhuān)題tag2tag3文章專(zhuān)題文章專(zhuān)題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專(zhuān)題3
問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

.Net Core實(shí)現(xiàn)圖片文件上傳下載功能

來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:35:41
文檔

.Net Core實(shí)現(xiàn)圖片文件上傳下載功能

.Net Core實(shí)現(xiàn)圖片文件上傳下載功能:當(dāng)下.Net Core項(xiàng)目可是如雨后春筍一般發(fā)展起來(lái),作為.Net大軍中的一員,我熱忱地?fù)肀Я?Net Core并且積極使用其進(jìn)行業(yè)務(wù)的開(kāi)發(fā),我們先介紹下.Net Core項(xiàng)目下實(shí)現(xiàn)文件上傳下載接口。 一、開(kāi)發(fā)環(huán)境 毋庸置疑,宇宙第一IDE VisualStudio 2017
推薦度:
導(dǎo)讀.Net Core實(shí)現(xiàn)圖片文件上傳下載功能:當(dāng)下.Net Core項(xiàng)目可是如雨后春筍一般發(fā)展起來(lái),作為.Net大軍中的一員,我熱忱地?fù)肀Я?Net Core并且積極使用其進(jìn)行業(yè)務(wù)的開(kāi)發(fā),我們先介紹下.Net Core項(xiàng)目下實(shí)現(xiàn)文件上傳下載接口。 一、開(kāi)發(fā)環(huán)境 毋庸置疑,宇宙第一IDE VisualStudio 2017

當(dāng)下.Net Core項(xiàng)目可是如雨后春筍一般發(fā)展起來(lái),作為.Net大軍中的一員,我熱忱地?fù)肀Я?Net Core并且積極使用其進(jìn)行業(yè)務(wù)的開(kāi)發(fā),我們先介紹下.Net Core項(xiàng)目下實(shí)現(xiàn)文件上傳下載接口。

一、開(kāi)發(fā)環(huán)境

毋庸置疑,宇宙第一IDE VisualStudio 2017

二、項(xiàng)目結(jié)構(gòu)

FilesController 文件上傳下載控制器

PictureController 圖片上傳下載控制器

Return_Helper_DG 返回值幫助類(lèi)

三、關(guān)鍵代碼

1、首先我們來(lái)看Startup.cs 這個(gè)是我們的程序啟動(dòng)配置類(lèi),在這里我們進(jìn)行一系列的配置。

跨域配置:

當(dāng)然跨域少不了dll的引用,我們使用Nuget引用相關(guān)的引用包

服務(wù)器資源路徑置換,這樣可以防止客戶(hù)端猜測(cè)服務(wù)端文件路徑,制造一個(gè)虛擬的隱射進(jìn)行訪(fǎng)問(wèn),提高了安全性。

Startup.cs的完整代碼如下:

using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Http;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.FileProviders;
using Microsoft.Extensions.Logging;
using System.IO;

namespace QX_Core.FilesCenter
{
 public class Startup
 {
 public Startup(IHostingEnvironment env)
 {
 var builder = new ConfigurationBuilder()
 .SetBasePath(env.ContentRootPath)
 .AddJsonFile("appsettings.json", optional: false, reloadOnChange: true)
 .AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true)
 .AddEnvironmentVariables();
 Configuration = builder.Build();
 }

 public IConfigurationRoot Configuration { get; }

 // This method gets called by the runtime. Use this method to add services to the container.
 public void ConfigureServices(IServiceCollection services)
 {
 // Add framework services.
 services.AddMvc();
 #region CORS
 services.AddCors(options =>
 {
 options.AddPolicy("AllowSpecificOrigin",
 builder => builder.WithOrigins("http://localhost:3997").AllowAnyHeader().AllowAnyOrigin().AllowAnyMethod());
 });
 #endregion
 }

 // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
 public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory)
 {
 //loggerFactory.AddConsole(Configuration.GetSection("Logging"));
 //loggerFactory.AddDebug();

 app.UseMvc();
 // Shows UseCors with named policy.
 app.UseCors("AllowSpecificOrigin");

 app.UseStaticFiles(new StaticFileOptions()
 {
 FileProvider = new PhysicalFileProvider(Path.Combine(Directory.GetCurrentDirectory(), @"wwwroot/Files")),
 RequestPath = new PathString("/src")
 });
 }
 }
}

2、Return_Helper_DG類(lèi)用戶(hù)設(shè)置一個(gè)統(tǒng)一的返回值反饋到客戶(hù)端
Return_Helper_DG類(lèi)的代碼如下:

using System.Net;
/**
* author:qixiao
* create:2017-5-19 15:15:05
* */
namespace QX_Core.FilesCenter.QX_Core.Helper
{
 public abstract class Return_Helper_DG
 {
 public static object IsSuccess_Msg_Data_HttpCode(bool isSuccess, string msg, dynamic data, HttpStatusCode httpCode = HttpStatusCode.OK)
 {
 return new { isSuccess = isSuccess, msg = msg, httpCode = httpCode, data = data };
 }
 public static object Success_Msg_Data_DCount_HttpCode(string msg, dynamic data = null, int dataCount = 0, HttpStatusCode httpCode = HttpStatusCode.OK)
 {
 return new { isSuccess = true, msg = msg, httpCode = httpCode, data = data, dataCount = dataCount };
 }
 public static object Error_Msg_Ecode_Elevel_HttpCode(string msg, int errorCode = 0, int errorLevel = 0, HttpStatusCode httpCode = HttpStatusCode.InternalServerError)
 {
 return new { isSuccess = false, msg = msg, httpCode = httpCode, errorCode = errorCode, errorLevel = errorLevel };
 }
 }
}

3、FilesController是我們的文件上傳控制器接口,這里定義了對(duì)上傳的文件的接收操作,并且在控制器上啟用跨域配置

using Microsoft.AspNetCore.Cors;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Net.Http.Headers;
using QX_Core.FilesCenter.QX_Core.Helper;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;

namespace QX_Core.FilesCenter.Controllers
{
 //[Produces("application/json")]
 [Route("api/[controller]")]
 [EnableCors("AllowSpecificOrigin")]
 public class FilesController : Controller
 {
 private IHostingEnvironment hostingEnv;

 public FilesController(IHostingEnvironment env)
 {
 this.hostingEnv = env;
 }

 [HttpPost]
 public IActionResult Post()
 {
 var files = Request.Form.Files;
 long size = files.Sum(f => f.Length);

 //size > 100MB refuse upload !
 if (size > 104857600)
 {
 return Json(Return_Helper_DG.Error_Msg_Ecode_Elevel_HttpCode("files total size > 100MB , server refused !"));
 }

 List<string> filePathResultList = new List<string>();

 foreach (var file in files)
 {
 var fileName = ContentDispositionHeaderValue.Parse(file.ContentDisposition).FileName.Trim('"');

 string filePath = hostingEnv.WebRootPath + $@"\Files\Files\";

 if (!Directory.Exists(filePath))
 {
 Directory.CreateDirectory(filePath);
 }

 fileName = Guid.NewGuid() + "." + fileName.Split('.')[1];

 string fileFullName = filePath + fileName;

 using (FileStream fs = System.IO.File.Create(fileFullName))
 {
 file.CopyTo(fs);
 fs.Flush();
 }
 filePathResultList.Add($"/src/Files/{fileName}");
 }

 string message = $"{files.Count} file(s) /{size} bytes uploaded successfully!";

 return Json(Return_Helper_DG.Success_Msg_Data_DCount_HttpCode(message, filePathResultList, filePathResultList.Count));
 }

 }
}

在上述的代碼中,我們對(duì)上傳的文件的大小進(jìn)行了限制,并且對(duì)文件的大小進(jìn)行反饋。

4、PictureController 圖片上傳控制器接口,類(lèi)似于文件,不過(guò)對(duì)上傳的圖片類(lèi)型進(jìn)行了校驗(yàn)和限制

using Microsoft.AspNetCore.Cors;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Net.Http.Headers;
using QX_Core.FilesCenter.QX_Core.Helper;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;

namespace QX_Core.FilesCenter.Controllers
{
 //[Produces("application/json")]
 [Route("api/[controller]")]
 [EnableCors("AllowSpecificOrigin")]
 public class PicturesController : Controller
 {
 private IHostingEnvironment hostingEnv;

 string[] pictureFormatArray = { "png", "jpg", "jpeg", "bmp", "gif","ico", "PNG", "JPG", "JPEG", "BMP", "GIF","ICO" };

 public PicturesController(IHostingEnvironment env)
 {
 this.hostingEnv = env;
 }

 [HttpPost]
 public IActionResult Post()
 {
 var files = Request.Form.Files;
 long size = files.Sum(f => f.Length);

 //size > 100MB refuse upload !
 if (size > 104857600)
 {
 return Json(Return_Helper_DG.Error_Msg_Ecode_Elevel_HttpCode("pictures total size > 100MB , server refused !"));
 }

 List<string> filePathResultList = new List<string>();

 foreach (var file in files)
 {
 var fileName = ContentDispositionHeaderValue.Parse(file.ContentDisposition).FileName.Trim('"');

 string filePath = hostingEnv.WebRootPath + $@"\Files\Pictures\";

 if (!Directory.Exists(filePath))
 {
 Directory.CreateDirectory(filePath);
 }

 string suffix = fileName.Split('.')[1];

 if (!pictureFormatArray.Contains(suffix))
 {
 return Json(Return_Helper_DG.Error_Msg_Ecode_Elevel_HttpCode("the picture format not support ! you must upload files that suffix like 'png','jpg','jpeg','bmp','gif','ico'."));
 }

 fileName = Guid.NewGuid() + "." + suffix;

 string fileFullName = filePath + fileName;

 using (FileStream fs = System.IO.File.Create(fileFullName))
 {
 file.CopyTo(fs);
 fs.Flush();
 }
 filePathResultList.Add($"/src/Pictures/{fileName}");
 }

 string message = $"{files.Count} file(s) /{size} bytes uploaded successfully!";

 return Json(Return_Helper_DG.Success_Msg_Data_DCount_HttpCode(message, filePathResultList, filePathResultList.Count));
 }

 }
}

到此,我們的文件圖片上傳代碼已經(jīng)全部完成,下面我們對(duì)文件上傳的客戶(hù)端進(jìn)行實(shí)現(xiàn)

四、客戶(hù)端的實(shí)現(xiàn) 

客戶(hù)端我們很簡(jiǎn)單地用jQuery Ajax的方式進(jìn)行圖片文件的提交,客戶(hù)端代碼的實(shí)現(xiàn):

<!doctype>

<head>
 <script src="jquery-3.2.0.min.js"></script>
 <script>
 $(document).ready(function () {
 var appDomain = "http://localhost:53972/";
 $("#btn_fileUpload").click(function () {
 var fileUpload = $("#files").get(0);
 var files = fileUpload.files;
 var data = new FormData();
 for (var i = 0; i < files.length; i++) {
 data.append(files[i].name, files[i]);
 }
 $.ajax({
 type: "POST",
 url: appDomain+'api/Pictures',
 contentType: false,
 processData: false,
 data: data,
 success: function (data) {
 console.log(JSON.stringify(data));
 },
 error: function () {
 console.log(JSON.stringify(data));
 }
 });
 });
 //end click


 })
 </script>
</head>
<title></title>

<body>
 <article>
 <header>
 <h2>article-form</h2>
 </header>
 <p>
 <form id="uploadForm" enctype="multipart/form-data">
 <input type="file" id="files" name="files" placeholder="file" multiple>file-multiple屬性可以選擇多項(xiàng)<br><br>
 <input type="button" id="btn_fileUpload" value="fileUpload">
 </form>
 </p>
 </article>
</body>

五、代碼測(cè)試

1.啟動(dòng)服務(wù)器

我們可以看到一個(gè)控制臺(tái)和一個(gè)web自動(dòng)啟動(dòng),并且web顯示默認(rèn)的Values控制器的請(qǐng)求返回值。

2.圖片上傳

我們使用ajax的方式進(jìn)行圖片的上傳操作,打開(kāi)測(cè)試web頁(yè)面,并且選擇圖片,點(diǎn)擊上傳,查看控制臺(tái)返回的結(jié)果:

可以看到,一張圖片上傳成功!

輸入返回的地址,我們可以看到成功訪(fǎng)問(wèn)到了圖片,特別注意這里服務(wù)器路徑的改變:

多圖片上傳:

可見(jiàn),多圖片上傳沒(méi)有任何問(wèn)題!

同樣進(jìn)行文件上傳的測(cè)試:

同樣,文件上傳也沒(méi)有任何問(wèn)題!

六、總結(jié)

至此,我們已經(jīng)實(shí)現(xiàn)了預(yù)期的.Net Core圖片文件上傳的全部功能!

聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

.Net Core實(shí)現(xiàn)圖片文件上傳下載功能

.Net Core實(shí)現(xiàn)圖片文件上傳下載功能:當(dāng)下.Net Core項(xiàng)目可是如雨后春筍一般發(fā)展起來(lái),作為.Net大軍中的一員,我熱忱地?fù)肀Я?Net Core并且積極使用其進(jìn)行業(yè)務(wù)的開(kāi)發(fā),我們先介紹下.Net Core項(xiàng)目下實(shí)現(xiàn)文件上傳下載接口。 一、開(kāi)發(fā)環(huán)境 毋庸置疑,宇宙第一IDE VisualStudio 2017
推薦度:
  • 熱門(mén)焦點(diǎn)

最新推薦

猜你喜歡

熱門(mén)推薦

專(zhuān)題
Top
主站蜘蛛池模板: 国产成人99久久亚洲综合精品 | 精品视频一区二区三区四区五区 | 亚洲欧美另类自拍第一页 | 国产91成人精品亚洲精品 | 国内精品久久久久久久97牛牛 | 国产成人三级经典中文 | 中文字幕在线不卡 | 国产黄色小视频在线观看 | 精品一区 二区三区免费毛片 | 国产福利一区二区 | 国产在线播放免费 | 欧美αv日韩αv另类综合 | 亚洲第一区视频在线观看 | 自拍偷自拍亚洲精品情侣 | 亚洲日韩精品欧美一区二区 | 久久久影院亚洲精品 | 在线免费国产 | 久久精品国产一区二区三区 | 亚洲国产第一页 | 日韩国产欧美一区二区三区 | 日韩亚洲欧美综合 | 亚洲精品免费在线观看 | 久久成人a毛片免费观看网站 | 国产精品第一区在线观看 | 一级毛片免费毛片毛片 | 欧美日本在线 | 国产在线高清视频 | 91精品久久久久久久久久 | 日韩中文欧美 | 亚洲国产成人久久综合一 | 一级一级一级毛片免费毛片 | 亚洲一区精品伊人久久 | 亚洲国产精久久久久久久 | 国产成人黄网址在线视频 | 一区二区三区免费电影 | 欧美日韩精品一区二区三区视频在线 | 国产精品一区二区三区高清在线 | 国产最新在线视频 | 91精品啪国产在线观看免费牛牛 | 日日综合| 免费国产叼嘿视频大全网站 |