關于數字證書理解的簡單整理以及12306站點證書簡單分析

版權聲明:本文為博主原創文章,未經博主允許不得轉載。 https://blog.csdn.net/sundacheng1989/article/details/25540601

首先簡單理解一下什么是數字證書。這里是一篇英文文檔,描寫敘述的非常形象。形象的描寫敘述了什么是公鑰。什么是私鑰。假設確保數字證書的可靠性等。

以下。我們看一個應用"數字證書"的實例:https協議。這個協議主要用于網頁加密。


一般我們電腦的瀏覽器中都有一些受信任的證書頒發機構列表, 里邊存儲的都是一些機構的信息。這些機構都是權威的。當然能夠通過安裝軟件的方式。來添加證書頒發機構,比方中國銀行的根證書軟件,阿里巴巴的根證書軟件。

默認我們覺得這些軟件都是從官網下載的,是絕對的沒被篡改的,可靠的。簡單來講,根證書存在的意義,就是驗證偶爾從網絡上傳到瀏覽器的數字證書的真假。


當我們向一個站點發起加密訪問協議后,站點會返回一個數字證書M給你。那么我們怎么確定這個證書M沒有在途中被人篡改過呢?這里就用到了根證書。

站點返回來的數字證書都是一定格式的,記錄了站點的名稱,公鑰,以及證書頒發機構A。并且有的地方,是用這個機構A的私鑰加密過的。我們的瀏覽器會依據這個證書寫著的頒發機構A,去“受信任的證書頒發機構”列表中,找到這個機構A。然后通過本機中存儲的關于機構A的信息,去檢查這個證書有沒有被篡改過。


有人說,怎么依據根證書去驗證數字證書M有沒有被篡改過呢?事實上這里也用到了對稱加密。假設根證書對某個站點頒布了數字證書。就是用自己的私鑰加密根證書的部分內容。這個根證書頒發機構把自己的公鑰放入到軟件中。安裝到客戶計算機中。用戶收到安全證書M后。會用根證書機構的公鑰去解密這個證書。假設能解開,說明沒有被改動過。假設不能解開,說明別改動了,不安全了。



比方說,證書傳送途中。被某個組織截獲。他們想篡改。并且他們也篡改了。可是注意如今有一點,他們篡改之后是須要加密的。因為終于的瀏覽器是會用公鑰解密的。他們此時僅僅能用根證書機構的私鑰加密,終于的瀏覽器才會打開,才不會察覺。用不論什么其它的私鑰加密,瀏覽器都是打不開的。

而此時他們又沒有根證書機構的私鑰,所以就無法篡改了。一旦篡改就會被發現。

繼續回到樣例中。此時,瀏覽器收到站點的安全證書。通過根證書列表查看驗證。證明了這個證書是安全的。可靠的。

client就能夠使用證書中的server公鑰,對信息進行加密。然后與server交換加密信息。步驟例如以下圖

首先。client向server發出加密請求。

server用自己的私鑰加密網頁以后。連同本身的數字證書,一起發送給client。

client(瀏覽器)的"證書管理器",有"受信任的根證書頒發機構"列表。client會依據這張列表。查看解開數字證書的公鑰是否在列表之內。

假設數字證書記載的網址,與你正在瀏覽的網址不一致,就說明這張證書可能被冒用。瀏覽器會發出警告。

假設這張數字證書不是由受信任的機構頒發的,瀏覽器會發出還有一種警告。

假設數字證書是可靠的,client就能夠使用證書中的server公鑰。對信息進行加密。然后與server交換加密信息。



下邊是關于12306站點證書的一些看法,部分轉載。

12306站點買票。會出現證書過期或者是不可靠等提示,這里原因是什么?


大家都知道https的網頁是加密的,是須要證書的,網購火車票的網址是http://www.12306.cn/mormhweb/kyfw/。這個是http的普通網頁,沒有加密,是明文傳輸的。不須要證書。可是他里面有個iframe,也就是嵌套了還有一個網頁,地址是https://dynamic.12306.cn/otsweb/。這里就是https的了。

可是假設使用Chrome、Firefox或者IE8、9等瀏覽器都會顯示這個站點的證書有安全問題。

因為dynamic.12306.cn使用的是SRCA頒發的證書。這個證書在我們的計算機中是默認不被信任的,也就是不安全的。

Chrome:

?

IE9:

什么是SRCA?SRCA就是Sinorail Certification Authority,中文名叫中鐵數字證書認證中心,簡稱中鐵CA。

這是個鐵道部自己搞的機構,相當于是自己給自己頒發證書,當然不會被信任。

很多其它信息請見這個機構的站點。

于是,12306就在首頁顯著位置標明:為保障您順暢購票,請下載安裝根證書。

一般人假設看到這個肯定會依照要求下載安裝的。下載后解壓里面有個“SRCA根證書安裝說明手冊.doc”,這個doc格式我就先不吐槽了,還是先說說內容吧。

這個文檔一開頭就有這么一段話:

尊敬的用戶:

您如今安裝的是中鐵數字證書認證中心(中鐵CA。SRCA)的根證書,完畢這個操作能夠使您的購票體驗更為順暢,同一時候獲得一個更安全的網絡購票環境。

中鐵CA是由工業和信息化部審批通過的合法電子認證服務機構。該產品及相關操作不會對您的計算機構成危害,請您放心使用。

安裝了你的證書會使我的網絡購票更順暢更安全?我怎么不知道證書還有這種奇妙的能力?是不是Windows優化大師、360之類的軟件都應該集成一個安裝SRCA的證書的功能啊?

再看后面,“該產品及相關操作不會對您的計算機構成危害,請您放心使用。

”怎么感覺好像是此地無銀三百兩呢?

玩笑話就講到這里吧。以下來說說安裝了這個證書究竟會有什么危害。

以下因為涉及到一些password學的知識,限于篇幅和本人的表達能力。可能解釋得不是非常清晰,假設有什么不明確的地方建議學習一下這篇文章,圖文并茂,解釋得比較清晰。

假設你依照這個文檔的步驟安裝了SRCA的根證書的話。那么以后全部SRCA頒發的證書在你的電腦上都會被覺得是安全的。這有什么危害呢?首先SRCA是一個體制內的部門。所以他全然有可能會被有關部門控制。

假設有關部門利用SRCA的私鑰偽造了一個Gmail的證書,然后有關部門再通過電信運營商或者某墻攔截下來你和Gmailserver之間的全部通信,然后把自己偽造的證書發給你,因為你安裝了SRCA的根證書。你就會覺得這個證書是安全的。也就是說你就會以為你收到的內容是Gmailserver發送的。這樣有關部門就在你和Gmailserver之間充當了一個中間人的角色。這樣你和Gmailserver之間的全部加密通信就都神不知鬼不覺得被有關部門監聽了。他們就能夠得到你的郵件的內容甚至還有可能得到Gmail的password。這就是著名的中間人攻擊(MITM)。

這里僅僅是以Gmail為例,因為有關部門多次試圖獲得一些異見人士的Gmail郵件內容,就不具體說了。

說完了安裝證書的危害,那么為什么不使用VeriSign這個受信任的機構頒發的證書呢?

有些人就開始出來為鐵道部辯護了。說鐵道部不愿意花錢買證書,或者技術人員提出了要購買證書的要求可是領導不懂這些所以不允許等等。

我最開始也覺得這個是有可能的。畢竟這是在天朝。可是后來我發現https://epay.12306.cn/這個完畢訂票后用來支付的二級域名就是用的VeriSign頒發的證書。那為什么登陸賬號以及訂票不使用這個VeriSign的證書呢?

因為我實在無法找出合理的解釋,所以我僅僅好覺得是這種:鐵道部因為某個特殊的原因,希望大家在自己的電腦上面安裝SRCA的根證書,可是他自己也知道使用自簽名的證書是有危急的,只是登陸和訂票部分僅僅是涉及到用戶的隱私問題而已,即使有安全問題也無所謂的。天朝的p民本來就沒有什么隱私的。可是支付部分涉及到錢,假設出了事兒就比較麻煩。所以支付部分還是使用了VeriSign的證書。


轉載于:https://www.cnblogs.com/xfgnongmin/p/10739855.html

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

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

相關文章

Luogu3350 ZJOI2016 旅行者 最短路、分治

傳送門 題意:給出一個$N \times M$的網格圖,邊有邊權,$Q$組詢問,每組詢問$(x_1,y_1)$到$(x_2,y_2)$的最短路。$N \times M \leq 2 \times 10^4 , Q \leq 10^5$ BZOJ原題竟然沒有數據范圍 矩形的多組詢問問題考慮分治。考慮計算矩形…

Mac中安裝Node和版本控制工具nvm遇到的坑

首先說說常規的安裝 1. 下載nvm,使用nvm來管理Node版本 官方文檔 windows 版本  https://github.com/coreybutler/nvm-windows mac 版本    https://github.com/creationix/nvm#install-script 命令行 盡量不要用brew,免得掉坑 curl -o- https://raw.githubu…

幾道比較有意思的js面試題

1、[] ? !![] : ![];輸出結果是什么? 12345let val [] ? !![] : ![];console.log(val); //true://之前的錯誤解釋:[] 是一個null,做判斷則為false,false執行![]語句,結果為非空,即true//更正…

wepy - 與原生有什么不同(x.wpy)使用實例

源碼 1 <template>2 <view classmark wx:if"{{showMark}}">3 <view animation"{{animationData}}" class"animCat">4 <image src"http://osk1hpe2y.bkt.clouddn.com/18-5-30/34559443.jpg"></…

vue從入門到精通之高級篇(一)vue-router的高級用法

今天要介紹的是路由元信息&#xff0c;滾動行為以及路由懶加載這幾個的使用方法。 1.路由元信息 什么是路由元信息&#xff0c;看看官網的解釋&#xff0c;定義路由的時候可以配置 meta 字段可以匹配meta字段&#xff0c;那么我們該如何使用它&#xff0c;一個簡單的例子&…

Java 數組實現堆棧操作

class Stack {private int stck[] ; private int tos ; Stack(int size) { // 一個參數的構造參數stck new int[size] ; // 創建數組&#xff08;創建堆棧&#xff09;tos -1 ; // 空堆棧標識 -1}// 堆棧操作的特性&#xff1a;先進后出、后進先出void push(int…

re模塊

什么是正則表達式 一組特殊符號組成的表達式&#xff0c;用于描述某種規則。該應用場景生活中隨處可見。 例如&#xff1a;讓有志青年過上體面的生活&#xff0c;這里面就由規則&#xff0c;即有志青年。 正則表達式的作用&#xff0c;以及使用場景 用于從字符串中匹配滿足某種…

CSS實現div梯形分割

原理 使用的border邊框屬性結合svg 轉換 詳見代碼 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>css實現div邊框斜角</title><style type"text/css"> .labels {display: i…

算法學習——決策單調性優化DP

update in 2019.1.21 優化了一下文中年代久遠的代碼 的格式…… 什么是決策單調性&#xff1f; 在滿足決策單調性的情況下&#xff0c;通常決策點會形如1111112222224444445555588888..... 即不可能會出現后面點的決策點小于前面點的決策點這種情況。 那么這個性質應該如何使用…

SVG畫一個箭頭

參考菜鳥手冊&#xff1a; https://www.runoob.com/svg/svg-tutorial.html 打開菜鳥中的在線工具 在可視化截圖拖拉元素繪制箭頭 點擊command U 查看源碼 將源碼拷入html代碼中&#xff0c;查看效果 最后&#xff0c;貼出源碼供大家參考 <!DOCTYPE html> <…

HP Instant Information

HP Instant Information before HP-UX 11i v3 《管理系統和工作組&#xff1a;HP-UX系統管理員指南》 After HP-UX 11i v3 《HP-UX系統管理指南》(由多個文檔組成的文檔集) 《HP-UX系統管理員指南&#xff1a;概述》 《HP-UX系統管理員指南&#xff1a;配置管理》 《HP-UX系統管…

CodeForces 258D Little Elephant and Broken Sorting(期望)

CF258D Little Elephant and Broken Sorting 題意 題意翻譯 有一個\(1\sim n\)的排列&#xff0c;會進行\(m\)次操作&#xff0c;操作為交換\(a,b\)。每次操作都有\(50\%\)的概率進行。 求進行\(m\)次操作以后的期望逆序對個數。 \(n,m\le 1000\) 輸入輸出格式 輸入格式&#x…

記一次vue項目yarn打包環境配置失效的解決方案

項目中使用到了yarn打包工程&#xff0c;主要有以下幾個命名。 # build for production with minification yarn run build# build for production and view the bundle analyzer report yarn run build --report# 自定義API地址 baseurl"http://127.0.0.1:8080/api/&quo…

數字簽名與HTTPS詳解

因為HTTP協議本身存在著明文傳輸、不能很好的驗證通信方的身份和無法驗證報文的完整性等一些安全方面的確點&#xff0c;所以才有了HTTPS的缺陷。HTTPS確切的的說不是一種協議&#xff0c;而是HTTP SSL (TSL)的結合體。HTTP報文經過SSL層加密后交付給TCP層進行傳輸。SSL(安全套…

[BZOJ4320][ShangHai2006]Homework(根號分治+并查集)

對于<sqrt(300000)的詢問&#xff0c;對每個模數直接記錄結果&#xff0c;每次加入新數時暴力更新每個模數的結果。 對于>sqrt(300000)的詢問&#xff0c;枚舉倍數&#xff0c;每次查詢大于等于這個倍數的最小數是多少&#xff0c;這個操作通過將詢問逆序使用并查集支持。…

VScode 結局插件prettier和vetur格式化沖突

先上配置代碼 {"workbench.iconTheme": "vscode-icons","workbench.startupEditor": "newUntitledFile","workbench.colorTheme": "One Dark Pro","editor.fontSize": 14,"editor.tabSize":…

WPF效果(GIS三維續篇)

去年這個時候簡單的摸索了一下三維的GIS相關的東西,也就是僅僅玩耍了一把,這次來點真正用的上的干貨效果效果&#xff1a; 1、加載自定義百度樣式的瓦片效果 2、加載自定義百度樣式的縮放效果 3、快速手動進去咱的大帝都 4、加載海量Mark效果 5、加載海量Mark和簡單模型效果 6、…

vue 表單 驗證 async-validator

1、使用插件async-validator async-validator 地址&#xff1a;https://github.com/yiminghe/async-validator 2、示例&#xff08;vueelement-ui&#xff09; <el-form :model"numberValidateForm" ref"numberValidateForm" label-width"100px&qu…

[19/04/23-星期二] GOF23_創建型模式(工廠模式、抽象工廠模式)

一、工廠模式(分為&#xff1a;簡單工廠模式、工廠方法模式、抽象工廠模式) 實現了創建者和調用者的分離 核心本質&#xff1a;1、實例化對象&#xff0c;用工廠方法代替new操作&#xff1b;2、將選擇實現類、創建對象統一管理和控制&#xff0c;從而將調用者跟實現類解耦。 簡…

Chrome瀏覽器12px問題-webkit-text-size-adjust: none 已失效的解決方案

對于早期的chrome, 如果要想顯示12px以下的字體&#xff0c;一般通用的方案都是在對應的元素中添加 div {-webkit-text-size-adjust: none; }但是我今天遇到的需求&#xff0c;添加了之后沒有反應&#xff0c;而且瀏覽就根本不支持這種寫法。 在網上看到了博客《Chrome瀏覽器…