Linux三階段之十二:HTTPS安全證書訪問連接實踐配置

来源:https://www.cnblogs.com/cuiyongchao007/archive/2020/05/03/12820491.html
-Advertisement-
Play Games

十二、HTTPS安全證書訪問連接實踐配置 (一)網路安全涉及的問題 (二)網路安全涉及的問題 ①. 網路安全問題 數據機密性問題解決 ②. 網路安全問題 數據完整性問題解決 ③. 網路安全問題 身份驗證問題解決 (三)網路安全證書由來: (四) OpenSSL軟體詳細說明 第二步:生成證書文件信息 ...


十二、HTTPS安全證書訪問連接實踐配置

(一)網路安全涉及的問題

①. 網路安全問題-數據機密性問題
    傳輸的數據可能會被第三方隨時都能看到		
②. 網路安全問題-數據完整性問題
    傳輸的數據不能隨意讓任何人進行修改
③. 網路安全問題-身份驗證問題
    第一次通訊時,需要確認通訊雙方的身份正確

(二)網路安全涉及的問題

①. 網路安全問題-數據機密性問題解決

 a) 利用普通加密演算法解決機密性
利用相應演算法,對傳輸數據(明文數據)進行加密(密文數據);再利用對應演算法,將加密數據解密變為真實數據
優點:實現了數據機密傳輸,避免了明文傳輸數據的危險性。
缺點:利用加密演算法,將明文改密文,如果第三方獲得加密演算法,即可將傳輸密文再次變為明文
            
b) 利用對稱加密演算法解決機密性(重要的一種加密方式)
對稱加密演算法就好比將普通演算法的規則手冊放入到了保險柜里,只有獲取保險柜和保險柜鑰匙才能獲取《演算法手冊》
優點:密鑰加密演算法計算速度非常快;解決了普通加密演算法的安全問題
缺點:加解密過程的安全性完全依賴於密鑰,並且對稱加密密鑰是公開的,當通訊加密對象過多時,無法解決密鑰管理問題。

②. 網路安全問題-數據完整性問題解決

a) 利用單項加密演算法(全網備份數據完整性)
根據數據生成特征碼(數據指紋信息);接收數據方獲取數據信息算出特征碼,驗證是否與發送過來的特征碼一致
若特征碼一致,表示數據完整性沒被破壞;若特征碼不一致,表示數據已被破壞,直接丟棄
****************************************************************************
擴展說明:
01:不同數據的特征碼(數據指紋信息)是不可能一致的
單項加密演算法特征
· 數據輸入一樣,特征碼信息輸出必然相同
· 雪崩效應,輸入的微小改變,將造成輸出的巨大改變
· 定長輸出,無論源數據多大,但結果都是一樣的
· 不可逆的,無法根據數據指紋,還原出原來的數據信息。
****************************************************************************

優點:有效的解決了數據完整性問題
缺點:沒有考慮中間人攻擊對數據信息的影響

b) 利用單項加密演算法(加密特征碼)
利用對稱加密演算法對數據加密的同時,也對特征碼進行加密;
接收方擁有和發送方一樣的密鑰,才可以解密加密後的數據和特征碼
而中間人加密的特征碼是沒有辦法讓接收方進行解密的,所以接收方獲取不了特征碼,直接丟棄數據
****************************************************************************
擴展說明:
01:那麼對稱密鑰如何有效的讓通訊雙方獲取呢
需要進行對稱密鑰協商過程,即通過密鑰交換機制(Internet key exchange IKE)
實現密鑰交換機制的協議稱為diffie-hellman協議

③. 網路安全問題-身份驗證問題解決

a)利用非對稱密鑰加密演算法(公鑰加密演算法)
發送方建立私鑰和公鑰,將公鑰發送給接收方,從而實現發送數據方的身份驗證

讓你的母親驗證你的爸爸身份信息,你的母親就稱為證書頒發機構
公鑰信息在網站訪問過程中,被稱為證書(身份證)	

網路安全問題結論:實現網路安全性,需要解決問題的順序為
1. 解決身份驗證問題
2. 解決數據完整性問題
3. 解決數據機密性問題	

(三)網路安全證書由來:

根據上述結論可知,網路安全性最首先要解決的就是身份驗證問題;
而解決身份驗證問題,最主要的方式就是藉助私鑰和公鑰
而最主要的公鑰信息獲取就變得尤為重要;利用第三方公正者,公正公鑰信息

目前標準的證書存儲格式是x509,還有其他的證書格式,需要包含的內容為:
證書==身份證
?	公鑰信息,以及證書過期時間  
?	證書的合法擁有人信息  
?	證書該如何被使用(不用關註)   
?	CA頒發機構信息 
?	CA簽名的校驗碼	

(四) OpenSSL軟體詳細說明

獲取OpenSSL軟體的版本信息:
rpm -qa openssl
openssl version						<- 查看openssl版本信息

獲取OpenSSL配置文件信息:
/etc/pki/tls/openssl.cnf		    <- openssl配置文件,主要用於配置成私有ca時進行使用
說明:基本上openssl配置文件不需要運維過多修改配置

利用openssl軟體實現HTTPS訪問過程
實現HTTPS:

第一步:創建出一個私鑰文件(出生證明) --- 運維人員需要會

openssl genrsa 2048 >server.key			<- 創建私鑰信息,並指定私鑰的長度為2048,並將生成
的私鑰信息保存在一個文件中
openssl genrsa -out server.key 2048		<- 將私鑰信息直接進行保存,加密長度一定要放在輸出
文件後面
(umask 077;openssl genrsa -out server1024.key 1024)		
<- 利用小括弧,實現子shell功能,
臨時修改umask,使之創建的私鑰文件許可權為600

第二步:生成證書文件信息

①. 生成自簽發證書                   --- 運維人員可以自行操作
[root@NFS-server-01 ~]# openssl req -new -x509 -key server.key -out server.crt -days 365
req		<- 用於請求創建一個證書文件
new		<- 表示創建的是新的證書
x509	<- 表示定義證書的格式為標準格式
key		<- 表示調用的私鑰文件信息
out		<- 表示輸出證書文件信息
days	<- 表示證書的有效期
You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
-----
Country Name (2 letter code) [XX]:CN					<- 定義生成證書的國家
State or Province Name (full name) []:BJ				<- 定義生成證書的省份
Locality Name (eg, city) [Default City]:BJ				<- 定義生成證書的城市
Organization Name (eg, company) [Default Company Ltd]:oldboy		      <- 定義生成證書的組織
Organizational Unit Name (eg, section) []:it						      <- 定義生成證書的職能部門
Common Name (eg, your name or your server's hostname) []:oldboy.com.cn    <- 定義主機伺服器名稱
說明:此輸出信息非常重要,客戶端在獲取證書前,會利用主機名與相應伺服器之間建立連接,然後獲得證書
Email Address []:

②. 向證書頒發機構申請證書            --- ca證書版本機構完成
生成請求證書文件 (戶口本)       --- 運維人員完成
openssl req -new -key httpd.key -out httpd.csr
獲取得到證書文件 (身份證)       --- ca頒發機構完成   
省略

​ 第三步:配置網站服務,載入私鑰和證書信息

server {
server_name YOUR_DOMAINNAME_HERE;
listen 443;
ssl on;
ssl_certificate /usr/local/nginx/conf/server.crt;
ssl_certificate_key /usr/local/nginx/conf/server.key;
}

server {
listen        80;
server_name  www.etiantian.org;
rewrite ^(.*)$  https://$host$1 permanent; 
}
server {
listen       443;
server_name  www.etiantian.org;
ssl on;
ssl_certificate /server/key/server.crt;
ssl_certificate_key /server/key/server.key;
root   html/www;
index  index.html index.htm;
}

第四步:利用瀏覽器訪問測試

ssl模塊官方鏈接:http://nginx.org/en/docs/http/ngx_http_ssl_module.html


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

-Advertisement-
Play Games
更多相關文章
  • 前言 理解原型和原型鏈,有助於更好的理解JavaScript中的繼承機制。 最近比較有空,所以想寫一篇關於原型和原型鏈的文章,如寫得不好請見諒。 原型對象 無論什麼時候,只要創建了一個新函數,就會根據一組特定的規則為該函數創建一個 prototype 屬性,這個屬性指向函數的原型對象。在預設情況下, ...
  • Hi,大家好,我是明哥。 在自己學習 Golang 的這段時間里,我寫了詳細的學習筆記放在我的個人微信公眾號 《Go編程時光》,對於 Go 語言,我也算是個初學者,因此寫的東西應該會比較適合剛接觸的同學,如果你也是剛學習 Go 語言,不防關註一下,一起學習,一起成長。 我的線上博客:http://g ...
  • 一、應用系列 Docker安裝MySql完整教程、實操 使用到的mysql資料庫的安裝方案。 Docker安裝Alibaba Nacos教程 docker安裝單實例或集群的Nacos的註冊中心方便快速開始。 實現Nacos服務註冊與發現教程 通過簡單的方式進行服務註冊與調用 ******完善中 二、 ...
  • 1 簡介 之前講解的 整合 用的是 作為容器, 也是一個流行多年的老牌Java容器了。但針對不同的場景,還是會有不同的選擇,如 。`Jetty Handler Servlet`容器。更多詳情請參考 "官方文檔" 。 另外建議閱讀其它相關文章: (1) "Springboot整合https原來這麼簡單 ...
  • 1、生成的字元串每個位置都有可能是str中的一個字母或數字,需要導入的包是import java.util.Random; //length用戶要求產生字元串的長度 public static String getRandomString1(int length){ String str = "ab ...
  • FluentAspects 基於 Fluent API 的 Aop Intro 上次我們做了一個簡單的 AOP 實現示例,但是實現起來主要是基於 來做的,對於代碼的侵入性太強,於是嘗試實現基於 Fluent API 的方式來做 AOP 。 抽象 InterceptorResolver 原來獲取方法執 ...
  • @[toc] 0. 前言 本章節是IO篇的第二集,我們在上一篇中介紹了C 中IO的基本概念和一些基本方法,接下來我們介紹一下操作文件的方法。在編程的世界中,操作文件是一個很重要的技能。 1. 文件、目錄和路徑 在開始操作之前,先大概講解一下基本概念。在電腦系統中,文件是以硬碟為載體存儲在電腦上的 ...
  • 首先我們來看一下haproxy的https的配置;https是什麼我這裡就不過多闡述了,有關證書的申請相關說明請參考https://www.cnblogs.com/qiuhom-1874/p/12237944.html;在haproxy的配置文件中,我們要明確的聲明監聽某個埠,該埠需要ssl協... ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...