用asp.net core 2.0 + EFCore.Sqlite做個小網站

来源:http://www.cnblogs.com/pasoraku/archive/2017/10/13/7661861.html
-Advertisement-
Play Games

許久沒用C#寫程式。聽說進來發生大事,.NetCore2.0發佈了,於是便學習了下,本站也應運而生。 大多數的地方按照官方的文檔起步走就可以了,這裡談談遇到的幾個坑。 首先,本站是基於ASP.NetCore2.0和EntityFrameWorkCore.Sqlite的,前端使用了layui,搭建於C ...


許久沒用C#寫程式。聽說進來發生大事,.NetCore2.0發佈了,於是便學習了下,本站也應運而生。

大多數的地方按照官方的文檔起步走就可以了,這裡談談遇到的幾個坑。

首先,本站是基於ASP.NetCore2.0和EntityFrameWorkCore.Sqlite的,前端使用了layui,搭建於CentOS7上。

ASP.NetCore部分沒有什麼難度,選擇MVC方式,基本上和原來的asp.net mvc差不多。不過我也是很久沒有用過mvc了,所以摸索了一下,tagHelper很好用。

主要說說EFC,目前是EFC2.0,不支持延遲查詢,所以每一個表關聯查詢需要Include()。然後表關聯上也不能用多對多,不過多對多的地方可以加中間類來解決。

比如一篇文章有多個分類,而一個分類也有多篇文章。這裡用到了多對多的關聯,所以我增加了一個中間關聯的類型,包含文章和分類的ID。用兩個一對多的關聯,規避了多對多的關聯。

EF還有一個控制台命令 dotnet ef

使.NetCore2.0網站項目支持EF.Sqlite

1)添加appsettings.json,並配置sqlite的連接字元串

"sqlitedb": "Filename=./sqlitedb.db"

註意appsettings.json添加完之後設置屬性為複製到輸出目錄

2)在Startup中啟用服務

添加引用:

using Microsoft.Extensions.Configuration;

using Microsoft.EntityFrameworkCore;

添加屬性:

public IConfiguration Configuration { get; set; }

添加構造:

       public Startup()

        {

            var builder = new ConfigurationBuilder()

               .AddJsonFile("appsettings.json");

            Configuration = builder.Build();

        }

在ConfigureServices()啟用:

var connection = Configuration.GetConnectionString("sqlitedb");

services.AddDbContextPool<DataContext>(options => options.UseSqlite(connection));

此時缺少DataContext類,新建之在Data文件夾下

支持Identity

1)編輯DataContext

添加引用:

using Microsoft.AspNetCore.Identity.EntityFrameworkCore;

using Microsoft.EntityFrameworkCore;

繼承IdentityDbContext<User>

添加非預設構造函數:

       public DataContext(DbContextOptions<DataContext> options)

            : base(options)

        {

        }

2)此時缺少User類,新建之在Model文件夾下,並繼承自IdentityUser

在User類中添加引用:

using Microsoft.AspNetCore.Identity;

3)在Startup類中

ConfigureServices()里啟動服務:

    services.AddMvc();

    services.AddIdentity<User, IdentityRole>().AddEntityFrameworkStores<DataContext>().AddDefaultTokenProviders();

在Pipeline的Configure()函數中進行身份驗證:

app.UseAuthentication();

此後可以在Controller里使用[Authorize]標簽驗證登錄身份了

使用EF工具生成資料庫結構

1)右鍵編輯項目文件csproj

在ItemGroup中添加

<DotNetCliToolReference Include="Microsoft.EntityFrameworkCore.Tools.DotNet" Version="2.0.0" />

2)打開項目所在目錄,按住shift後右鍵呼出菜單打開命令行

在命令行中輸入:

dotnet ef migrations add InitialCreate

名稱可替換

如果遇到錯誤,請分析錯誤原因

之後會在項目下生成一個Migrations文件包含了資料庫結構相關代碼

輸入下麵命令並回車,使之生效:

dotnet ef database update

然後就會出現appsettings.json中配置的資料庫文件.


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

-Advertisement-
Play Games
更多相關文章
  • 學習Linux的時候,最先學習的幾個命令中有一個就是clear,中文翻譯為:清屏。 以前的理解都是按照字面進行解讀的,清除屏幕上多餘的內容。 但是實際上真的如此麽? 原來屏幕是: 運行clear命令: 屏幕已經乾凈了。 不過嘗試滑鼠上翻,發現竟然有上一屏,而且有之前輸出的內容。 由此可見,clear ...
  • 1. ...
  • 今天學習的是關於EF數據模型的,但在學習並實際操作之前,我又將前兩章的內容看了一遍,把登錄界面和註冊界面都完成了,覺得自己在代碼這方面有點欠缺,改錯的能力有點弱!那下邊就總結一下我學習EF之後的感受吧! 第一步,先新建文件夾,規劃好代碼存放位置 1.根目錄下新建ViewModels文件夾, (因為m ...
  • http://www.cnblogs.com/hy13211114/p/6193593.html 軟體工程之結構化方法與面向對象方法之比較與結合 軟體開發方法指,在項目投資規模和時間限制內,設計、實現符合用戶需求的高質量軟體,根據軟體開發的特點,提出的多種軟體開發的策略。隨著20世紀60年代,電腦 ...
  • 回到目錄 古人雲《一山不容二虎》,而進行dotnet core時代之後,我們可以看到這樣的一些官方的DEMO,它將數據連接串和其它配置項都直接硬編碼在代碼里,即在startup中進行定義,試問你在生產環境如何相容!當然,你會說,可以在對應appsettings里進行配置,說它是對應的appsetti ...
  • 假設有段代碼是這樣的,需要判斷角色裝備哪些武器,然後根據角色的這個屬性來進行其它的一些操作。這時候我們可以用枚舉來標記角色可以裝備的武器。 這就有個問題了,當角色可以裝備多種武器的時候,難道要用多個變數去表示他可以使用的武器嗎?又或者是在Equipment類型中加入新的成員,刀和箭,刀和箭和弓... ...
  • 前言:審批流程中常見的都是人工類型任務,但是也會有一些自動化的任務需要定時觸發。因此,引擎框架中需要解決掉兩個問題:選擇合適的任務調度框架,集成新的任務調度模塊。 1. 任務調度框架選擇 Hangfire 是一個開源的.NET任務調度框架,目前1.6+版本已支持.NET Core。 基於隊列的任務處 ...
  • is和as is關鍵字可以確定對象實例或表達式結果是否可轉換為指定類型。基本語法: 如果滿足以下條件,則 is 語句為 true: expr 是與 type 具有相同類型的一個實例。 expr 是派生自 type 的類型的一個實例。 換言之,expr 結果可以向上轉換為 type 的一個實例。 ex ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...