10 種保護 Spring Boot 應用的絕佳方法

Spring Boot大大簡化了Spring應用程序的開發。它的自動配置和啟動依賴大大減少了開始一個應用所需的代碼和配置量,如果你已經習慣了Spring和大量XML配置,Spring Boot無疑是一股清新的空氣。

Spring Boot于2014年首次發布,自那以后發生了很多變化。安全性問題與代碼質量和測試非常相似,已經日漸成為開發人員關心的問題,如果你是開發人員并且不關心安全性,那么也許認為一切理所當然。本文目的是介紹如何創建更安全的Spring Boot應用程序。

馬特雷布爾與Simon Maple合作完成了這篇文章,他們都是為安全公司工作,熱愛Java,并希望幫助開發人員創建更安全的應用程序。我們認為撰寫這篇文章將是回饋社區的有趣方式。

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證書可以自動化生成和更新,由于他們是免費的,所以沒有理由不去做!Spring Boot Secured By Let’s Encrypt的加密是如何做到這一點的有用指南。

要在Spring Boot應用程序中強制使用HTTPS,您可以擴展WebSecurityConfigurerAdapter并要求安全連接。

@Configuration
public class WebSecurityConfigurerAdapter extends WebSecurityConfigurerAdapter {@Overrideprotected void configure(HttpSecurity http) throws Exception {http.requiresChannel().requiresSecure();}
}

另一個重要的事情是使用HTTP嚴格傳輸安全性(HSTS)。HSTS是一種Web安全策略機制,可以保護網站免受協議降級攻擊和cookie劫持。服務器使用名為Strict-Transport-Security的響應頭字段將HSTS策略傳送到瀏覽器。Spring Security默認發送此標頭,以避免在開始時出現不必要的HTTP躍點,點擊這里一分鐘開啟Tomcat https支持。

2.使用Snyk檢查你的依賴關系

你很可能不知道應用程序使用了多少直接依賴項,這通常是正確的,盡管依賴性構成了整個應用程序的大部分。攻擊者越來越多地針對開源依賴項,因為它們的重用為惡意黑客提供了許多受害者,確保應用程序的整個依賴關系樹中沒有已知的漏洞非常重要。

Snyk測試你的應用程序構建包,標記那些已知漏洞的依賴項。它在儀表板在應用程序中使用的軟件包中存在的漏洞列表。

此外,它還將建議升級的版本或提供補丁,并提供針對源代碼存儲庫的拉取請求來修復您的安全問題。Snyk還確保在你的存儲庫上提交的任何拉取請求(通過webhooks)時都是通過自動測試的,以確保它們不會引入新的已知漏洞。

每天都會在現有項目和庫中發現新的漏洞,因此監控和保護生產部署也很重要。Snyk拍攝快照并監控你的部署,以便在發現新漏洞時,你可以通過JIRA,slack或電子郵件自動收到通知,并創建拉取請求以提供新漏洞的升級和補丁。

Snyk可通過Web UI和CLI獲得,因此您可以輕松地將其與CI環境集成,并將其配置為在存在嚴重性超出設定閾值的漏洞時中斷構建。

你可以免費使用Snyk進行開源項目或使用有限數量的私有項目。

3.升級到最新版本

定期升級應用程序中的依賴項有多種原因。安全性是讓您有升級動力的最重要原因之一。該start.spring.io起始頁面采用了最新的春季版本的軟件包,以及依賴關系,在可能的情況。

基礎架構升級通常不如依賴項升級具有破壞性,因為庫作者對向后兼容性和版本之間的行為更改的敏感性各不相同。話雖如此,當你在配置中發現安全漏洞時,您有三種選擇:升級,修補程序或忽略。

在對應用程序進行必要的更改以使用較新版本之后,就應用程序的整體運行狀況而言,升級是最安全的。

4.啟用CSRF保護

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

Spring Security具有出色的CSRF支持,如果您正在使用Spring MVC的<form:form>標簽或Thymeleaf @EnableWebSecurity,默認情況下處于啟用狀態,CSRF令牌將自動添加為隱藏輸入字段。

如果你使用的是像Angular或React這樣的JavaScript框架,則需要配置CookieCsrfTokenRepository以便JavaScript可以讀取cookie。

@EnableWebSecurity
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {@Overrideprotected void configure(HttpSecurity http) throws Exception {http.csrf().csrfTokenRepository(CookieCsrfTokenRepository.withHttpOnlyFalse());}
}

如果你正在使用Angular,這就是你需要做的。如果您使用的是React,則需要讀取XSRF-TOKENcookie并將其作為X-XSRF-TOKEN標題發回。

當請求通過HTTPS發生時,Spring Security會自動加入一個secure標識到XSRF-TOKENcookie 。Spring Security對于CSRF cookie不使用SameSite=strict 的標志,但它在使用Spring Session或WebFlux會話處理時會使用,這對會話cookie有意義,因為它有助于識別用戶,但是沒有為CSRF cookie提供太多價值,因為CSRF令牌也需要在請求中。點擊這里了解CSRF更多詳情。

5.使用內容安全策略防止XSS攻擊

內容安全策略(CSP)是一個增加的安全層,可幫助緩解XSS(跨站點腳本)和數據注入攻擊。要啟用它,你需要配置應用程序以返回Content-Security-Policy標題。你還可以在HTML頁面中<meta http-equiv="Content-Security-Policy">使用標記。

Spring安全性默認提供了許多安全標頭:

Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Content-Type-Options: nosniff
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
X-XSS-Protection: 1; mode=block

Spring Security * 默認情況下不添加 CSP。你可以使用以下配置在Spring Boot應用程序中啟用CSP標頭。

@EnableWebSecurity
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {@Overrideprotected void configure(HttpSecurity http) throws Exception {http.headers().contentSecurityPolicy("script-src 'self' https://trustedscripts.example.com; object-src https://trustedplugins.example.com; report-uri /csp-report-endpoint/");}
}

CSP是防止XSS攻擊的良好防御,請記住,打開CSP能讓CDN訪問許多非常古老且易受攻擊的JavaScript庫,這意味著使用CDN不會為安全性增加太多價值。點擊這里了解XSS更多詳情。

你可以在securityheaders.com測試你的CSP標頭是否有用。

6.使用OpenID Connect進行身份驗證

OAuth 2.0是行業標準的授權協議。它使用scope來定義授權用戶可以執行的操作的權限。但是,OAuth 2.0不是身份驗證協議,并且不提供有關經過身份驗證的用戶的信息。

OpenID Connect(OIDC)是一個OAuth 2.0擴展,提供用戶信息,除了訪問令牌之外,它還添加了ID令牌,以及/userinfo可以從中獲取其他信息的端點,它還添加了發現功能和動態客戶端注冊的端點。

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

要了解如何在Spring Boot應用程序中使用OIDC,請參閱Spring Security 5.0和OIDC入門。要總結如何使用它,你需要向項目添加一些依賴項,然后在application.yml文件中配置一些屬性。

spring:security:oauth2:client:registration:okta:client-id: {clientId}client-secret: {clientSecret}scope: openid email profileprovider:okta:issuer-uri: https://{yourOktaDomain}/oauth2/default

注意:issuer-uri僅在Spring Security 5.1中支持使用,Spring Security 5.1正在積極開發中并計劃于2018年9月發布。

你可以使用像Keycloak這樣的開源系統來設置自己的OIDC服務器。如果你不想在生產中維護自己的服務器,可以使用Okta的Developer API。

7.管理密碼?使用密碼哈希!

以純文本格式存儲密碼是最糟糕的事情之一。幸運的是,Spring Security默認情況下不允許使用純文本密碼。它還附帶了一個加密模塊,可用于對稱加密,生成密鑰和密碼散列(也就是密碼編碼)。

PasswordEncoder 是Spring Security中密碼哈希的主要接口,如下所示:

public interface PasswordEncoder {String encode(String rawPassword);boolean matches(String rawPassword, String encodedPassword);
}

Spring Security提供了幾種實現,最受歡迎的是BCryptPasswordEncoder和Pbkdf2PasswordEncoder。

對于一般的密碼管理,我們建議使用SCrypt或Argon2, SCrypt現在已經過時了(已經有一段時間了),并且有一個額外的復雜因素,BCrypt沒有這個因素,這使得暴力破解變得加倍地困難。它由著名的密碼學家/安全人員(Colin Percival)編寫,并且在幾乎所有編程語言中都有很好的庫,SCrypt也得到Latacora的認可。

Spring Security 5.1(即2018年9月下旬)將附帶UserDetailsPasswordService API,允許您升級密碼存儲。

8.安全地存儲秘密

應謹慎處理敏感信息,如密碼,訪問令牌等,你不能以純文本形式傳遞,或者如果將它們保存在本地存儲中。由于(GitHub)的歷史已經一次又一次證明,開發人員并沒有仔細考慮如何存儲他們的秘密。

一個好的做法是將保密信息存儲在保管庫中,該保管庫可用于存儲,提供對應用程序可能使用的服務的訪問權限,甚至生成憑據。HashiCorp的Vault使得存儲機密變得很輕松,并提供了許多額外的服務。

如果您對此感興趣,請務必花一些時間查看Spring Vault,它為HashiCorp Vault添加抽象,為客戶提供基于Spring注釋的訪問,允許他們訪問、存儲和撤銷機密而不會迷失在基礎架構中。以下代碼段顯示了使用注釋從Spring Vault中提取密碼的方便程度。

@Value("${password}")
String password;

9.使用OWASP的ZAP測試您的應用程序

OWASP ZAP安全工具是針對在運行活動的應用程序進行滲透測試的代理。它是一個受歡迎的(超過4k星)免費的開源項目,托管在GitHub上。

OWASP ZAP用于查找漏洞的兩種方法是Spider和Active Scan。

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

Active Scan工具將根據潛在漏洞列表自動測試你選擇的目標。它提供了一個報告,顯示Web應用程序可被利用的位置以及有關漏洞的詳細信息。

10.讓你的安全團隊進行代碼審查

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


更多干貨推薦

1.史上最強 Java 中高級面試題整理

2.史上最強 Spring Boot & Cloud 教程整理

3.史上最強架構設計分布式技術干貨整理

更多請掃描下方的二維碼關注我們的微信公眾號,干貨每日推送!

Java技術棧

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/537799.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/537799.shtml
英文地址,請注明出處:http://en.pswp.cn/news/537799.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

zkServer.cmd 閃退

調用 zkEnv.cmd 查看下 zkEnv.cmd 在\conf下復制zoo_sample.cfg 重命名為 zoo.cfg 再運行&#xff0c;成功

c語言單字符輸入和輸出函數分別為,第03章單元總練習-實訓-知識拓展.doc

第03章單元總練習-實訓-知識拓展《C語言程序設計》單元總結單元練習實訓指導知識拓展第三章 最簡單的C程序設計——順序結構設計班級:姓名:學號:單元總結提升本單元中&#xff0c;核心內容有C語言中基本的數據類型、常量和變量、運算符和表達式以及算法的概念。通過本單元的學習…

那些你不知道的 getClientRects()

1.getClientRects()。是可以獲取內聯元素的內容有多少行 最近一個交互&#xff0c;在限定文字展現是5行&#xff0c;超過5行&#xff0c;則在后面添加。。。展開。如果沒有展開二字&#xff0c;我們一般用css就能完成了。但是為了交互更人性化 text-overflow: -o-ellipsis-last…

idea統計代碼行數

使用統計代碼插件&#xff0c;可以統計代碼行數。安裝插件 Statistic。&#xff08;這個最好用&#xff09; File----settiing---plugins---browse repositories 重啟idea后&#xff0c;底部會多一個 Statistic 點擊刷新&#xff0c;行數就出來了。看最后的 Total

數據結構計算c語言數據步驟,數據結構C語言版視頻教程-介紹各種最常用的數據結構 分析各種數據結構運算算法的實現過程-電腦網絡視頻-星火視頻教程 21edu8.com...

這部數據結構C語言版視頻教程結構清晰&#xff0c;實例豐富&#xff0c;具有很強的操作性和實用性。 它主要為大家介紹各種最常用的數據結構&#xff0c;以及從編程角度出發&#xff0c;分析各種數據結構運算算法的實現過程。數據結構是計算機存儲、組織數據的方式。數據結構是…

極光推送小結 - iOS

此次即友盟分享小結(友盟分享小結 - iOS)之后對推送也進行了一版優化.此次分享內容依然基于已經成功集成 SDK 后 code 層級部分. 注:此次分享基于 SDK 3.1.0,若版本相差較大,僅供參考. 極光推送官方文檔: https://docs.jiguang.cn/jpush/guideline/intro/ 首先,為分享單獨創建了…

word去除所有的空行

申請軟著時&#xff0c;需要復制源代碼到word里。每行代碼不能有換行&#xff0c;要緊湊的80頁代碼。每頁要50~55行代碼。 字體可設置為&#xff1a;宋體&#xff0c;5號&#xff0c;行間距固定值12。 演示實例 去除下面word代碼里的空行 第一步&#xff1a; word顯示隱藏的…

c語言Wndproc未定義,為什么我的老是未定義

該樓層疑似違規已被系統折疊 隱藏此樓查看此樓這是源代碼#includeLRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM);int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance,PSTR szCmdLine, int iCmdShow){static TCHAR szAppName[] TEXT("HelloWin&qu…

spark on yarn

2019獨角獸企業重金招聘Python工程師標準>>> spark on yarn 軟件安裝 當前環境 hadoop環境搭建參考&#xff1a;hadoop集群安裝 hadoop2.6spark-2.2.0-bin-hadoop2.6.tgzscala-2.11.12安裝scala tar -zxvf scala-2.11.12.tgz vi /etc/profile 添加以下內容 export S…

如何查看SQL Server2000執行過的SQL語句

SQLServer事件探查器可以完整記錄SQL服務器執行過的SQL語句以及存儲過程等 下面是SQLServer事件探查器的使用方法&#xff1a; 1. 打開SQL Server 企業管理器。 2. 從“工具”菜單選擇“事件探查器”。 3. 當“事件探查器”主界面打開后&#xff0c;從“文件”菜單選擇“新跟蹤…

c語言鏈表不帶頭節點的排序,不帶頭結點的單向鏈表排序——插入排序(C語言)...

LinkList* LinkListInsertSort(LinkList* pHead){LinkList *pFirst (LinkList *)NULL; /* 原鏈表剩下未排序節點的頭指針 */LinkList *pCurrInsert (LinkList *)NULL; /* 無序鏈表中當前待插入節點 */LinkList *pPrev (LinkList *)NULL; /* 有序鏈表中插入位置的前一個節點 …

免費字體

若不想字體版權有問題&#xff0c;可以參考以下幾種完全免費的字體&#xff1a; 方正&#xff1a;方正黑體、方正書宋、方正仿宋、方正楷體 思源&#xff1a;思源黑體、思源柔黑體、思源宋體 站酷&#xff1a;站酷酷黑體、站酷高端黑體、站酷快樂體、站酷意大利體 。

【Python爬蟲學習筆記12】Ajax數據爬取簡介

有時候在我們設計利用requests抓取網頁數據的時候&#xff0c;會發現所獲得的結果可能與瀏覽器顯示給我們的不一樣&#xff1a;比如說有的信息我們通過瀏覽器可以顯示&#xff0c;但一旦用requests卻得不到想要的結果。這種現象是因為我們通過requests獲得的都是HTML源文檔&…

c語言的報告一,C語言實驗報告(一).doc

C語言實驗報告(一)C語言實驗報告(一)一、實驗目的掌握C語言中&#xff0c;基本的輸入輸出函數的使用方法。掌握printf中轉義字符’\t’&#xff0c;’\n’的用法。掌握賦值語句的用法。掌握算術表達式、賦值表達式的計算。掌握數學函數的使用。二、實驗內容從鍵盤輸入一個6位整…

數據挖掘——相似文章推薦

相似文章推薦&#xff1a;在用戶閱讀某篇文章時&#xff0c;為用戶推薦更多的與在讀文章內容相類似的文章 相關概念&#xff1a; 推薦(Recommended)&#xff1a;指介紹好的人或事物&#xff0c;希望被任用或接受。數據挖掘領域&#xff0c;推薦包括相似推薦和協同過濾推薦。 相…

win10投影無法正常使用:我們正在確認此功能 解決方法

鼠標移動到開始按鈕&#xff0c;右鍵----- windows powershell&#xff08;管理員&#xff09; 輸入命令&#xff1a; netsh winsock reset 然后重啟電腦&#xff0c;問題解決

青海師大c語言研究生專業課,2016年青海師范大學計算機應用技術C語言程序設計考研復試題庫...

一、選擇題1&#xff0e; 有如下程序:程序運行后的輸出結果是( )。答:C【解析】題目中判斷if 條件是否成立&#xff0c;后a 自增 得if 條件不成立執行else 函數體&#xff0c;輸出F 。最后執行語句故C 選項正確。 按照格式輸出2&#xff0e; 有如下程序&#xff1a;先取值為0, …

產品經理和項目經理的差別

原文地址&#xff1a;https://blog.csdn.net/verifocus/article/details/79219539 --------------------------------------------------------------------- 項目經理與產品經理的區別&#xff0c;用一句話概括就是&#xff1a;產品經理是做正確的事情&#xff0c;項目經理是…

c語言設計一個按時間片輪轉法實現處理器調度的程序,設計一個按時間片輪轉法實現處理器調度的程序...

實驗一處理器調度一、實習內容選擇一個調度算法&#xff0c;實現處理器調度。&#xff1b;二、實習目的在采用多道程序設計的系統中&#xff0c;往往有若干個進程同時處于就緒狀態。當就緒進程個數大于處理器數時&#xff0c;就必須依照某種策略來決定哪些進程優先占用處理器。…

Perl的淺拷貝和深度拷貝

首先是深、淺拷貝的概念&#xff1a; 淺拷貝&#xff1a;shallow copy&#xff0c;只拷貝第一層的數據。Perl中賦值操作就是淺拷貝深拷貝&#xff1a;deep copy&#xff0c;遞歸拷貝所有層次的數據&#xff0c;Perl中Clone模塊的clone方法&#xff0c;以及Storable的dclone()函…