如何為SpringBoot服務添加HTTPS證書


HTTPS是HTTP的安全版本,旨在提供數據傳輸層安全性(TLS)。當你的應用不使用HTTP協議的時候,瀏覽器地址欄就會出現一個不安全的提示。HTTPS加密每個數據包以安全方式進行傳輸,並保護敏感數據免受竊聽者或黑客的攻擊。

您可以通過在Web應用程序上安裝SSL證書來實現HTTPS,互聯網上受信任的證書通常是需要(CA)頒發的證書。為了學習目的,您也可以使用自簽名證書,比如:使用Java Keytool生成自簽名證書。

一、自簽名證書

您可以使用位於JDK bin文件夾下的Keytool生成證書。例如,C:\Program Files\Java\jdk1.8.0_161\bin。可以使用兩種自簽名證書,如下所示。

  1. 通過您自己的Java應用程序可以輕松訪問JKS(Java密鑰庫)。JKS僅限於Java,不能從Java外部訪問。
  2. PKCS12:該證書使用的公鑰加密標准與語言無關,用於存儲加密的私鑰和證書。

本作者技術博客是:字母哥博客(z i m u g 點 康 姆),里面包含精品技術文章集合,歡迎您的訪問。

二、如何生成自簽名證書

在Windows的搜索字段中鍵入cmd以找到命令提示符,然后以“以管理員身份運行”右鍵單擊。使用如下的keytool命令。您可以提及所需的證書名稱,如下所示。

C:\Program Files\Java\jdk1.8.0_161\bin>

keytool -genkeypair -alias selfsigned_localhost_sslserver -keyalg RSA -keysize 2048 -storetype PKCS12 -keystore ebininfosoft-ssl-key.p12 -validity 3650

自簽名證書受密碼保護。命令回車之后,會提示輸入密碼(這個密碼要記住,后面會用到)和其他詳細信息,如以下屏幕截圖所示。

file

完成上述步驟后,便會創建PKS密鑰並將其存儲在JDK Bin文件夾下。

三、將SSL應用於Spring Boot應用程序

  1. 從JDK bin文件夾復制ebininfosoft-ssl-key並將其放在Spring Boot Application的src / main / resources下。
  2. 如下所示,將SSL密鑰信息添加到application.properties中。
#SSL Key Info
security.require-ssl=true
server.ssl.key-store-password=生成證書的密碼
server.ssl.key-store=src/main/resources/ebininfosoft-ssl-key.p12
server.ssl.key-store-type=PKCS12

四、寫一個Controller做簡單的測試

@RestController
@RequestMapping("/home")
public class HomeController {
 @RequestMapping(value = "/", method = RequestMethod.GET)
 public String hello() {
  return "welcome to spring boot application";
 }
}

如果您在不使用HTTPS的情況下訪問Rest Endpoint,則會在瀏覽器中收到“Bad Request”消息。如果您使用HTTPS來訪問URL,則會得到如下響應:"welcome to spring boot application"

歡迎關注我的博客,里面有很多精品合集

  • 本文轉載注明出處(必須帶連接,不能只轉文字):字母哥博客


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM