從系統架構分析安全問題及應對措施

来源:https://www.cnblogs.com/Jcloud/archive/2022/09/07/16664741.html
-Advertisement-
Play Games

在日常生產生活中,我們常說,“安全第一”、“安全無小事”。圍繞著安全問題,在各行各業都有對各類常見安全問題的解決方案和突發安全問題的應急預案。在互聯網、軟體開發領域,我們日常工作中對各類常見的安全問題又有哪些常見的解決方案呢?在此,結合經典架構圖做一個梳理。 ...


在日常生產生活中,我們常說,“安全第一”、“安全無小事”。圍繞著安全問題,在各行各業都有對各類常見安全問題的解決方案和突發安全問題的應急預案。在互聯網、軟體開發領域,我們日常工作中對各類常見的安全問題又有哪些常見的解決方案呢?在此,結合經典架構圖做一個梳理。

經典架構圖


下麵,結合上述的經典架構圖,對數據存儲、微服務介面、外網數據傳輸及APP層可能出現的安全問題進行分析,並給出一些常見的應對措施。

1 數據存儲

為了保證數據存儲的安全,對於敏感數據在進行存儲時,需要進行加密存儲,同時,敏感數據建議在全公司進行收口管理,便於統一管理。對敏感數據進行加密存儲時,常見的加密方式有可逆加密和不可逆加密,分別適用於不同的敏感數據。

1.1 可逆加密或對稱加密

可逆加密,即通過對密文進行解密後,能把密文解密還原出明文。對稱加密演算法加密和解密用到的密鑰是相同的,這種加密方式加密速度非常快,適合經常發送數據的場合,缺點是密鑰的傳輸比較麻煩。比如:網路購物的收貨地址、姓名、手機號等就適合用該加密方式,常用的對稱加密演算法有DES、AES,下麵以AES為例說明對稱加密的過程。

 

在該加解密中,對於秘鑰K的生成需要加解密雙方共同制定並妥善保管。通常,我們會把該秘鑰K存儲在需要使用加解密程式的進程內,便於在程式使用時直接進行使用。

1.2 不可逆加密

不可逆加密,即不需要解密出明文,如:用戶的密碼。不可逆加密常用的演算法有RES、MD5等,在此以MD5為例進行說明。但大家都知道,MD5演算法是存在碰撞的,即不同的明文通過MD5加密後,存在相同的密文。因此,直接使用MD5對密碼進行加密在生產上是不嚴謹的,通常還需要配合鹽(salt)進行使用。對於鹽的使用,也有一定的技巧,一種鹽值是固定的,即所有的明文在進行加密時都使用相同的鹽進行加密;另一種是結合具體的業務場景,用可變鹽值,比如:就密碼加密而言,可以把用戶名的部分或全部作為鹽值,和密碼進行一起加密後存儲。

 

2 微服務介面

微服務的安全,需要從請求鑒權和請求容量限制這2個方面來考慮。對於請求鑒權,可以設置請求IP黑名單的方式,對該IP的所有請求或全部放行或全部拒絕,該方式的粒度較粗。而如果要做得較細粒度一些,可以針對具體的API進行token鑒權,相比粗粒度該方式會控制得比較精準;

 

<jsf:consumer id="setmentService" interface="com.jd.lfsp.jsf.service.SetmentService"
                  protocol="jsf" alias="${jsf.consumer.alias}" timeout="${jsf.consumer.timeout}" retries="0">
        <jsf:parameter key="token" value="${jsf.consumer.token}" hide="true" />
</jsf:consumer>
 

除了對請求鑒權外,在實際的生產中,還可以對請求容量進行限制,對請求容量進行限制時,可以按QPS進行限制,也可以對每天的最大請求次數進行限制。在jsf平臺管理端,可以對具體的方法進行請求的QPS限流。

 

3 數據傳輸

數據傳輸主要分為數據通過前端APP的請求,進入到服務網關前和進入服務網關後這倆部分,對於數據已經進入服務網關後,這屬於機房內的數據傳輸,通常這類加密意義不大,對這類的數據傳輸的安全需要建立相應的內部安全機制及流程規範,通過制度措施來保證。而數據在進入服務網關前,對數據的安全傳輸有哪些可做的。在數據請求進入服務網關前,通常我們有基於SSL協議的傳輸加密以及現在普遍通用的HTTPS加密。

 

HTTPS也是HTTP和SSL協議的結合體,所以在數據傳輸中,SSL協議扮演了至關重要的角色。那SSL協議的工作過程是怎麼樣的,他是怎麼保證數據傳輸過程中的安全的呢?下麵為大家解析一下SSL協議的工作過程。

 

SSL客戶端與SSL服務端驗證的過程如下:

  1. SSL客戶端向SSL服務端發送隨機消息ClientHello的同時把自己支持的SSL版本、加密演算法、秘鑰交換演算法、MAC演算法等信息一併發送;
  2. SSL服務端收到SSL客戶端的請求後,確定本次通信採用的SSL版本及加密組件和MAC演算法,並通過ServerHello發送給SSL客戶端;
  3. SSL服務端將攜帶自己公鑰信息的數字證書通過Certificate發送給SSL客戶端;
  4. SSL服務端通過ServerHelloDone消息通知SSL客戶端版本和加密組件協商結束,開始進行秘鑰交換;
  5. SSL客戶端驗證SSL服務端發送的證書合法後,利用證書中的公鑰加密隨機數生成ClientKeyExchange發送給SSL服務端;
  6. SSL客戶端發送ChangeCipherSpec消息,通知SSL服務端後續將用協商好的秘鑰及加密組件和MAC值;
  7. SSL客戶端計算已交互的握手消息的hash值,利用協商好的秘鑰和加密組件加密hash值,並通過Finished消息發送給SSL服務端,SSL服務端用相同的方法計算已交互的hash值,並與Finished消息進行對比,二者相同且MAC值相同,則秘鑰和加密組件協商成功;
  8. 同樣地,SSL服務端也通過ChangeCipherSpec消息通知客戶端後續報文將採用協商好的秘鑰及加密組件和MAC演算法;
  9. SSL服務端端計算已交互的握手消息的hash值,利用協商好的秘鑰和加密組件加密hash值,並通過Finished消息發送給SSL客戶,SSL客戶端用相同的方法計算已交互的hash值,並與Finished消息進行對比,二者相同且MAC值相同,則秘鑰和加密組件協商成功;

通過上面的這個交互過程,我們可以看出,在使用SSL的過程中,除了客戶端(瀏覽器)跟伺服器之間的通訊外,其他的任何第三方想要獲取到協商的秘鑰是比較困難的。即使有比較厲害的人獲取到了,基於目前用戶在某個網站上的時效性,會影響我們對應秘鑰的時效性,因此,造成的破壞性也比較有限。

4 APP

在APP層的安全問題,需要結合服務端一併來解決,在這主要介紹驗證碼這種形式。驗證碼作為一種人機識別手段,其主要作用是區分正常人操作還是機器的操作,攔截惡意行為。當前互聯網中,大多數系統為了更好地提供服務,通常都需要用戶進行註冊。註冊後,用戶每次在使用系統時需要進行登錄,登錄過程中,為了防止系統非法使用,通常都需要用戶進行登錄操作,登錄過程中,常用的驗證方式主要通過驗證碼進行驗證,當前比較常用的驗證碼有以下幾種類型。

4.1 簡訊驗證碼

目前用得比較廣泛的一種驗證碼形式,輸入有效的手機號後,系統給手機號發送相應的簡訊驗證碼完成驗證。

 

4.2 語音驗證碼

通過輸入有效的手機號,系統給手機號撥打電話後,用語音播報的方式完成驗證碼的驗證。

 

4.3 圖片驗證碼

較傳統的驗證碼驗證方式,由系統給出驗證碼在頁面顯示,在進行頁面提交時,驗證碼一併提交到系統後臺驗證。

 

4.4 語義驗證碼

比較新穎的一種驗證碼形式,但是該種方式相比較而言對用戶不是特別友好,需要慎用。

 

除了上述的幾種目前常用的驗證碼外,還有文本驗證碼、拼圖驗證碼、問題類驗證碼等,在此就不再一一列舉,大家如果感興趣可以自己去搜索、學習。

這主要從系統的架構上,分析了日常工作中我們所接觸到的比較常見的一些安全問題及其應對措施,在實際工作的安全問題遠不止這裡提到的內容。希望在日常工作中,我們大家都繃緊安全的神經,時刻關註自己工作中的各類潛在的安全問題,爭取把安全問題消滅在系統發佈前。

5 參考文獻

SSL是如何加密傳輸的數據的:
[技術每日說] - SSL是如何加密傳輸的數據的!

名詞解釋:

  • SSL:(Secure Socket Layer,安全套接字層),位於可靠的面向連接的網路層協議和應用層協議之間的一種協議層。SSL通過互相認證、使用數字簽名確保完整性、使用加密確保私密性,從而實現客戶端和伺服器之間的安全通訊。該協議由兩層組成:SSL記錄協議和SSL握手協議。
  • HTTPS:(全稱:Hypertext Transfer Protocol over Secure Socket Layer),是以安全為目標的HTTP通道,簡單講是HTTP的安全版(HTTP+SSL)。即HTTP下加入SSL層,HTTPS的安全基礎是SSL,因此加密的詳細內容就需要SSL。

作者:廖宗雄


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

-Advertisement-
Play Games
更多相關文章
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 一、效果圖 具體效果可參考iview官方界面iView - 一套高質量的UI組件庫 大波浪效果,使用的是three.js的官方例子,需要先安裝three.js支持 npm install --save three 具體可以看 three. ...
  • 每日3題 1 以下代碼執行後,控制臺中的輸出內容為? var company = { address: "chengdu", }; var obj = Object.create(company); delete obj.address; console.log(obj.address); 2 以下 ...
  • 終於,在漫長的等待下,容器查詢(CSS Container Queries)將在 Chrome 105 版本得到正式的支持! 而目前,我們也能在 Chrome Canary 版本中,或者在 Chrome 93~104 通過開啟 Enable CSS Container Queries 特性搶先體驗。 ...
  • 基於全屏iframe的微前端框架--擎天,解決了iframe UI不同步、URL不同步、數據不共用的難題,並充分發揮了iframe作為頁面容器的優勢,實現了父子應用非同步載入、子應用瞬間切換的能力,從而將微前端項目達到單體應用的體驗。 ...
  • 不知不覺,掘金關註者人數已經超過 1000 人,因此特地做了這個頁面紀念一下,感謝大家關註 🙇‍ ,希望博客園的粉絲也漲漲。後續也將繼續努力,持續輸出一些有價值的文章。本文內容涉及的技術棧為 React + Three.js + Stulus,本文中主要包含的知識點包括:圓錐幾何體 ConeGeo... ...
  • 一、系統架構的演變 1、技術架構發展歷史時間軸 ①單機垂直拆分:應用間進行瞭解耦,系統容錯提高了,也解決了獨立應用發佈的問題,存在單機計算能力瓶頸。 ②集群化負載均衡可有效解決單機情況下併發量不足瓶頸。 ③服務改造架構 雖然系統經過了垂直拆分,但是拆分之後發現有重覆的功能,比如,用戶註冊、發郵件等等 ...
  • 外觀模式(Facade Pattern)隱藏系統的複雜性,並向客戶端提供了一個客戶端可以訪問系統的介面。這種類型的設計模式屬於結構型模式,它向現有的系統添加一個介面,來隱藏系統的複雜性。 ...
  • 什麼是統一建模語言,來看看百科中的介紹統一建模語言(Unified Modeling Language,UML)是一種為面向對象系統的產品進行說明、可視化和編製文檔的一種標準語言,是非專利的第三代建模和規約語言。UML是面向對象設計的建模工具,獨立於任何具體程式設計語言。簡單來說UML就是脫離於具體 ...
一周排行
    -Advertisement-
    Play Games
  • C#TMS系統代碼-基礎頁面BaseCity學習 本人純新手,剛進公司跟領導報道,我說我是java全棧,他問我會不會C#,我說大學學過,他說這個TMS系統就給你來管了。外包已經把代碼給我了,這幾天先把增刪改查的代碼背一下,說不定後面就要趕鴨子上架了 Service頁面 //using => impo ...
  • 委托與事件 委托 委托的定義 委托是C#中的一種類型,用於存儲對方法的引用。它允許將方法作為參數傳遞給其他方法,實現回調、事件處理和動態調用等功能。通俗來講,就是委托包含方法的記憶體地址,方法匹配與委托相同的簽名,因此通過使用正確的參數類型來調用方法。 委托的特性 引用方法:委托允許存儲對方法的引用, ...
  • 前言 這幾天閑來沒事看看ABP vNext的文檔和源碼,關於關於依賴註入(屬性註入)這塊兒產生了興趣。 我們都知道。Volo.ABP 依賴註入容器使用了第三方組件Autofac實現的。有三種註入方式,構造函數註入和方法註入和屬性註入。 ABP的屬性註入原則參考如下: 這時候我就開始疑惑了,因為我知道 ...
  • C#TMS系統代碼-業務頁面ShippingNotice學習 學一個業務頁面,ok,領導開完會就被裁掉了,很突然啊,他收拾東西的時候我還以為他要旅游提前請假了,還在尋思為什麼回家連自己買的幾箱飲料都要叫跑腿帶走,怕被偷嗎?還好我在他開會之前拿了兩瓶芬達 感覺感覺前面的BaseCity差不太多,這邊的 ...
  • 概述:在C#中,通過`Expression`類、`AndAlso`和`OrElse`方法可組合兩個`Expression<Func<T, bool>>`,實現多條件動態查詢。通過創建表達式樹,可輕鬆構建複雜的查詢條件。 在C#中,可以使用AndAlso和OrElse方法組合兩個Expression< ...
  • 閑來無聊在我的Biwen.QuickApi中實現一下極簡的事件匯流排,其實代碼還是蠻簡單的,對於初學者可能有些幫助 就貼出來,有什麼不足的地方也歡迎板磚交流~ 首先定義一個事件約定的空介面 public interface IEvent{} 然後定義事件訂閱者介面 public interface I ...
  • 1. 案例 成某三甲醫預約系統, 該項目在2024年初進行上線測試,在正常運行了兩天後,業務系統報錯:The connection pool has been exhausted, either raise MaxPoolSize (currently 800) or Timeout (curren ...
  • 背景 我們有些工具在 Web 版中已經有了很好的實踐,而在 WPF 中重新開發也是一種費時費力的操作,那麼直接集成則是最省事省力的方法了。 思路解釋 為什麼要使用 WPF?莫問為什麼,老 C# 開發的堅持,另外因為 Windows 上已經裝了 Webview2/edge 整體打包比 electron ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...