學習ASP.NET Core Razor 編程系列十五——文件上傳功能(三)

来源:https://www.cnblogs.com/chillsrc/archive/2018/07/11/9294202.html
-Advertisement-
Play Games

我們通過前面的二篇文章的學習,已經實現了文件上傳的主要功能,這一篇文章我們來學習如何把上傳文件的功能頁面添加到首面上面,以及刪除功能的實現 。 ...


學習ASP.NET Core Razor 編程系列目錄

學習ASP.NET Core Razor 編程系列一

學習ASP.NET Core Razor 編程系列二——添加一個實體

 學習ASP.NET Core Razor 編程系列三——創建數據表及創建項目基本頁面

學習ASP.NET Core Razor 編程系列四——Asp.Net Core Razor列表模板頁面

學習ASP.NET Core Razor 編程系列五——Asp.Net Core Razor新建模板頁面

學習ASP.NET Core Razor 編程系列六——資料庫初始化

學習ASP.NET Core Razor 編程系列七——修改列表頁面

學習ASP.NET Core Razor 編程系列八——併發處理

學習ASP.NET Core Razor 編程系列九——增加查詢功能

 學習ASP.NET Core Razor 編程系列十——添加新欄位

學習ASP.NET Core Razor 編程系列十一——把新欄位更新到資料庫

學習ASP.NET Core Razor 編程系列十二——在頁面中增加校驗

學習ASP.NET Core Razor 編程系列十三——文件上傳功能(一)

學習ASP.NET Core Razor 編程系列十四——文件上傳功能(二)

 

八、添加文件 Razor 頁面的鏈接

       我們通過前面的二篇文章的學習,已經實現了文件上傳的主要功能,這一篇文章我們來學習如何把上傳文件的功能頁面添加到首面上面,以及刪除功能的實現 。

  1. 在Visual Studio 2017中按F5運行書籍管理應用程式,在瀏覽器瀏覽,如下圖。但是沒有發現上傳頁面的菜單。

 

        2.在Visual Studio 2017中打開“_Layout.cshtml”,然後嚮導航欄添加一個鏈接以訪問文件上傳頁面,如下圖:

 

        3.在Visual Studio 2017中按F5運行書籍管理應用程式,在瀏覽器瀏覽,如下圖。此時你會發現上傳頁面的菜單。

 

 

九、添加文件刪除確認頁面

      1.  為了更好的用戶體驗,當用戶單擊刪除上傳文件時,要提供一個刪除確認的操作。 在Visual Studio 2017的解決方案資源管理器中找到“Descri”文件夾,並添加刪除確認頁面 (Delete.cshtml),html代碼如下:

@page "{id:int}"
@model RazorMvcBooks.Pages.Descri.DeleteModel
@{
    ViewData["Title"] = "刪除上傳文件";
}

<h2>刪除上傳文件</h2>
<h3>你是否確認要刪除此文件?</h3>
<div>
    <h4>上傳文件</h4>
    <hr />
    <dl class="dl-horizontal">
        <dt>
            @Html.DisplayNameFor(model => model.Describe.Name)

        </dt>
        <dd>
            @Html.DisplayFor(model => model.Describe.Name)

        </dd>
        <dt>
            @Html.DisplayNameFor(model => model.Describe.PublicScheduleSize)

        </dt>
        <dd>
            @Html.DisplayFor(model => model.Describe.PublicScheduleSize)

        </dd>
        <dt>
            @Html.DisplayNameFor(model => model.Describe.PrivateScheduleSize)

        </dt>
        <dd>
            @Html.DisplayFor(model => model.Describe.PrivateScheduleSize)

        </dd>
        <dt>
            @Html.DisplayNameFor(model => model.Describe.UploadDateTime)

        </dt>
        <dd>
            @Html.DisplayFor(model => model.Describe.UploadDateTime)

        </dd>
    </dl>

    <form method="post">
        <input type="hidden" asp-for="Describe.ID" />
        <input type="submit" value="Delete" class="btn btn-default" /> |
        <a asp-page="./Index">Back to List</a>
    </form>
</div>

        2. 在Visual Studio 2017的解決方案資源管理器中,打開Delete.cshtml.cs文件,修改Delete.cshtml.cs中的代碼如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.RazorPages;
using RazorMvcBooks.Models;
using Microsoft.EntityFrameworkCore; 

namespace RazorMvcBooks.Pages.Descri
{
    public class DeleteModel : PageModel
    { 

        private readonly RazorMvcBooks.Models.BookContext _context;
 
        public DeleteModel(RazorMvcBooks.Models.BookContext context)

        {
            _context = context;
        }


        [BindProperty]
        public Describe Describe { get; set; }

        public async Task<IActionResult> OnGetAsync(int? id)
        {
            if (id == null)
            {
                return NotFound();

            } 

            Describe = await _context.Describe.SingleOrDefaultAsync(m => m.ID == id); 

            if (Describe == null)
            {
                return NotFound();

            }
            return Page();
        } 

// OnPostAsync 方法按 id 處理計劃刪除:
        public async Task<IActionResult> OnPostAsync(int? id)
        {
            if (id == null)
            {
                return NotFound();
            }
            Describe = await _context.Describe.FindAsync(id); 

            if (Describe != null)
            {
                _context.Describe.Remove(Describe);

                await _context.SaveChangesAsync();

            } 
            return RedirectToPage("./Index");
        }

    }
}

 

      3. 在Visual Studio 2017中按F5運行書籍管理應用程式,然後在瀏覽器中點擊“上傳文件”菜單,瀏覽上傳文件頁面,並上傳文件。如下圖。

 

     4.  在已上傳文件列表中,點擊要刪除的上傳文件記錄,按下圖操作。用戶可單擊該表中的“刪除”鏈接以訪問刪除確認視圖,併在其中選擇確認或取消刪除操作。

 

     5.  成功刪除上傳文件後,RedirectToPage 將返回到計劃的上傳文件(“Index.cshtml”)頁面。如下圖。

 

十、上傳文件頁面的說明

     按初始載入所示計劃 Razor 頁面,其中不含驗證錯誤和空欄位

     在不填充任何欄位的情況下選擇“上傳”按鈕會違反此模型上的 [Required] 特性。 ModelState 無效。 會向用戶顯示驗證錯誤消息:

 

      驗證錯誤消息顯示在每個輸入控制項旁邊

 

      在“文件名”欄位中鍵入兩個字母。 校驗提示信息會提示文件名長度必須介於 3-60 個字元之間:

 

      文件名文本框中輸入“image1”,則校驗信息自動會消失,如下圖。

 

      上傳一個或多個文本文件時,“已上傳文件列表”部分會顯示已經上傳的文件信息,顯示每個上傳文件的文件名稱、UTC 格式的上傳時間、公共描述文件的大小和後臺描述文件的大小。如下圖。

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  •  Asp.Net Core Web Api圖片上傳及MongoDB存儲實例教程(一) 圖片或者文件上傳相信大家在開發中應該都會用到吧,有的時候還要對圖片生成縮略圖。那麼如何在Asp.Net Core Web Api實現圖片上傳存儲以及生成縮略圖呢?今天我就使用MongoDB作為圖片存儲,然後使用S ...
  • 吃飯/訓覺-工作室尊重並保護所有使用其應用的用戶的個人隱私權。為了給您提供更準確、更有個性化的服務,吃飯/訓覺-工作室會按照本隱私權政策的規定使用和披露您的個人信息。但吃飯/訓覺-工作室將以高度的勤勉、審慎義務對待這些信息。除本隱私權政策另有規定外,在未徵得您事先許可的情況下,吃飯/訓覺-工作室不會 ...
  • 介紹 不管是新手還是工作幾年的老油條,對try{}catch{}來說是不陌生的。他可以來幫助我們獲取異常信息,在try中的代碼出現錯誤,火災catch代碼塊中被捕獲到。官方也給了詳細的解釋:。 拋出異常時,公共語言運行庫(CLR)會查找catch處理此異常的語句。如果當前正在執行的方法不包含這樣的c ...
  • 步驟:以VS2015為例, 第一步,右鍵解決方案後 點擊【管理解決方案的NuGet程式包(N)...】,找到【log4net】下載安裝,如下圖: 第二步:安裝完成後,在AssemblyInfo.cs代碼中 加入以下代碼: 如下圖: 第三步:新建log4net.config,內容如下: 第四步:新建公 ...
  • 在開發者界面用可以看到很多ptqrlogin開頭的 name 我要做的就是 模擬瀏覽器的操作,把它轉換成我們自己的客戶端。所以只要是瀏覽器里有的我們都要模擬。接下來判斷二維碼失效,兩秒一次吧,弄一個Timer smart 類 #region 第二講檢查二維碼狀態 private static Sys ...
  • 正則表達式平時不常用,經常都是用的時候,臨時抱佛腳,查文檔,然後就是被各種坑之後,才會逐漸熟練。 線上正則表達式測試:http://tool.oschina.net/regex/ 線上JSON格式化:https://www.bejson.com/ 正則表達式手冊:http://tool.oschin ...
  • 開發工具:Visual Studio 2017 15.7.5 開發平臺:Windows 10 新建WebApi項目,Web.config配置文件中,system.web下級節點中預設沒有customErrors的配置,即customErrors預設是RemoteOnly `` mode 必選的屬性。 ...
  • XSS攻擊全稱跨站腳本攻擊,是為不和層疊樣式表(Cascading Style Sheets, CSS)的縮寫混淆,故將跨站腳本攻擊縮寫為XSS,XSS是一種在web應用中的電腦安全漏洞,它允許惡意web用戶將代碼植入到提供給其它用戶使用的頁面中。 比如我們在表單提交的時候插入腳本代碼 如果不進行 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...