.NET Core 必備安全措施

来源:https://www.cnblogs.com/shanyou/archive/2018/11/13/9952663.html
-Advertisement-
Play Games

.NET Core大大簡化了.NET應用程式的開發。它的自動配置和啟動依賴大大減少了開始一個應用所需的代碼和配置量,本文目的是介紹如何創建更安全的.NET Core應用程式。 1.在生產中使用HTTPS傳輸層安全性(TLS)是HTTPS的官方名稱,你可能聽說過它稱為SSL(安全套接字層),SSL是已... ...


.NET Core大大簡化了.NET應用程式的開發。它的自動配置和啟動依賴大大減少了開始一個應用所需的代碼和配置量,本文目的是介紹如何創建更安全的.NET Core應用程式。

1.在生產中使用HTTPS

傳輸層安全性(TLS)是HTTPS的官方名稱,你可能聽說過它稱為SSL(安全套接字層),SSL是已棄用的名稱,TLS是一種加密協議,可通過電腦網路提供安全通信。其主要目標是確保電腦應用程式之間的隱私和數據完整性。過去,TLS / SSL證書很昂貴,而且HTTPS被認為很慢,現在機器變得更快,已經解決了性能問題,Let's Encrypt提供免費的TLS證書,這兩項發展改變了游戲,並使TLS成為主流。截至2018年7月24日,Google Chrome 將HTTP網站標記為“不安全”。雖然這在網路社區引起了相當多的爭議。知名安全研究員特洛伊亨特創建了一個 為什麼不適用HTTPS ?跟蹤不使用HTTPS的大型網站的網站。

Let’s Encrypt TLS證書可以自動化生成和更新,由於他們是免費的,所以沒有理由不去做!

要在ASP.NET Core應用程式中強制使用HTTPS,ASP.NET Core 2.1版本已經預設支持HTTPS。

----------public void ConfigureServices(IServiceCollection services)  部分:

services.AddMvc(options =>
{
options.Filters.Add(new RequireHttpsAttribute());//所有請求都使用HTTPS
})


---------public void Configure(IApplicationBuilder app, IHostingEnvironment env) 部分:

var options = new RewriteOptions().AddRedirectToHttps();
app.UseRewriter(options);
app.UseHttpsRedirection();

另一個重要的事情是使用HTTP嚴格傳輸安全性(HSTS)。HSTS是一種Web安全策略機制,可以保護網站免受協議降級攻擊和cookie劫持。伺服器使用名為Strict-Transport-Security的響應頭欄位將HSTS策略傳送到瀏覽器。ASP.NET Core預設發送此標頭,以避免在開始時出現不必要的HTTP躍點。 具體參考 https://docs.microsoft.com/zh-cn/aspnet/core/security/enforcing-ssl?view=aspnetcore-2.1&tabs=visual-studio 

2、升級到最新版本

定期升級應用程式中的依賴項有多種原因。安全性是讓您有升級動力的最重要原因之一。 基礎架構升級通常不如依賴項升級具有破壞性,因為庫作者對向後相容性和版本之間的行為更改的敏感性各不相同。話雖如此,當你在配置中發現安全漏洞時,您有三種選擇:升級,修補程式或忽略。在對應用程式進行必要的更改以使用較新版本之後,就應用程式的整體運行狀況而言,升級是最安全的。

3、啟用CSRF保護

跨站點請求偽造(Cross-Site Request Forgery )是一種攻擊,強制用戶在他們當前登錄的應用程式中執行不需要的操作。如果用戶是普通用戶,一個成功攻擊可能涉及請求的狀態更改,如轉移資金或更改其電子郵件地址,如果用戶具有提升管理員的許可權,則CSRF攻擊可能會危及整個應用程式。

ASP.NET Core具有出色的CSRF支持,ASP.NET Core使用 ASP.NET Core data protection stack 來實現防請求偽造。預設情況下處於啟用狀態,CSRF令牌將自動添加為隱藏輸入欄位。

如果你使用的是像Angular或React這樣的JavaScript框架,則需要配置CookieCsrfTokenRepository以便JavaScript可以讀取cookie。參考 https://www.cnblogs.com/tdfblog/p/aspnet-core-security-anti-request-forgery.html 

4、使用內容安全策略防止XSS攻擊

內容安全策略(CSP)是一個增加的安全層,可幫助緩解XSS(跨站點腳本)和數據註入攻擊。 參考 http://www.cnblogs.com/wang2650/p/7785106.html 

5、使用OpenID Connect進行身份驗證

OAuth 2.0是行業標準的授權協議。它使用scope來定義授權用戶可以執行的操作的許可權。但是,OAuth 2.0不是身份驗證協議,並且不提供有關經過身份驗證的用戶的信息。OpenID Connect(OIDC)是一個OAuth 2.0擴展,提供用戶信息,除了訪問令牌之外,它還添加了ID令牌,以及/userinfo可以從中獲取其他信息的端點,它還添加了發現功能和動態客戶端註冊的端點。

如果使用OIDC進行身份驗證,則無需擔心如何存儲用戶、密碼或對用戶進行身份驗證。相反,你可以使用身份提供商(IdP)為你執行此操作,你的IdP甚至可能提供多因素身份驗證(MFA)等安全附加組件。

.NET Core具有良好的OpenID Connect 標準的基礎,我們可以很容易的通過Identity Server4 等開源項目實現OpenID Connect的身份認證。

6、安全地存儲敏感數據

應謹慎處理敏感信息,如密碼,訪問令牌等,你不能以純文本形式傳遞,或者如果將它們保存在本地存儲中。由於(GitHub)的歷史已經一次又一次證明,開發人員並沒有仔細考慮如何存儲他們的秘密。一個好的做法是將保密信息存儲在保管庫中,該保管庫可用於存儲,提供對應用程式可能使用的服務的訪問許可權,甚至生成憑據。HashiCorp的Vault使得存儲機密變得很輕鬆,並提供了許多額外的服務。

7、使用OWASP的ZAP測試您的應用程式

OWASP Zed Attack Proxy簡寫為ZAP,是一個簡單易用的滲透測試工具,是發現Web應用中的漏洞的利器,更是滲透測試愛好者的好東西。OWASP ZAP安全工具是針對在運行活動的應用程式進行滲透測試的代理。它是一個受歡迎的(超過4k星)免費的開源項目,托管在GitHub上。OWASP ZAP用於查找漏洞的兩種方法是Spider和Active Scan。

Spider工具以URL種子開頭,它將訪問並解析每個響應,識別超鏈接並將它們添加到列表中。然後,它將訪問這些新找到的URL並以遞歸方式繼續,為您的Web應用程式創建URL映射。

Active Scan工具將根據潛在漏洞列表自動測試你選擇的目標。它提供了一個報告,顯示Web應用程式可被利用的位置以及有關漏洞的詳細信息。參考http://www.cnblogs.com/tdcqma/p/5344494.html 

8、讓你的安全團隊進行代碼審查

代碼評審對任何高性能軟體開發團隊都至關重要。我們所有的生產代碼和官方開源項目都需要通過我們的專家安全團隊進行分析,但如果你正在處理敏感數據,也許你應該這樣做!

可以參考的工具:


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

-Advertisement-
Play Games
更多相關文章
  • Spring Security Oauth2 示例,基於SpringBoot搭建授權服務和資源服務 ...
  • Java的serialization提供了一種持久化對象實例的機制。當持久化對象時,可能有一個特殊的對象數據成員,我們不想用serialization機制來保存它。 為了在一個特定對象的一個域上關閉serialization,可以在這個域前加上關鍵字transient。 當一個對象被序列化的時候,t ...
  • 首先請using這個類庫。 這個類庫老牛逼了,首先是包含了一個IdentityUser類。我們可以自己寫一個User類繼承IdentityUser,這樣一來,很多屬性我就不用手動建了。如你所見,我的User沒有Emai這個欄位,但是IdentityUser有這個欄位。 如何把用戶發來的數據變成一個U ...
  • /*普通行列轉換 假設有張學生成績表(tb)如下:Name Subject Result張三 語文 74張三 數學 83張三 物理 93李四 語文 74李四 數學 84李四 物理 94*/ /*想變成 姓名 語文 數學 物理 李四 74 84 94張三 74 83 93*/createtable t ...
  • 關於Dapper的介紹,我想很多人都對它有一定的瞭解,這個類似一個輕型的ORM框架是目前應用非常火的一個東西,據說各方面的性能都不錯,而且可以支持多種資料庫,在開始介紹這個文章之前,我花了不少功夫來學習了Dapper 的相關使用。Dapper.Contrib是對Dapper的進一步封裝,使對象的基本... ...
  • 原文: [Building C# 8.0](https://blogs.msdn.microsoft.com/dotnet/2018/11/12/building-c-8-0/) C# 的下一個主要版本是 8.0。我們已經為它工作了很長一段時間,即使我們構建併發布了次要版本 C# 7.1, 7.... ...
  • 在PDF中,書簽作為一種導航的有效工具,能幫助我們快速地定位到文檔中的指定段落。同時,書簽也能讓人對文檔結構一目瞭然,在某種程度上也可作為目錄使用。對於C#操作PDF中的書簽,在上一篇文章中介紹了具體的如何添加書簽、修改已有書簽以及刪除書簽的操作,在本篇文章中,將介紹C#如何讀取PDF中的多級書簽。 ...
  • 一、安裝 二、安裝後會在根目錄出現NLog.config配置文件,簡單修改配置文件為寫入文件記錄日誌: 三、使用方法: 簡單的異常日誌寫入完成,看了配置項太多頭有點大,先這樣了 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...