ASP.NET Core MVC的基礎學習筆記

来源:https://www.cnblogs.com/yxx24/archive/2020/02/19/12329461.html
-Advertisement-
Play Games

最近由於“武漢肺炎”疫情在家辦公,也沒閑著,最近學習了一下asp.net core mvc的一些網頁開發的的基礎知識,話不多說直接上教程! 一、創建Web應用程式 1)創建新項目 >找到 “ASP.NET Core Web 應用程式” 類型的項目(也可以模糊查詢:語言選擇c#,項目類型選擇Web): ...


最近由於“武漢肺炎”疫情在家辦公,也沒閑著,最近學習了一下asp.net core mvc的一些網頁開發的的基礎知識,話不多說直接上教程!

 

一、創建Web應用程式

1)創建新項目--->找到 “ASP.NET Core Web 應用程式” 類型的項目(也可以模糊查詢:語言選擇c#,項目類型選擇Web):

 

 

2)選擇Web 應用程式 (模型視圖控制器)--->修改名稱--->創建:

 

 

3)新建完成後,解決方案出現如圖顯示

 

wwwroot 存放網站的 js、css 等前端文件,

Models-模型:封裝業務邏輯相關的數據及對數據的處理方法【如圖黃框框選中】;

Views-視圖: 向用戶提供交互界面【如圖藍框框選中】;

Controllers-控制器: 負責控制Model和View【如圖紅框選中】;

appsettings.json-配置文件: 如可以在其中加入資料庫連接字元串,如圖:

 

 

 

二、創建實體模型

1)添加一個實體類 (選中Models--->右鍵 --->添加--->類--->修改名稱--->創建 )

並給欄位添加一些特性如下圖: 

   /// <summary>
    /// 用戶表
    /// </summary>
    public class InfoUser
    {
        [Key]//主鍵 非已ID命名的主鍵必須添加
        [StringLength(10)]
        [DisplayName("用戶名")]//顯示名稱
        [Required(ErrorMessage = "酒店名稱不能為空")]//屬性 表示該欄位不能為空
        public string UserName { get; set; }
        [StringLength(16)]
        [DisplayName("密碼")]
        [Required(ErrorMessage = "密碼不能為空")]
        public string Password { get; set; }
        [DisplayName("創建日期")]
        public DateTime DTCreate { get; set; }
        [DisplayName("登錄日期")]
        public DateTime DTLogin { get; set; } 
        public byte[] HeaderImg { get; set; }

}

 

2)再添加一個實體框架類【資料庫上下文類】(同樣在Models文件夾下創建,命名我這推薦以Db+name,如DbWwp;) 

創建後再繼承DbContext

/// <summary>
/// 實體框架 EntityFrameworkCore
/// </summary>
namespace EasyBlog.Models
{
    public class DbWwp : DbContext
    {
        public DbWwp(DbContextOptions<DbWwp> options)
         : base(options)
        {

 
        }
        public DbSet<InfoUser> InfoUsers { get; set; }
        public DbSet<InfoBlog> InfoBlogs { get; set; }
        public DbSet<InfoLog> InfoLogs { get; set; }
        public DbSet<InfoReply> InfoReplys { get; set; }
    }
}

 

3)首先添加兩個包:Microsoft.EntityFrameworkCore.sqlserver 和Microsoft.EntityFrameworkCore.Tools

步驟:

右鍵依賴項-->管理NuGet程式包--->瀏覽--->搜索包名--->選擇需要的包下載並安裝

 

 

4)在 Startup類中的 ConfigureServices 方法中註冊資料庫上下文

services.AddDbContext<DbWwp>(options => options.UseSqlServer(Configuration.GetConnectionString("DbWwp")));

 

5)現在我們打開” 程式包管理器控制台”(工具-->NuGet 包管理器-->程式包管理器控制台),寫入命令 “add-migration init” 如下圖,添加新的資料庫” 遷移”(init--是遷移的名稱)。

 

不要介意add-migration 後面的名字與上圖不符哈, 出來這個黃色的後成功一半咯~

  

Update-Database 然後回車

 

 這時候在上下文中就會出現一個叫做當前創建日期 加上你之前add 後面創建名字的一個記錄了添加的” 遷移” 都保存在 Migrations 目錄下:

 

 

三、新增MVC和EF框架

 

1)接下來我們開始創建一套完整的MVC及增刪改查,所以我們選擇 “視圖使用 Entity Framework 的 MVC 控制器”(步驟:Controllers文件夾右鍵 -->添加-->雙擊控制器-->視圖使用 Entity Framework 的 MVC 控制器):

 

 

2)接下來下拉選擇好模型類(如上面創建的模型類InfoUsers)、下拉選中自己創建的數據上下文類(如上面創建的資料庫上下文類),勾上” 生成視圖”,點擊” 添加” 即可,同時你也可以自己命名,但控制器名稱必須以Controller結尾(這是ASP.NET Core MVC的一個約定),這裡我們預設命名InfoUsersController

 

創建完後系統自動幫我們生成了控制器(如圖下InfoUsersController)和自動在Views 文件夾下生成 InfoUsers文件夾的增刪改查等五個的視圖(如圖下的Create-增,Delete-刪,Details-查,Edit-改,Index-主頁):

 

當然你也可以自己創建View視圖,不過添加View視圖有兩種方法,一種是直接在Views文件夾下添加(右鍵Views文件夾下的InfoUsers文件夾-->添加-->視圖);另外一種是通過Controller中的Action來添加,打開控制器里(如InfoUsersController), 在”return View ();” 的地方右鍵-->添加視圖方法。不過我推薦大家採用後一種方法。

 

3)採用前面兩種方法後會進入如下圖添加視圖確認視窗,點添加就行

 

 

4)這樣再添加了一個和特定的Controller和InfoUsers(這裡指InfoUsersController和Login)相對應的View(Login.cshtml)並補充代碼如下

 Login.cshtml

@{
    ViewData["Title"] = "登錄";
}

<h4>@ViewData["Title"]</h4>
<hr />
<div class="row">
    <div class="col-md-4">
        <form asp-action="Login">
            <div class="form-group">
                <label class="control-label">用戶名</label>
                <input name="UserName" id="UserName" class="form-control" />
            </div>
            <div class="form-group">
                <label class="control-label">密碼</label>
                <input name="Password" id="Password" type="password" class="form-control" />
            </div>
            <div class="form-group">
                <input type="submit" value="登錄" class="btn btn-primary" />
                <small>@ViewBag.Msg</small>
            </div>
        </form>
    </div>
</div>

 

InfoUsersController.cs

public IActionResult Login()
        {
            return View();
        }

        [HttpPost]
        [ActionName("Login")]
        public async Task<ActionResult> Logining()
        {
            var userName = Request.Form["UserName"];
            var password = Request.Form["Password"];
            var item = db.InfoUsers.Find(userName);

            if (item != null && password == item.Password)
            {

                item.DTLogin = DateTime.Now;
                db.SaveChanges();


                var claims = new List<Claim>();

                claims.Add(new Claim(ClaimTypes.Name, userName));

                var claimsIdentity = new ClaimsIdentity(claims, "Cookies");
                await HttpContext.SignInAsync(new ClaimsPrincipal(claimsIdentity));
                return RedirectToAction("Index", "Blog");
            }
            else
                ViewBag.Msg = "登陸失敗";
            return View();
        }

 

  

5)最後運行程式(單擊IIS Express如圖或按F5),啟動後在瀏覽器地址中後面接上/InfoUsers/Login(瀏覽器中的地址 xx/InfoUsers/Login與開頭的路由規則url:"{controller}/{action}/{id}"對應起來)後按回車Enter。

當可以看到這界面時,說明成功了。

最後,請大家戴口罩,勤洗手,少去人群聚集處。保護好自己不給祖國添麻煩!!!武漢加油!中國加油!!!


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

-Advertisement-
Play Games
更多相關文章
  • 由於疫情的原因,所以目前一直在家遠程辦公,所以很多時間在刷面試題,發現2019大廠的面試雖然種類很多,但是總結了一下發現主要是這幾點:演算法和數據結構、 JVM、集合、多線程、資料庫這幾點在面試的時候比較多。今天總結了幾個JVM比較問的多的問題和答案希望可以幫到大家。 1、首先就是JVM垃圾回收機制和 ...
  • 打開python官網https://www.python.org/,然後點擊頁面的downloads導航菜單。在下拉的菜單中選中windows, 直接點擊頁面右側的 python 3.X(X表示對應的版本號),可以下載最新的python安裝包。安裝完畢以後,在命令行中執行python -V來測試是... ...
  • 把x用八進位,十進位、十六進位的形式列印,把y用布爾值的形式列印:int x = 10;cout << oct << x << endl; //show octalcout << dec << x << endl; //show decimalcout << hex << x << endl; //... ...
  • 樹結構基礎 LCA c++ ……(省略,同LCA) int L[N], R[N];//每個子樹代表的區間 int tot;//總時間 //搜索整棵樹, 得到每個節點的深度 void dfs(int u, int f){//u: 一節點 f: 其節點的父親節點 L[u] = ++tot; dep[u] ...
  • [toc] 一.Java的基本數據類型介紹 | 類型 | 關鍵字 | 位數 | 預設值 | 取值範圍 | | : : | : : | : : | : : | : : | | 位元組型 | byte | 8 | 0 | 128~127 | | 短整型 | short | 16 | 0 | 32768~3 ...
  • springboot預設打包成jar,如果想打包成war,則需要做以下三步。 1.修改pom.xml文件 a.將jar改成war 1 <groupId>com.test</groupId> 2 <artifactId>01-springboot-HelloWorld</artifactId> 3 < ...
  • 下載cron包: go get github.com/robfig/cron 開啟一個定時: 根據cron表達式進行時間調度,cron可以精確到秒,大部分表達式格式也是從秒開始。 c := cron.New()預設從分開始,所以加上cron.WithSeconds(),保證定時按照表達式字面意思執行 ...
  • 1.工具類可以一次寫入多方多方調用,很大程度的節約開發時間得到想要的信息 這裡演示一個json介面的工具類(文件定義在App\Http\Controllers\Tools)中 <?php /** * Created by PhpStorm. * User: yly * Date: 2020/2/18 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...