溫馨提示×

溫馨提示×

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

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

如何在VUE中使用iView+.Net Core實現(xiàn)上傳圖片

發(fā)布時間:2022-05-06 14:04:42 來源:億速云 閱讀:240 作者:iii 欄目:大數(shù)據(jù)

本篇內(nèi)容主要講解“如何在VUE中使用iView+.Net Core實現(xiàn)上傳圖片”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“如何在VUE中使用iView+.Net Core實現(xiàn)上傳圖片”吧!

首先要創(chuàng)建一個WebApi項目,創(chuàng)建完之后,在wwwroot文件下,創(chuàng)建一個文件夾 名字可以隨意起  我這里呢就叫做Upload了

如何在VUE中使用iView+.Net Core實現(xiàn)上傳圖片

ok ! 然后我們再創(chuàng)建一個控制器 IndexController 代碼如下

要知道上傳圖片都是通過HTTP去請求,服務端從request中讀取

public class PicData
    {
      public string Msg { get; set; }
    }

    [HttpPost]
    public async Task<bool> InsertPicture([FromServices]IHostingEnvironment environment)
    {
      var data = new PicData();
      string path = string.Empty;
      var files = Request.Form.Files;
      if (files == null || files.Count() <= 0)
      {
        data.Msg = "請選擇上傳的文件。";
        return false;
      }

      //格式限制
      var allowType = new string[] {"image/jpg", "image/png", "image/jpeg"};
      if (files.Any(c => allowType.Contains(c.ContentType)))
      {
        if (files.Sum(c => c.Length) <= 1024 * 1024 * 4)
        {
          foreach (var file in files)
          {
            string strpath = Path.Combine("Upload", DateTime.Now.ToString("MMddHHmmss") + file.FileName);
            path = Path.Combine(environment.WebRootPath, strpath);

            using (var stream = new FileStream(path, FileMode.OpenOrCreate, FileAccess.ReadWrite))
            {
              await file.CopyToAsync(stream);
            }
          }

          data.Msg = "上傳成功";
          return true;
        }
        else
        {
          data.Msg = "圖片過大";
          return false;
        }
      }
      else

      {
        data.Msg = "圖片格式錯誤";
        return false;
      }
    }

注意一下這段代碼

string strpath = Path.Combine("Upload", DateTime.Now.ToString("MMddHHmmss") + file.FileName);

在wwwroot下創(chuàng)建的文件夾,要將Upload替換成你的文件夾名稱

然后這還沒有完,還要做跨域,要在Startup.cs文件中去改

public void ConfigureServices(IServiceCollection services)
    {
      services.AddMvc();
      services.AddCors(options =>
      {
        options.AddPolicy("hehe", p => p.AllowAnyMethod()// 允許任何方法 GET,POST,PUT,DELETE, OPTIONS
            .AllowAnyHeader()    // 允許任何請求頭
            .AllowAnyOrigin()    // 允許任何地址
        );
      });
    }

ConfigureServices方法,然后還有Configure方法

public void Configure(IApplicationBuilder app, IHostingEnvironment env)
    {
      app.UseStaticFiles(); app.UseCors("hehe");
      if (env.IsDevelopment())
      {
        app.UseDeveloperExceptionPage();
      }
      app.UseMvc();
    }

ok完成了,

然后我們就要去創(chuàng)建Vue項目了,

使用npm創(chuàng)建vue項目,vue init webpack file     我們跳過創(chuàng)建過程

使用npm 引用iview  然后在vue項目中的main.js中引用

import iView from 'iview';
import 'iview/dist/styles/iview.css';
import locale from 'iview/dist/locale/en-US';

Vue.use(iView, { locale });

ok,然后我們就在app.vue里面寫代碼

<template>
 <div id="app">
  
  <Upload action="http://localhost:53688/api/Index">
    <Button icon="ios-cloud-upload-outline">Upload files</Button>
  </Upload>

 </div>
</template>

到此,相信大家對“如何在VUE中使用iView+.Net Core實現(xiàn)上傳圖片”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學習!

向AI問一下細節(jié)

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

AI