軟體快速開發平臺設計思路及實現方法(二)

来源:https://www.cnblogs.com/szzzzn/archive/2019/07/17/11200492.html
-Advertisement-
Play Games

接上篇內容描述談談平臺設計思路及方法。前一篇簡單的介紹了一下整體的實現思路。那從本節開始開始說明如何引入資料庫表視圖等,因為我們不管做什麼項目軟體,設計的時候能直接將頁面控制項綁定到指定的欄位,那樣後續的操作就會很方便。至於實現的方法,有很多種,每個人可能有各自不同的思路,我不去評價別人是怎麼做的,僅 ...


       接上篇內容描述談談平臺設計思路及方法。前一篇簡單的介紹了一下整體的實現思路。那從本節開始開始說明如何引入資料庫表視圖等,因為我們不管做什麼項目軟體,設計的時候能直接將頁面控制項綁定到指定的欄位,那樣後續的操作就會很方便。至於實現的方法,有很多種,每個人可能有各自不同的思路,我不去評價別人是怎麼做的,僅說說我自己的實現思路,因為這個思路在後續的實際使用中,經過很多大型項目的驗證,的確是可行的,但並不代表此實現的方式是最好、最完善的,肯定有很多不足之處,說實話,技術有限,不可能滿足實現所有人的想法。

     數據集合:引入此概念,目的是實現我們在資料庫中的表、視圖的映射,為什麼叫映射呢,因為它只是起到一個中轉作用,自身不實現什麼其他的功能。

     因為是設計開發工具,那麼使用者肯定包含不同層次的開發者,例如剛畢業的學生等等,一套軟體項目一般都是經過多個人員協同分工來實現的,那我們肯定要對這些分工做一個規則的制定,讓所有參與的人員都能明白前一步操作人員設計的意圖和含義,這樣就省去了很長時間的理解消化。

     表、視圖在資料庫中是可以直接建立完成,但是我想在頁面設計中使用,那麼肯定需要從資料庫中獲取表或視圖來綁定使用。一般來說我直接調用表、視圖不行嗎?不是也能實現這樣的功能嗎?答案是肯定的,可以那麼做,但是如果表是A員工做的,B員工設計頁面,他需要調用表,但是表結構的欄位直接查看是無法知道是什麼含義的,某個控制項的值應該保存到哪個欄位中,還有如果我們將表名直接暴露在WEB前端,那麼此風險繫數是不是很大呢?為瞭解決這樣的問題,可以提出一個新的概念,數據集合,這個數據集合與我們說的其他的數據集合不是一個含義,只是名字相同。

     實現目的: (先上幾張實現的圖片用於說明)

 

 

            1、將資料庫表或視圖直接建立一個映射,生成一個數據集合記錄,關聯上表名,一般希望數據集合中文描述標註為表名的中文含義,

                  同時對錶或視圖中的欄位也標註上中文,因為我們大部分人還是習慣看中文,這樣能一目瞭然。方便使用者查看。

            2、隔離真實的表名或視圖名,實現變相的替換,可以先解決前端WEB不允許直接操作表或視圖,降低安全風險,但這樣就犧牲了一點

                 點的性能,因為後臺進行與資料庫交互時,就需要根據配置名來獲取真實的表、視圖名,再來執行實際的操作,這樣就多了一步。為了

                 安全,我認為這點性能的犧牲是值得的。

                 唯一遺憾:我當初也想將欄位進行別名化,這樣進一步加強安全繫數,但是當初設計時很多同事說那樣建立數據源和後臺處理時就麻煩了,

                 每次需要中轉遍歷欄位對應才能處理,雖然以前沒這樣實現,我相信後續還會繼續補充上去。

             3、實現通過視圖來進行數據保存的功能。我們在開發ERP等項目時,經常會碰到 例如物料信息,在真實的出庫業務中,可能只保存物料編碼、

                 批次、計量單位編碼、數量等信息,但是在頁面顯示中還必須要顯示出物料名稱、規格型號等其他不保存的信息,為瞭解決這樣的問題,我

                 想可以通過數據集合的保存表名來進行處理,這樣不就即解決了顯示問題,又解決了保存問題。並且設計操作就便捷了。

             4、實現SQL(存儲過程等) 語句建立數據源(此功能當初設想了,但是到目前來說還沒有好的模式來實現,因為不單單建立數據源,還會關聯到

                  的Tree 、Grid 、Combobox 、List、輸入感應等後續根據數據集合取值問題,後續我相信肯定會有辦法來處理,這樣就能解決數據集合多樣

                  化建立的問題了)

             5、實現頁面數據增、刪、改、查等的中轉載體,所以的數據的通用的存儲,全部採用依據數據集合,這樣能從一個源頭來進行控制。

 

                     6、實現頁面設計中,頁面數據保存查詢許可權過濾條件設計的載體,例如:目錄樹、下拉選擇、輸入感應、數據列表等等,

                        因為既然是通過JS 來執行,那麼前端設置的條件可以通過JS來跟蹤到,但是我們可以在後端設計時,針對集合設置許可權條件

                        這樣WEB前端就永遠不會獲取到我設計端設計時候的許可權條件,那樣就有效的控制數據的橫向或縱向許可權。

                   7、快速定義列表中的查詢欄位,這樣便於設計人員針對不同的列表,只要勾選一下,就可以快速增加了

                        此欄位的組合查詢。

 

                     通過以上幾個要點的描述,那麼我們就將數據集合需要實現的功能描述出來了,下麵就是我們自己通過掌握技術,來分別實現。

                    只要實現的方法其實很簡單,我們是通過C/S來實現的,那麼就建立一個數據集合設計頁面,通過同步功能將欄位顯示出來,分別

                    填寫上對應的中文標題,執行保存。

                           我建議每個集合保存後,如果要讓WEB頁面調用時候,請將信息發佈保存為JSON格式字元串,最好能加密,這樣前端WEB只

                   有解密後才能獲取到。至於WEB端組合查詢頁面的設計與製作在後續的頁面設計中進行敘述。

                   

 

 

 

 

 

 

 

 

 

 

 

    

  


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

-Advertisement-
Play Games
更多相關文章
  • 在JavaScript中,函數其實就是對象。使函數不同於其他對象的決定性特點是函數存在一個被稱為[[Call]]的內部屬性。內部屬性無法通過代碼訪問而是定義了代碼執行時的行為。ECMAScript為JavaScript的對象定義了多種內部屬性,這些內部屬性都用雙重中括弧來標註。 ​[[Call]]屬 ...
  • wxss文件樣式 .item-image{ width: 80px; height: 80px; margin-right: 2px; } .item-image{ width: 80px; height: 80px; margin-right: 2px; } wxml 佈局 ...
  • 設置錨點的兩種方式 1.設置一個錨點鏈接<a href="#wang">去找汪星人</a> 在頁面中需要的位置設置錨點<a name="wang">汪星人基地</a> 2.設置一個錨點鏈接<a href="#miao">去找喵星人</a> 在頁面中需要的位置設置錨點<h3 id="miao">喵星人 ...
  • 主要介紹了一些數據保存在本地中的一些處理方法,包括cookie和webSrorage的保存優缺點介紹,以及簡單介紹cookie中的坑 ...
  • 我們定義一個組件的時候,可以在組件的某個節點內預留一個位置,當父組件調用該組件的時候可以指定該位置具體的內容,這就是插槽的用法,子組件模板可以通過slot標簽(插槽)規定對應的內容放置在哪裡,比如: 渲染結果為: 對應的html節點如下: 引用AppLayout這個組件時,我們指定了header和f ...
  • 最近在研究慢請求監控的問題,寫了一個簡單的測試代碼:在網頁端( )通過 函數向服務端獲取數據,然後列印請求耗時。 在服務端通過 延時 才返回數據(服務端使用 "ExpressJS" )。 不出所料, 數據都略微大於 1500。 而後,我突發奇想,假設我同時發送多個請求會怎麼樣呢?於是有瞭如下代碼: ...
  • JQuery本質上還是JavaScript,是JavaScript的一個框架,可以讓我們更簡潔地去使用JavaScript 使用之前,記得在html頭部引用JQuery 通過選擇器獲得JQuery對象 id element class selector1,selector2... 層級 attrib ...
  • 快速熱門指導,櫥窗註意細節 雙語字幕添加,資源對接擔保 全國抖音聯盟內部唯一官網 : http://douyinlianmeng.tk ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...