我的第一個netcore2.2 api項目搭建(一)

来源:https://www.cnblogs.com/sy-ds/archive/2019/05/08/10832504.html
-Advertisement-
Play Games

早早就想入門netcore,一直沒下定決心,這次正好碰上項目服務變更,便想著入坑試試,邊學邊用。 目標: 一.api使用core版的SqlSugar,集成orm,實現快速開發 二.api使用Swagger,實現api文檔管理 三.api添加身份驗證功能 開發環境: Win10、VS2017、orac ...


早早就想入門netcore,一直沒下定決心,這次正好碰上項目服務變更,便想著入坑試試,邊學邊用。

目標:

一.api使用core版的SqlSugar,集成orm,實現快速開發

二.api使用Swagger,實現api文檔管理

三.api添加身份驗證功能

 

開發環境:

Win10、VS2017、oracle11g

一.api使用core版的SqlSugar,集成orm,實現快速開

1.1一步一步來,很簡單

F5運行

初步搭建完成。

 

1.2添加SqlSugar項目

下載地址:https://github.com/sunkaixuan/SqlSugar

下載後解壓,將Asp.NetCore2里的SqlSugar文件夾拷貝到api項目根目錄下,解決方案添加SqlSugar項目。

 

1.3添加其他項目

 總體依賴關係:

JH.OPEMR.DBUtility:SqlSugar、JH.OPEMR.Model       實現db實例化,供業務層調用

JH.OPEMR.BLL:JH.OPEMR.DBUtility、JH.OPEMR.Model、JH.OPEMR.Common     業務層,供視圖 或 api層調用

JH.OPEMR.API:JH.OPEMR.BLL、JH.OPEMR.Model、JH.OPEMR.Common  

 

JH.OPEMR.DBUtility層:

該層主要提供db上下文,給業務層調用,使用官方提供的上下文即可

 

全部代碼:

using SqlSugar;
using System;
using System.Collections.Generic;
using System.Text;

namespace JH.OPEMR.DBUtility
{
    public class DbContext<T> where T : class, new()
    {
        public DbContext()
        {
            Db = new SqlSugarClient(new ConnectionConfig()
            {
                ConnectionString = "Data Source=192.168.11.43/xxx;User ID=xx;Password=xx;",
                DbType = DbType.Oracle,
                InitKeyType = InitKeyType.Attribute,//從特性讀取主鍵和自增列信息
                IsAutoCloseConnection = true,//開啟自動釋放模式和EF原理一樣我就不多解釋了

            });
            //調式代碼 用來列印SQL 
            Db.Aop.OnLogExecuting = (sql, pars) =>
            {
                //Console.WriteLine(sql + "\r\n" +
                //    Db.Utilities.SerializeObject(pars.ToDictionary(it => it.ParameterName, it => it.Value)));
                Console.WriteLine();
            };
        }
        //註意:不能寫成靜態的
        public SqlSugarClient Db;//用來處理事務多表查詢和複雜的操作
        public SimpleClient<Model.USERS> StudentDb { get { return new SimpleClient<Model.USERS>(Db); } }//
        public SimpleClient<T> CurrentDb { get { return new SimpleClient<T>(Db); } }//用來處理T表的常用操作

        /// <summary>
        /// 獲取所有
        /// </summary>
        /// <returns></returns>
        public virtual List<T> GetList()
        {
            return CurrentDb.GetList();
        }

        /// <summary>
        /// 根據主鍵刪除
        /// </summary>
        /// <param name="id"></param>
        /// <returns></returns>
        public virtual bool Delete(dynamic id)
        {
            return CurrentDb.Delete(id);
        }


        /// <summary>
        /// 更新
        /// </summary>
        /// <param name="id"></param>
        /// <returns></returns>
        public virtual bool Update(T obj)
        {
            return CurrentDb.Update(obj);
        }

    }
}
View Code

 

JH.OPEMR.BLL層:

新建了BaseBLL類,該類繼承上下文,可自行擴展方法,現在什麼方法都沒,只是為了提供給其他業務層調用,或者api直接調用,然後其他業務類可以繼承該類,其他業務類就統一歸基類管制了

User表的業務層:

 ok,到這裡,db層和業務層基本搭建完成,在api層測試下看看:

將原有的values根據id獲取的方法改造下,F5運行,結果如下:

至此,第一個目標完成!!

 

 

 

 

 


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

-Advertisement-
Play Games
更多相關文章
  • 最近每天在用VS2017,但是每次打開它都會彈出最近項目的記錄,很是煩人。 最主要是我不想別人得知我最近的項目和項目進度,每次加密項目會比較麻煩。 所以經過簡單的研究,編寫了這個小工具,打開直接單擊就可以清楚最近項目的記錄。 算是一種隱私安全小工具吧! 有問題或者任何建議,歡迎騷擾!工具會持續更新優 ...
  • 跨域資源共用(CORS) 是一種機制,它使用額外的 HTTP 頭來告訴瀏覽器 讓運行在一個 origin (domain) 上的Web應用被准許訪問來自不同源伺服器上的指定的資源。當一個資源從與該資源本身所在的伺服器不同的域、協議或埠請求一個資源時,資源會發起一個跨域 HTTP 請求。 什麼情況下 ...
  • 一、C#獲取當前路徑的方法: 1. System.Diagnostics.Process.GetCurrentProcess().MainModule.FileName -獲取模塊的完整路徑。 2. System.Environment.CurrentDirectory -獲取和設置當前目錄(該進程 ...
  • 上一章快速添加了swagger文檔管理功能,我的第一個netcore2.2 api項目搭建(二) 這一章實現目標二:api添加身份驗證功能 在實現該目標之前,先得理解netcore運行機制。 這是微軟提供的圖,從圖上可以看出,一個請求發出,逐個通過middleware,然後做出響應。這裡的middl ...
  • 簡介 醫學領域專用工具,千金難求,可以批量把jpg、png、bmp、tif圖片轉換為dicom(dcm)格式,並且保持原有順序,同時支持嵌入部分重要的dicom元數據,比如:病人姓名,病人生日等。 將需要轉換的圖片全部放入同一個文件夾中,如果文件排序不是預設的按名稱排序,那麼需要設置成按名稱,因為這 ...
  • 上一章快速使用SqlSugar搭建了netcore api項目,我的第一個netcore2.2 api項目搭建(一) 這一章實現目標二:api使用Swagger,實現api文檔管理 效果圖:第一張收縮,第二張展開,共有2個控制器:values和Account;控制器有註釋,api有註釋,實體有註釋 ...
  • 遷移的時候發現,ef6 不能添加 到 .NET Standard2 的類庫,因為不相容, 6 以上的版本只能用於 .net 4.5 以上 只能用別的 ...
  • 可以做冪運算,根號運算,十進位與二進位互轉,16進位與十進位互轉 namespace WindowsFormsApplication15{ public partial class 祥哥計算器 : Form { public 祥哥計算器() { InitializeComponent(); } #r ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...