生成本地測試用https證書,支持通配符和多功能變數名稱,初學OpenSSL

来源:https://www.cnblogs.com/xiangyuecn/archive/2018/01/27/8365634.html
-Advertisement-
Play Games

18 01 26在v2ex上看到一妹紙發的《身為一個 21 歲的年輕程式員,我已經腰突了(躺》,哈哈,感同身受,想到這幾天我左腿麻木持續了好幾天,前幾天屁股疼的只要坐下就站不起來,不過站著卻一點事沒有,然後堅持站了好幾天,目前屁股不疼,腿麻的毛病還沒有恢復。。。[後續] 接觸到的https http ...


18-01-26在v2ex上看到一妹紙發的《身為一個 21 歲的年輕程式員,我已經腰突了(躺》,哈哈,感同身受,想到這幾天我左腿麻木持續了好幾天,前幾天屁股疼的只要坐下就站不起來,不過站著卻一點事沒有,然後堅持站了好幾天,目前屁股不疼,腿麻的毛病還沒有恢復。。。[後續]

封面圖怎麼發?

接觸到的https

https站點生產環境和本地測試環境搭建以前也有點接觸(Windows Server2008 2012、Win7+IIS、還沒有接觸過其他系統Mac OS算半個),比如生產環境的:從免費的AlphaSSL通配符證書申請(好像已經關掉了),到坐等2月27號Let’s Encrypt正式開通通配符證書介面。

為什麼執意要通配符證書,其實不用也可以,不過要看伺服器臉色,Windows Server2008不支持SNI哦,如果是騰訊雲或者別的地方免費申請的單功能變數名稱證書就有點慘了,目前瞭解到的針對這種單功能變數名稱的只有加上埠才能多個功能變數名稱同時使用。免費的Let’s Encrypt簽的多功能變數名稱證書3月要維護一次,感覺好累啊~

本地測試環境相對就簡單多了,自己想怎麼搞就怎麼搞,證書想怎麼簽就就怎麼簽,誰要測試就在電腦上把根證書一裝,妥妥的。

以前生成證書比較簡單,直接用Windows Server系統自帶功能證書頒發機構就可以完成證書的簽發,也一直是這麼乾的,給我台式電腦ip簽了一個證書,需要的功能開發基本上都滿足了,要求其實並沒有那麼高@.@
網路上的一幅圖

好了,為什麼又扯出OpenSSL了呢,如果沒有Windows Server,Win7是沒有證書頒發機構這個玩意的,額外再裝一個虛擬機嗎?不方便,並且對證書頒發機構不夠熟,高級點的證書還要好好研究。需要尋找別的方法了,首選就是OpenSSL了。

準備工作

因為用的是Win7系統,下載了Win32OpenSSL。以前沒有怎麼用過OpenSSL,用的最多也就是生成個把子RSA秘鑰,對於簽名和證書是從來沒有接觸過的,而外花了半天時間搜索學習生成ssl通配符和多功能變數名稱證書的方法。

IIS全站https計劃

準備這樣對二級功能變數名稱進行細分,舉個慄子aa.com:

  1. www .aa .com、aa .com:網頁和介面
  2. static .aa .com:靜態資源,圖片、js等
  3. *.aa .com:其他功能站點子功能變數名稱,廣告、單獨功能站點
  4. bb .com、cc .com:其他功能變數名稱,備用

1、3、4是全部要上https的,2這個分http和https,js必須要https,圖片之類的沒有強制要求,預設全部是https的,讓瀏覽器有把小綠鎖。

根據這些功能變數名稱,本地測試生成證書就有方向了,最好是一個證書解決,不然IIS配置麻煩的要死。用通配符和多功能變數名稱解決。

生成本地測試證書

根據網上找到的資料,正常生成了證書。先生成根證書,然後生成功能變數名稱證書,最後用根證書對功能變數名稱證書簽名。把根證書導入目標電腦上就能正常訪問所有對應的功能變數名稱了。

1. 創建根證書

@echo off
set OPENSSL_CONF=openssl.ini

echo 創建秘鑰
pause
openssl genrsa -out LocalRootCA.key 2048

echo 生成證書並自簽名
pause
openssl req -sha256 -new -x509 -days 3650 -key LocalRootCA.key -out LocalRootCA.crt -subj "/CN=LocalRootCA"

echo 完成
pause

2. 創建功能變數名稱證書

@echo off
set OPENSSL_CONF=openssl.ini

echo 創建秘鑰
pause
openssl genrsa -out aa.com.key 2048

echo 創建請求文件
pause
openssl req -new -sha256 -key aa.com.key -out aa.com.csr -subj "/CN=*.aa.com"

echo 生成證書並用根證書簽名
pause
openssl x509 -req -in aa.com.csr -CA LocalRootCA.crt -CAkey LocalRootCA.key -CAcreateserial -days 3560 -out aa.com.crt -extfile aa.com.ini -extensions ext

echo 導出pfx,請輸入密碼
pause
openssl pkcs12 -export -out aa.com.pfx -inkey aa.com.key -in aa.com.crt

echo 完成
pause

3. 以上代碼涉及到兩個配置文件:

(1) openssl.ini就是OpenSSL安裝目錄中的配置文件,原封不動的(除了文件名)

(2) aa.com.ini是多功能變數名稱配置列表,文件內容:
```
[ ext ]
subjectAltName = @dns

[ dns ]
DNS.1 = aa.com
DNS.2 = *.aa.com
DNS.3 = bb.com
DNS.4 = cc.com
DNS.5 = localhost
DNS.6 = 127.0.0.1
```

4. 測試

將根證書導入到系統受信任的根證書頒發機構裡面,將生成的pfx文件導入到iis裡面,站點綁定https,這時我電腦上彈出丟失證書鏈的提示,不過好像並沒有什麼影響。瀏覽器訪問正常的很:
功能變數名稱訪問測試

生成的證書文件

收尾

可以看到,通過OpenSSL本地已生成了支持通配符和多功能變數名稱的證書,本地https全站化測試環境搭建的證書資源算是妥了,想要什麼樣的就立馬生成什麼樣的,可以看到除了功能變數名稱,IP也是可以支持進去的。

如果要切換到線上,要簡單省錢,等到2月Let’s Encrypt就能提供完美的解決方案了,說到底還是買不起證書,我用免費的。

預告:證書搞完後,下一件已完成的事是把統計局的2017年5月發佈的新的行政區劃數據重新採集了一遍(省市區鎮數據),含數據格式化和拼音標註,整個過程用純js處理的,這個方法比較拿手,過段時間針對這個功能會單獨發一篇文章。

[接續] 可能是躺久了或者是持續坐久了的的原因吧,來三亞將近20天一直貓在一間5平米不到的小屋裡面,行李箱當桌子、床當凳子,矮了點。不過後面幾天站著還好,至少沒有屁股和腰疼的毛病,前段時間上班經歷了第一次腰疼,疼了半個月,不過自己恢復了。少坐多站,坐也要坐好,躺也要躺好。


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

-Advertisement-
Play Games
更多相關文章
  • 在整理自己的代碼的時候,考慮到我寫的代碼從一至終都是在一個cpp文件裡面。於是,想把自己的代碼中的各個模塊分離開來,以便更好地閱讀和管理。可在分離的時候出現了xxx變數已經在*.obj中定義的問題,即我定義的全局變數出現了重覆定義的現象。深究編譯鏈接的過程,發現static關鍵字的方法不可行,唯獨好... ...
  • 此篇文章為項目代碼,,,需要項目需求 ,思路分析與窗體效果請訪問:http://www.cnblogs.com/lsy131479/p/8367304.html ...
  • 此篇文章為項目需求 ,思路分析與窗體效果,,,需要相關代碼請訪問:http://www.cnblogs.com/lsy131479/p/8367314.html ...
  • 《深入.NET平臺和C#編程》內部測試題-筆試試卷 一 選擇題 1) 以下關於序列化和反序列化的描述錯誤的是( C)。 a) 序列化是將對象的狀態存儲到特定存儲介質中的過程 b) 二進位格式化器的Serialize()和Deserialize()方法可以分別用來實現序列化和反序列 化過程 解析:Bi ...
  • 項目需求: 一、語言和環境 A、實現語言 C# B、環境要求 Visual Studio 2012 二、功能要求 現使用.NET WinForms技術為居委會開發一個街道管理軟體,其中街道管理窗體界面如圖-4所示。 要求: 1、讀取提供的XML文件(詳見 \提供給學員的素材\Address.xml) ...
  • 1、調用方式上 靜態方法依賴於類,通過類.靜態方法調用;實例方法依賴於類的對象,需要創建對象後,對象.實例方法使用。 2、使用上 實例方法內部不能定義靜態變數,會出現編譯錯誤;實例方法可以直接調用靜態方法;靜態方法內部可以定義和使用實例變數,靜態方法無法直接調用實例方法(因靜態方法載入時類還沒有實例 ...
  • [DllImport("kernel32.dll", EntryPoint = "SetProcessWorkingSetSize")]public static extern int SetProcessWorkingSetSize(IntPtr process, int minSize, int... ...
  • 在.Net 4.5中,通過async和await兩個關鍵字,引入了一種新的基於任務的非同步編程模型(TAP)。在這種方式下,可以通過類似同步方式編寫非同步代碼,極大簡化了非同步編程模型。如下式一個簡單的實例: 而之前的方式是這樣的: 也許前面這個例子不足以體現async和await帶來的優越性,下麵這個例 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...