.netcore 定製化開發的思考和實現

来源:https://www.cnblogs.com/wangpengzong/archive/2020/05/06/12833014.html
-Advertisement-
Play Games

今年年初進了一家新公司,進入之後一邊維護老項目一邊瞭解項目流程,為了接下來的項目重做積累點經驗。 先說下老項目吧,.net fx 3.5+oracle...... 在實際維護中逐漸發現,老項目有標準版、定製版兩種,標準版就是一套代碼,粗略計算了下,全部版本加起來有20+個版本,如果項目重做後還是依照 ...


今年年初進了一家新公司,進入之後一邊維護老項目一邊瞭解項目流程,為了接下來的項目重做積累點經驗。

先說下老項目吧,.net fx 3.5+oracle......

在實際維護中逐漸發現,老項目有標準版、定製版兩種,標準版就是一套代碼,粗略計算了下,全部版本加起來有20+個版本,如果項目重做後還是依照這個模式去開發維護,估計距離猝死也不遠了,並且不同版本代碼的復用率極低(好吧,根本沒有)。打個比方,我在標準版中發現了一個bug,需要去其他的20+版本裡面都修改一遍,刪庫跑路瞭解一下。。。。

為了提升工資(偷懶),進公司沒多久就在想辦法,如何去提高不同項目的代碼復用率,然後想起來了wtm、abp、simplcommerce這三種項目,似乎有不同項目中代碼服用的地方。

wtm、abp類似,是將底層的部分controller、view封裝在底層類庫,然後項目最外層去使用;

simplcommerce是將所有的模塊放在各個類庫中,然後在主項目中集成;

(或許是我看的不夠深入,歡迎指正)

這三種項目,對於我的不同項目提交代碼復用率來說,不能直接起到作用,但是卻提供了一種思路,我們可以將原始的標準版作為一個類庫,然後在不同的項目中引用這個類庫,做到絕大部分的代碼復用,少部分修改

那我們開始新建一個簡化版的項目,大概的分組可以做這樣

native/default作為標準版的web類庫,entity是實體、service是服務,實體和服務我們暫且不說,先說明下default這個類庫,這個類庫就是上面所說的標準類庫,讓其他的Tailor.Custom1、Tailor.Custom1.Https、Tailor.Custom2.Https、Tailor.Custom3.Https(以下稱定製項目)去引用,然後再各自的項目中可以個性化修改

default類庫的csproj文件做適當的修改

<Project Sdk="Microsoft.NET.Sdk.Web">

  <PropertyGroup Label="Globals">
    <SccProjectName>SAK</SccProjectName>
    <SccProvider>SAK</SccProvider>
    <SccAuxPath>SAK</SccAuxPath>
    <SccLocalPath>SAK</SccLocalPath>
  </PropertyGroup>

  <PropertyGroup>
    <TargetFramework>netcoreapp3.1</TargetFramework>
    <OutputType>Library</OutputType>
  </PropertyGroup>
  ...
</Project>

借鑒wtm中使用項目對web類庫的引用,定製項目主要引用是通過Startup=>ConfigureServices=>AddFrameworkService和Startup=>ConfigureServices=>UseFrameworkService將標準版default中的controller和view添加到我們的定製項目中,我們就可以進行使用了。

想到這個,我們大概可以在定製項目中調用所有的標準版功能了。

 

但是我們如果想在定製項目中對標準版某個controller的某個action進行修改該怎麼辦?

1.我首先想到的是在個性化項目中寫一個同名的controller,然後這個controller繼承自預設版本的對應controller,來達到重寫的目的,但是這個慣性思維陷入誤區了,mvc對於controller的控制不和普通的type繼承一樣,如果同名controller存在,則會報錯。。。在運行時我們可以判斷出是哪個action不同,但是無法通過emit來進行修改,所以這種辦法不可以。

2.第一種辦法不行,那麼我們是否可以對於同名controller進行名稱上的修改,比如homecontroller在Tailor.Custom1中修改未TailorCustom1homecontroller,然後利用路由進行重定向?結果發現路由重定向,要麼自定義一個路由中間件(求大佬給解決辦法,我不會。。),要麼在請求進入的時候對請求進行重定向(這種重定向就是對HttpContext.Request.Path進行特殊判斷和處理,符合條件的進行重定向,但是可能會有很大的問題)

3.使用版本控制的思路,這個似乎可以,我們將標準版default中所有的都作為版本1.0,然後定製化作為2.0,在請求進入的時候,將請求頭添加一個version,如果mvc找不到這個version的controller或者action,會自動轉到預設的1.0版本中

 

具體實現代碼地址:https://github.com/wangpengzong/Tailor

Native/Default是標準版網站類庫

Tailor.Custom* 是定製化網站,可以在此路徑下繼承Native/Default的對應Controller,利用overvide對需要重寫的action進行重寫,不需要重寫的不進行overvide即可,或者對cshtml進行重寫,不需要重寫的不在對應路徑下增加cshtml文件即可

 


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

-Advertisement-
Play Games
更多相關文章
  • 一:背景 1. 講故事 我們有一家top級的淘品牌店鋪,為了後續的加速計算,在程式啟動的時候灌入她家的核心數據到記憶體中,灌入完成後記憶體高達100G,雖然雲上的機器記憶體有256G,然被這麼劃掉一半看著還是有一點心疼的,可憐那些被擠壓的小啰啰程式
  • 網上很多寫使用WindowsMediaPlayer WMP控制項的文章. 大多數都是從工具欄或COM導入. 最近正在做的CEF整合Asp.Net Core Blazor server side的過程中, 因為CEF編譯支持mp4的dll是涉及了版權的問題, 不能隨便乾的. 要播放mp4, 可以用Win ...
  • 以前一直想著有沒有一個方法能夠把字元串直接轉化成函數的,剛好有需求就找了下,還真有。 微軟地址:https://docs.microsoft.com/en-us/previous-versions/bb894665(v=msdn.10)?redirectedfrom=MSDN 一、安裝 NuGet程 ...
  • 綜述 .NET CORE 3.0開始,桌面端支持WPF了。很多.NET FRAMEWORK的項目已經跑了一陣子了,不是很有必要支持.NET CORE,不過最近用一個程式,為了貫徹一些C 8的特性,需要升級項目到.NET CORE 3.1。 方法 參考 "官方指導" ,需要這麼幾步: 1. 瞭解並更新 ...
  • vue+element部署 一.環境準備 1.因為Nginx依賴於gcc的編譯環境,所以,需要安裝編譯環境來使Nginx能夠編譯起來。 命令:yum install gcc-c++ 2.Nginx的http模塊需要使用pcre來解析正則表達式,需要安裝pcre。 命令:yum install -y ...
  • EFCore數據操作 ...
  • 0. 前言 這是C 基礎知識系列的最後一個內容講解篇,下一篇是基礎知識 實戰篇。這一篇主要講解一下C 程式的結構和主要編程工具。 1. 工具 工欲善其事必先利其器,在實際動手之前我們先來看看想要編寫一套C 程式需要做哪些準備吧。 1.1 選擇 C 的sdk在之前的某個時間點分為了三個方向: 1. . ...
  • 關於數據類型 c#的類型一般分為值類型和引用類型兩種, 值類型的變數包含類型的實例,值類型存放棧中 引用類型的變數包含對類型實例的引用,引用類型放在堆中,在棧中設置一個指針指向堆 值類型: 1.整數型數值:所有的整型數值類型均為值類型,可以用文本進行初始化,每個整型類型的預設值都是0,c#支持以下預 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...