日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
.NetCore開發(fā)如何實現(xiàn)圖片文件上傳下載功能

這篇文章主要介紹.Net Core開發(fā)如何實現(xiàn)圖片文件上傳下載功能,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!

成都網(wǎng)站設(shè)計、網(wǎng)站建設(shè)的開發(fā),更需要了解用戶,從用戶角度來建設(shè)網(wǎng)站,獲得較好的用戶體驗。創(chuàng)新互聯(lián)建站多年互聯(lián)網(wǎng)經(jīng)驗,見的多,溝通容易、能幫助客戶提出的運營建議。作為成都一家網(wǎng)絡(luò)公司,打造的就是網(wǎng)站建設(shè)產(chǎn)品直銷的概念。選擇創(chuàng)新互聯(lián)建站,不只是建站,我們把建站作為產(chǎn)品,不斷的更新、完善,讓每位來訪用戶感受到浩方產(chǎn)品的價值服務(wù)。

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

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

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

.Net Core開發(fā)如何實現(xiàn)圖片文件上傳下載功能

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

.Net Core開發(fā)如何實現(xiàn)圖片文件上傳下載功能

FilesController 文件上傳下載控制器

PictureController 圖片上傳下載控制器

Return_Helper_DG 返回值幫助類

三、關(guān)鍵代碼

1、首先我們來看Startup.cs 這個是我們的程序啟動配置類,在這里我們進行一系列的配置。

跨域配置:

.Net Core開發(fā)如何實現(xiàn)圖片文件上傳下載功能

.Net Core開發(fā)如何實現(xiàn)圖片文件上傳下載功能

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

.Net Core開發(fā)如何實現(xiàn)圖片文件上傳下載功能

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

.Net Core開發(fā)如何實現(xià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類用戶設(shè)置一個統(tǒng)一的返回值反饋到客戶端
Return_Helper_DG類的代碼如下:

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是我們的文件上傳控制器接口,這里定義了對上傳的文件的接收操作,并且在控制器上啟用跨域配置

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 filePathResultList = new List();

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

 }
}

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

4、PictureController 圖片上傳控制器接口,類似于文件,不過對上傳的圖片類型進行了校驗和限制

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 filePathResultList = new List();

  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)全部完成,下面我們對文件上傳的客戶端進行實現(xiàn)

四、客戶端的實現(xiàn)

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




 
 




 

article-form

file-multiple屬性可以選擇多項

五、代碼測試

1.啟動服務(wù)器

.Net Core開發(fā)如何實現(xiàn)圖片文件上傳下載功能

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

2.圖片上傳

我們使用ajax的方式進行圖片的上傳操作,打開測試web頁面,并且選擇圖片,點擊上傳,查看控制臺返回的結(jié)果:

.Net Core開發(fā)如何實現(xiàn)圖片文件上傳下載功能

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

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

.Net Core開發(fā)如何實現(xiàn)圖片文件上傳下載功能

多圖片上傳:

.Net Core開發(fā)如何實現(xiàn)圖片文件上傳下載功能

.Net Core開發(fā)如何實現(xiàn)圖片文件上傳下載功能

可見,多圖片上傳沒有任何問題!

同樣進行文件上傳的測試:

.Net Core開發(fā)如何實現(xiàn)圖片文件上傳下載功能

.Net Core開發(fā)如何實現(xiàn)圖片文件上傳下載功能

同樣,文件上傳也沒有任何問題!

以上是.Net Core開發(fā)如何實現(xiàn)圖片文件上傳下載功能的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


分享標(biāo)題:.NetCore開發(fā)如何實現(xiàn)圖片文件上傳下載功能
網(wǎng)站地址:http://www.dlmjj.cn/article/ghhchd.html