透過HTTPS存取使用者指定主機的應用程式是一個常見的需求,但在實際應用中可能會遇到一些困惑。對於這個問題,php小編香蕉認為應該嘗試透過尋找FQDN來提供幫助。 FQDN(Fully Qualified Domain Name)是一個完全限定的域名,包含主機名稱和域名。透過尋找FQDN,可以確保準確地定位到使用者指定的主機,從而提供準確的幫助和服務。因此,在進行HTTPS訪問時,尋找FQDN是一個有益的策略。
問題內容
我正在使用一個 golang 應用程序,該應用程式透過另一台主機上的 HTTPS 與伺服器進行通訊。具體來說,如果上下文很重要:從同一 Google Cloud 專案中的 GCE 實例與 Dataproc 叢集進行通訊(無需特殊的網域設定)。
伺服器產生一個自簽名證書,我已在客戶端手動安裝該證書。
伺服器和用戶端都是我的 Google 雲端專案上的 GCE 實例(它們的 FQDN 是 <hostname>.c.<project_id>.internal</project_id></hostname>
)
如果我嘗試使用 golang 的 http.Client 從客戶端連接到伺服器,我會收到以下錯誤:
failed to verify certificate: x509: certificate is valid for *.c.<project_id>.internal, not <server_hostname>
但是,如果我將其 FQDN 傳遞給它(<server_hostname>.c.<project_id>.internal</project_id></server_hostname>
),則它可以開箱即用。
僅供參考,此行為與我執行 cURL 時看到的一致:
curl: (60) SSL: no alternative certificate subject name matches target host name '<server_hostname>'
所以我的問題是:
- 為什麼它不適用於短/部分主機名稱?它位於同一網域中,因此它是
*.c.<project_id>.internal</project_id>
的一部分,並且開箱即用,不是嗎?或者它是否總是要求使用傳入的字串來實際匹配通配符字串(這意味著它不進行查找,並且僅在您傳入 fqdn 時才有效)? - 建立要分發的應用程式時,最佳實踐是什麼?我是否應該添加一些邏輯來讓它計算 FQDN,以便它可以將短名稱轉換為更可能與自簽名憑證一起使用的長名稱,或者將其留給呼叫者來找出神秘的錯誤訊息?李>
注意:我不想跳過驗證 - 我只是想更好地了解正在發生的事情,並知道這裡的最佳實踐是什麼。
謝謝!
解決方法
- 憑證根據其中包含的名稱與網域/主機進行匹配,因此即使
<server_hostname></server_hostname>
和<server_hostname>.c.<project_id>.internal</project_id></server_hostname>
解析為相同的內容,證書僅包含第二個(或與其匹配的通配符) 。由於這些是自行產生的,因此您可以在其中添加短名稱作為 SAN(主題備用名稱)。 OpenSSL 的附加標誌:
-addext "subjectAltName = DNS:localhost,DNS:<server_hostname>"
公共 CA 不太可能為您提供具有不可公開解析的 SAN 的憑證。 (有些可能,我沒試過)
作為範例,您不希望從 google.com.someevildomain.org
提供或信任 google.com
,因此這是一項安全功能。
- 這要看情況。如果您可以控制證書,則只需新增您希望使用的名稱即可。這可能最終成為具有許多 SAN 的單一證書,在這種情況下,讓每個人都使用 FQDN 進行交談可能會更乾淨。如果您可以匯入許多證書,那麼最好讓每個服務都有自己的帶有 FQDN 和短名稱的證書。
以上是透過 HTTPS 存取使用者指定主機的應用程式是否應該嘗試透過尋找其 FQDN 來提供協助?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Golang在实际应用中表现出色,以简洁、高效和并发性著称。1)通过Goroutines和Channels实现并发编程,2)利用接口和多态编写灵活代码,3)使用net/http包简化网络编程,4)构建高效并发爬虫,5)通过工具和最佳实践进行调试和优化。

Go語言的核心特性包括垃圾回收、靜態鏈接和並發支持。 1.Go語言的並發模型通過goroutine和channel實現高效並發編程。 2.接口和多態性通過實現接口方法,使得不同類型可以統一處理。 3.基本用法展示了函數定義和調用的高效性。 4.高級用法中,切片提供了動態調整大小的強大功能。 5.常見錯誤如競態條件可以通過gotest-race檢測並解決。 6.性能優化通過sync.Pool重用對象,減少垃圾回收壓力。

Go語言在構建高效且可擴展的系統中表現出色,其優勢包括:1.高性能:編譯成機器碼,運行速度快;2.並發編程:通過goroutines和channels簡化多任務處理;3.簡潔性:語法簡潔,降低學習和維護成本;4.跨平台:支持跨平台編譯,方便部署。

關於SQL查詢結果排序的疑惑學習SQL的過程中,常常會遇到一些令人困惑的問題。最近,筆者在閱讀《MICK-SQL基礎�...

golang ...

Go語言中如何對比並處理三個結構體在Go語言編程中,有時需要對比兩個結構體的差異,並將這些差異應用到第�...


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SublimeText3 Linux新版
SublimeText3 Linux最新版

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

Atom編輯器mac版下載
最受歡迎的的開源編輯器

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。