1. <ul id="0c1fb"></ul>

      <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
      <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区

      RELATEED CONSULTING
      相關(guān)咨詢
      選擇下列產(chǎn)品馬上在線溝通
      服務(wù)時間:8:30-17:00
      你可能遇到了下面的問題
      關(guān)閉右側(cè)工具欄

      新聞中心

      這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
      互聯(lián)網(wǎng)中安全和加密的示例分析-創(chuàng)新互聯(lián)

      這篇文章主要介紹互聯(lián)網(wǎng)中安全和加密的示例分析,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!

      成都創(chuàng)新互聯(lián)始終堅持【策劃先行,效果至上】的經(jīng)營理念,通過多達(dá)10余年累計超上千家客戶的網(wǎng)站建設(shè)總結(jié)了一套系統(tǒng)有效的網(wǎng)絡(luò)營銷推廣解決方案,現(xiàn)已廣泛運用于各行各業(yè)的客戶,其中包括:成都加固等企業(yè),備受客戶贊美。

      安全和加密

      安全機制

      信息安全防護(hù)的目標(biāo)
      保密性      Confidentiality
      完整性      Integrity
      可用性      Usability
      可控制性    Controlability
      不可否認(rèn)性  Non-repudiation
      
      安全防護(hù)環(huán)節(jié)
      物理安全:各種設(shè)備/主機、機房環(huán)境
      系統(tǒng)安全:主機或設(shè)備的操作系統(tǒng)
      應(yīng)用安全:各種網(wǎng)絡(luò)服務(wù)、應(yīng)用程序
      網(wǎng)絡(luò)安全:對網(wǎng)絡(luò)訪問的控制、防火墻規(guī)則
      數(shù)據(jù)安全:信息的備份與恢復(fù)、加密解密
      管理安全:各種保障性的規(guī)范、流程、方法

      安全

      安全: STRIDE
      Spoofing 假冒 
          發(fā)郵件冒充
             telnet 127.0.0.1 25
             25端口為郵件工作端口,連接的軟件為Postfix,監(jiān)聽ESMTP,對應(yīng)25端口
             helo magedu.com
             mail from(以誰的身份發(fā)送):mayun@alibaba.com
             rcpt to(發(fā)送給誰):wang
             data(內(nèi)容)
             以.結(jié)束
      dig命令可以做名字解析
        -t 可以查到郵件服務(wù)器的地址,郵件地址的類型為mx
      例: 
         dig  -t mx 163.com
         telnet 163mx00.mxmail.netease.com 25 即可連通網(wǎng)易郵箱
      Tampering 篡改
      Repudiation 否認(rèn)
      Information Disclosure 信息泄漏 (密碼泄露)
      Denial of Service 拒絕服務(wù)
      Elevation of Privilege 提升權(quán)限

      安全設(shè)計基本原則

      使用成熟的安全系統(tǒng)
      以小人之心度輸入數(shù)據(jù)
      外部系統(tǒng)是不安全的
      最小授權(quán)
      減少外部接口
      缺省使用安全模式
      安全不是似是而非
      從STRIDE思考
      在入口處檢查
      從管理上保護(hù)好你的系統(tǒng)

      安全算法

      常用安全技術(shù)
          認(rèn)證  
          授權(quán)
          審計
          安全通信
      
      加密算法和協(xié)議
          對稱加密
          公鑰加密
          單向加密
          認(rèn)證協(xié)議

      對稱加密算法

      對稱加密:加密和解密使用同一個密鑰 key1==key2
      data明文 --->加密(key1)--->data'密文--->(key2)--->data
      
          DES:Data Encryption Standard,56bits
               (密鑰長度56位,7個字節(jié),逐漸淘汰,不太.安全)
          3DES:將DES加密三次
          AES:Advanced (128, 192, 256bits)
      
          Blowfish,Twofish 商用
          IDEA,RC6,CAST5
      
      特性:
          1、加密、解密使用同一個密鑰,效率高
          2、將原始數(shù)據(jù)分割成固定大小的塊,逐個進(jìn)行加密
      缺陷:
          1、密鑰過多
          2、密鑰分發(fā)
          3、數(shù)據(jù)來源無法確認(rèn)

      非對稱加密算法

      key1 != key2
      公鑰加密:密鑰是成對出現(xiàn)
          公鑰:公開給所有人;public key
          私鑰:自己留存,必須保證其私密性;secret key
      特點:用公鑰加密數(shù)據(jù),只能使用與之配對的私鑰解密;反之亦然
      功能:
          數(shù)字簽名:主要在于讓接收方確認(rèn)發(fā)送方身份
          對稱密鑰交換:發(fā)送方用對方的公鑰加密一個對稱密鑰后發(fā)送給對方
          數(shù)據(jù)加密:適合加密較小數(shù)據(jù)
      缺點:密鑰長,加密解密效率低下
      算法:
          RSA(加密,數(shù)字簽名)
          DSA(數(shù)字簽名)
          ELGamal

      非對稱加密

      public key 公鑰:公開
      secret(private) key 私鑰:私有 
      
      基于一對公鑰/密鑰對
          ?用密鑰對中的一個加密,另一個解密
      實現(xiàn)加密:
          ?接收者
              生成公鑰/密鑰對:P和S
              公開公鑰P,保密密鑰S
          ?發(fā)送者
              使用接收者的公鑰來加密消息M
              將P(M)發(fā)送給接收者
          ?接收者
              使用密鑰S來解密:M=S(P(M))
      
      alice(Pa,Sa)--->bob(Pb,Sb)
      公鑰和私鑰成對使用,alice的公鑰私鑰成對使用,bob的公鑰私鑰成對使用
          一個數(shù)據(jù)用對應(yīng)的公鑰加密,就必須用對應(yīng)的成對的私鑰解密
          反過來,如果用對應(yīng)的私鑰加密,就必須用成對的公鑰解密
      
      理解:如果用alice的公鑰(Pa)加密,就必須用alice的私鑰(Sa)解密
            如果用alice的私鑰(Sa)加密,就必須用alice的公鑰(Pa)解密

      非對稱加密

      實現(xiàn)數(shù)字簽名:    私鑰加密 = 數(shù)字簽名(確認(rèn)數(shù)據(jù)來源)
          ?發(fā)送者
              生成公鑰/密鑰對:P和S
              公開公鑰P,保密密鑰S
              使用密鑰S來加密消息M
              發(fā)送給接收者S(M)
      ?接收者
              使用發(fā)送者的公鑰來解密M=P(S(M))
      
      結(jié)合簽名和加密
      分離簽名
      rpm -K /misc/cd/Packages/tree-1.6.0-10.e17.x86.64.rpm 檢查數(shù)據(jù)來源是否安全
      每個公司發(fā)布包的時候都有數(shù)字簽名,進(jìn)行了私鑰加密,
      如果想要確定包的數(shù)據(jù)來源,就必須使用公鑰,進(jìn)行解密
      驗證包是由哪家公司發(fā)布的,系統(tǒng)默認(rèn)沒有公鑰,需要導(dǎo)入
      
      rpm --import /misc/cd/RPM-GPG-KEY-CentOS-7  導(dǎo)入公鑰
      獲得公鑰以后即可驗證包的數(shù)字簽名
      
      /etc/yum.repos.d/base.repo yum源配置文件中
      gpgcheck=1 安裝某個包的時候要驗證包的數(shù)子簽名,=0則不檢查 
      將密鑰的路徑寫進(jìn)配置文件,第一次安裝包的時候,會導(dǎo)入密鑰
      
      導(dǎo)入公鑰的兩種方式:
      1. rpm --import   導(dǎo)入公鑰
      
      2.在yum源配置文件中,添加gpgkey路徑

      RSA和DSA

      RSA:公鑰加密算法是1977年由Ron Rivest、Adi Shamirh和LenAdleman在(美國麻省理工學(xué)院)開發(fā)的,
      RSA取名來自開發(fā)他們?nèi)叩拿郑蟪闪SA數(shù)據(jù)安全有限公司。
      RSA是目前最有影響力的公鑰加密算法,它能夠抵抗到目前為止已知的所有密碼***,已被ISO推薦為公鑰數(shù)據(jù)加密標(biāo)準(zhǔn)。
      RSA算法基于一個十分簡單的數(shù)論事實:將兩個大素數(shù)相乘十分容易,但那時想要對其乘積進(jìn)行因式分解卻極其困難,
      因此可以將乘積公開作為加密密鑰
      
      DSA (Digital Signature Algorithm):1991年7月26日提交,并歸屬于David W. Kravitz前NSA員工,
      DSA是Schnorr和ElGamal簽名算法的變種,被美國NIST作為SS(DigitalSignature Standard),
      DSA是基于整數(shù)有限域離散對數(shù)難題的,其安全性與RSA相比差不多。
      DSA只是一種算法,和RSA不同之處在于它不能用作加密和解密,也不能進(jìn)行密鑰交換,只用于簽名,它比RSA要快很多
      
      DSA只能實現(xiàn)數(shù)字簽名,無法實現(xiàn)數(shù)據(jù)加密

      單向散列(單向hash算法)

      將任意數(shù)據(jù)縮小成固定大小的“指紋”
          ?任意長度輸入
          ?固定長度輸出
          ?若修改數(shù)據(jù),指紋也會改變(“不會產(chǎn)生沖突”)
          ?無法從指紋中重新生成數(shù)據(jù)(“單向”)
      
      功能:數(shù)據(jù)完整性
      
      常見算法
          md5: 128bits、sha1: 160bits、sha224 、sha256、sha384、sha512
      
      常用工具
          ?md5sum | sha1sum [ --check ] file
              md5sum fstab > fstab.md5
              md5sum -checkfstab.md5 檢測md5值 
          ?openssl、gpg
          ?rpm -V  檢測包是否發(fā)生修改
      hash(data) => digest 摘要 
      hash算法得到的摘要,不可逆推回數(shù)據(jù),單向的
      數(shù)據(jù)如果不變,通過hash得到的摘要digest也是固定的
      如果數(shù)據(jù)發(fā)生改變,得到的摘要則會發(fā)生改變
      結(jié)論:
      數(shù)據(jù)不同,摘要必不同
      摘要相同,摘要必相同
      
      固定的hash算法,得到的摘要也是固定大小(長度)
      md5  128bit  數(shù)據(jù)不同128bit的值不同
      
      hash算法 經(jīng)常用來做數(shù)據(jù)完整性的檢查,檢查數(shù)據(jù)是否被更改

      數(shù)字簽名

      互聯(lián)網(wǎng)中安全和加密的示例分析

      原文件利用hash運算(md5)得到128bit的數(shù)字摘要(hash值)
      使用Sa加密得到的hash值,形成數(shù)字簽名,將原文附加在后面,得到完整的新的文件
      使用Pb加密生成的新文件,得到密文,發(fā)送給對方  
      
      確保無法被第三方截獲,并確認(rèn)數(shù)據(jù)來源
      
      使用Sb解密收到的密文,得到數(shù)字簽名和原文件
      對原文件做hash運算(md5),得到128bit的數(shù)字摘要
      使用Pa解密數(shù)字簽名,得到發(fā)送來的數(shù)字摘要
      對比兩個數(shù)字摘要是否一致
      一致,則原文沒有被篡改
      
      即實現(xiàn)的數(shù)據(jù)的安全傳輸,又實現(xiàn)了數(shù)據(jù)來源的確認(rèn)

      綜合對稱加密,非對稱加密,和單向散列三種算法,實現(xiàn)加密

      key{data +Sa[hash(data)]}+Pb(key) ==>
      
      將數(shù)據(jù)做hash運算,得到數(shù)字摘要(digest)       # 單向散列hash算法 
      使用a的私鑰將數(shù)字摘要(digest)做數(shù)字簽名     # 非對稱加密算法
      使用對稱加密將原文數(shù)據(jù)和數(shù)字簽名進(jìn)行加密    # 對稱加密算法
      將對稱密鑰,使用b的公鑰進(jìn)行加密
      
      對方可以使用Sb解開對稱密鑰,得到對稱密鑰中的數(shù)據(jù)

      應(yīng)用程序:RPM

      文件完整性的兩種實施方式
      被安裝的文件
          ?MD5單向散列
          ?rpm --verify package_name (or -V)
      發(fā)行的軟件包文件
          ?GPG公鑰簽名
          ?rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-redhat*
          ?rpm --checksig pakage_file_name (or -K)

      密鑰交換

      密鑰交換:IKE( Internet Key Exchange )
          公鑰加密:
          DH (Deffie-Hellman):生成會話密鑰,由惠特菲爾德·迪菲(Bailey Whitfield Diffie)和馬丁·赫爾曼(Martin Edward Hellman)在1976年發(fā)表
      參看:https://en.wikipedia.org/wiki/Diffie%E2%80%93Hellman_key_exchange
      
      DH:
      1>A: g,p 協(xié)商生成公開的整數(shù)g, 大素數(shù)p
        B: g,p
      
      2>A:生成隱私數(shù)據(jù) :a (aA:計算得出 [(g^b%p)^a] %p = g^ab%p,生成為密鑰
        B:計算得出 [(g^a%p)^b] %p = g^ab%p,生成為密鑰

      使用gpg實現(xiàn)對稱加密

      對稱加密file文件
          gpg -c file  對文件進(jìn)行加密
          ls file.gpg  生成加密文件
      在另一臺主機上解密file
          gpg -o file -d file.gpg

      使用gpg工具實現(xiàn)公鑰加密

      在hostB主機上用公鑰加密,在hostA主機上解密
      在hostA主機上生成公鑰/私鑰對
          gpg --gen-key
      在hostA主機上查看公鑰
          gpg --list-keys
      在hostA主機上導(dǎo)出公鑰到wang.pubkey
          gpg -a --export -o wang.pubkey
      從hostA主機上復(fù)制公鑰文件到需加密的B主機上
          scp wang.pubkey hostB:

      使用gpg工具實現(xiàn)公鑰加密

      在需加密數(shù)據(jù)的hostB主機上生成公鑰/私鑰對
          gpg --list-keys
          gpg --gen-key
      在hostB主機上導(dǎo)入公鑰
          gpg --import wang.pubkey
          gpg --list-keys
      用從hostA主機導(dǎo)入的公鑰,加密hostB主機的文件file,生成file.gpg
          gpg -e -r wangxiaochun file
          file file.gpg

      使用gpg工具實現(xiàn)公鑰加密

      復(fù)制加密文件到hostA主機
          scp fstab.gpg hostA:
      在hostA主機解密文件
          gpg -d file.gpg
          gpg -o file -d file.gpg
      刪除公鑰和私鑰
          gpg --delete-keys wangxiaochun
          gpg --delete-secret-keys wangxiaochun

      中間人

      互聯(lián)網(wǎng)中安全和加密的示例分析

      CA和證書

      PKI:Public Key Infrastructure
          簽證機構(gòu):CA(Certificate Authority)
          注冊機構(gòu):RAc 中間人,他會幫你把申請的證書提交給真正的CA
          證書吊銷列表:CRL
          證書存取庫:
      X.509:定義了證書的結(jié)構(gòu)以及認(rèn)證協(xié)議標(biāo)準(zhǔn)
          版本號           主體公鑰
          序列號           CRL分發(fā)點
          簽名算法         擴展信息
          頒發(fā)者           發(fā)行者簽名
          有效期限
          主體名稱

      證書獲取

      證書類型:
          證書授權(quán)機構(gòu)的證書
          服務(wù)器
          用戶證書
      獲取證書兩種方法:
      ?使用證書授權(quán)機構(gòu)
          生成證書請求(csr)
          將證書請求csr發(fā)送給CA
          CA簽名頒發(fā)證書
      ?自簽名的證書
          自已簽發(fā)自己的公鑰

      互聯(lián)網(wǎng)中安全和加密的示例分析

      A將公鑰Pa發(fā)送給CA,CA驗證身份,成功會用自己的私鑰簽名公鑰Sca(Pa)
      并追加信息:CA的信息,A的信息和有限期 得到證書,將證書發(fā)送給A,A從而有了證書
      A和B事先已經(jīng)拿到了CA的公鑰

      互聯(lián)網(wǎng)中安全和加密的示例分析
      所有的機器都必須有rootCA的公鑰,rootCA進(jìn)行自簽名Srootca(Prootca)+Prootca,自己證明自己

      安全協(xié)議

      SSL:Secure Socket Layer,TLS: Transport Layer Security
          1995:SSL 2.0 Netscape
          1996:SSL 3.0
          1999:TLS 1.0 國際規(guī)范
          2006:TLS 1.1 IETF(Internet工程任務(wù)組) RFC 4346
          2008:TLS 1.2 當(dāng)前使用
          2015:TLS 1.3
          功能:機密性,認(rèn)證,完整性,重放保護(hù)
      
      兩階段協(xié)議,分為握手階段和應(yīng)用階段
          握手階段(協(xié)商階段):客戶端和服務(wù)器端認(rèn)證對方身份(依賴于PKI體系,利用數(shù)字證書進(jìn)行身份認(rèn)證),并協(xié)商通信中使用的安全參數(shù)、密碼套件以及主密鑰。后續(xù)通信使用的所有密鑰都是通過MasterSecret生成
          應(yīng)用階段:在握手階段完成后進(jìn)入,在應(yīng)用階段通信雙方使用握手階段協(xié)商好的密鑰進(jìn)行安全通信

      SSL/TLS

      互聯(lián)網(wǎng)中安全和加密的示例分析

      SSL/TLS工作在應(yīng)用層和傳輸層中間,把應(yīng)中層數(shù)據(jù)加密,到達(dá)傳輸層的時候已經(jīng)被加密了

      SSL/TLS

      Handshake協(xié)議:包括協(xié)商安全參數(shù)和密碼套件、服務(wù)器身份認(rèn)證(客戶端身份認(rèn)證可選)、密鑰交換
      ChangeCipherSpec 協(xié)議:一條消息表明握手協(xié)議已經(jīng)完成
      Alert 協(xié)議:對握手協(xié)議中一些異常的錯誤提醒,分為fatal和warning兩個級別,fatal類型錯誤會直接中斷SSL鏈接,而warning級別的錯誤SSL鏈接仍可繼續(xù),只是會給出錯誤警告
      Record 協(xié)議:包括對消息的分段、壓縮、消息認(rèn)證和完整性保護(hù)、加密等
      HTTPS 協(xié)議:就是“HTTP 協(xié)議”和“SSL/TLS 協(xié)議”的組合。HTTP over SSL”或“HTTP over TLS”,對http協(xié)議的文本數(shù)據(jù)進(jìn)行加密處理后,成為二進(jìn)制形式傳輸

      HTTPS結(jié)構(gòu)

      互聯(lián)網(wǎng)中安全和加密的示例分析

      HTTPS工作過程

      互聯(lián)網(wǎng)中安全和加密的示例分析

      OpenSSL

      OpenSSL:開源項目
      三個組件:
          openssl:多用途的命令行工具,包openssl
          libcrypto:加密算法庫,包openssl-libs
          libssl:加密模塊應(yīng)用庫,實現(xiàn)了ssl及tls,包nss
      openssl命令:
          兩種運行模式:交互模式和批處理模式
          openssl version:程序版本號
          標(biāo)準(zhǔn)命令、消息摘要命令、加密命令
          標(biāo)準(zhǔn)命令:enc, ca, req, ...

      openssl命令

      對稱加密:
          工具:openssl enc, gpg
          算法:3des, aes, blowfish, twofish
      enc命令:
      幫助:man enc
      加密:
      openssl enc -e -des3 -a -salt -in testfile -out testfile.cipher
      解密:
      openssl enc -d -des3 -a -salt –in testfile.cipher -out testfile
      openssl ?
      
      -a base64編碼
      salt 鹽:將密碼順序打亂,隨機生成(也可指定),再進(jìn)行加密
      -in 跟加密文件
      -out 跟輸出結(jié)果
      例:加密
      openssl enc -e -des3 -a -salt -in f1.txt -out f1.txt.enc

      openssl命令

      單向加密:
      工具:md5sum, sha1sum, sha224sum,sha256sum…
          openssl dgst
      dgst命令:
          幫助:man dgst
          openssl dgst -md5 [-hex默認(rèn)] /PATH/SOMEFILE
          openssl dgst -md5 testfile   生成摘要
          md5sum /PATH/TO/SOMEFILE
      MAC: Message Authentication Code,單向加密的一種延伸應(yīng)用,用于實現(xiàn)網(wǎng)絡(luò)通信中保證所傳輸數(shù)據(jù)的完整性機制
      CBC-MAC
          HMAC:使用md5或sha1算法
      
      生成用戶密碼:
          passwd命令:
          幫助:man sslpasswd
          openssl passwd -1 -salt SALT(最多8位)
          openssl passwd -1 –salt centos
      
      生成隨機數(shù):
          幫助:man sslrand
          openssl rand -base64|-hex NUM
          NUM: 表示字節(jié)數(shù),使用-hex,每個字符為十六進(jìn)制,相當(dāng)于4位二進(jìn)制,出現(xiàn)的字符數(shù)為NUM*2
      
      公鑰加密:
          算法:RSA, ELGamal
          工具:gpg, openssl rsautl(man rsautl)
      數(shù)字簽名:
          算法:RSA, DSA, ELGamal
      密鑰交換:
          算法:dh
          DSA:Digital Signature Algorithm
          DSS:Digital Signature Standard
          RSA:

      openssl命令

      生成密鑰對兒:man genrsa  生成RSA公鑰私鑰對
      生成私鑰
          openssl genrsa -out /PATH/TO/PRIVATEKEY.FILE NUM_BITS
                          輸出一個私鑰文件,要求指定私鑰程度(位數(shù))
          (umask 077; openssl genrsa –out test.key –des 2048) 使用對稱密鑰生成口令
          例: (umask 066;openssl genrsa -out app.key -des 1024)
               -des 生成密鑰的的密碼,忘記無法破解,可以重新生成
      
          openssl rsa -in test.key –out test2.key 將加密key解密
              例:openssl rsa -in app.key  -out app1.key
      
      從私鑰中提取出公鑰
          openssl rsa -in PRIVATEKEYFILE –pubout –out PUBLICKEYFILE
          openssl rsa –in test.key –pubout –out test.key.pub  
              例:openssl rsa -in app.key -pubout -out app.key.pub
      
      隨機數(shù)生成器:偽隨機數(shù)字
          鍵盤和鼠標(biāo),塊設(shè)備中斷
          /dev/random:僅從熵池返回隨機數(shù);隨機數(shù)用盡,阻塞
          /dev/urandom:從熵池返回隨機數(shù);隨機數(shù)用盡,會利用軟件生成偽隨機數(shù),非阻塞

      OpenSSL

      PKI:Public Key Infrastructure
          CA
          RA
          CRL
          證書存取庫
      建立私有CA:
          OpenCA
          openssl
      證書申請及簽署步驟:
          1、生成申請請求
          2、RA核驗
          3、CA簽署
          4、獲取證書

      創(chuàng)建CA和申請證書

      創(chuàng)建私有CA:
          openssl的配置文件:/etc/pki/tls/openssl.cnf
          三種策略:match    匹配
                    optional 可選
                    supplied 提供
      
          match:要求申請?zhí)顚懙男畔⒏鶦A設(shè)置信息必須一致
          optional:可有可無,跟CA設(shè)置信息可不一致
          supplied:必須填寫這項申請信息,
      
      1、創(chuàng)建所需要的文件
          touch /etc/pki/CA/index.txt 生成證書索引數(shù)據(jù)庫文件
          echo 01 > /etc/pki/CA/serial 指定第一個頒發(fā)證書的序列號
      
      2、 CA自簽證書
          生成私鑰
          cd /etc/pki/CA/
          (umask 066; openssl genrsa -out private/cakey.pem 2048)
      
      生成自簽名證書
          openssl req -new -x509 -key /etc/pki/CA/private/cakey.pem
          -days 3650 -out /etc/pki/CA/cacert.pem
      選項說明:
          -new: 生成新證書簽署請求
          -x509:專用于CA生成自簽證書
          -key: 生成請求時用到的私鑰文件
          -days n:證書的有效期限
          -out /PATH/TO/SOMECERTFILE: 證書的保存路徑
      
      3、頒發(fā)證書
      在需要使用證書的主機生成證書請求
          給web服務(wù)器生成私鑰
          (umask 066; openssl genrsa –out /data/test.key 2048)
          生成證書申請文件
          openssl req -new -key /data/test.key -out /data/test.csr
      
      將證書請求文件傳輸給CA
      CA簽署證書,并將證書頒發(fā)給請求者
          openssl ca -in /tmp/test.csr –out /etc/pki/CA/certs/test.crt -days 100
          注意:默認(rèn)要求 國家,省,公司名稱三項必須和CA一致
      
      查看證書中的信息:
          openssl x509 -in /PATH/FROM/CERT_FILE -noout -text|issuer|subject|serial|dates
          openssl ca -status SERIAL 查看指定編號的證書狀態(tài)
      
      4、吊銷證書
          在客戶端獲取要吊銷的證書的serial
          openssl x509 -in /PATH/FROM/CERT_FILE -noout -serial -subject
      
      在CA上,根據(jù)客戶提交的serial與subject信息,對比檢驗是否與index.txt文件中的信息一致,吊銷證書:
      openssl ca -revoke /etc/pki/CA/newcerts/SERIAL.pem
      
      指定第一個吊銷證書的編號,注意:第一次更新證書吊銷列表前,才需要執(zhí)行
          echo 01 > /etc/pki/CA/crlnumber
      更新證書吊銷列表
          openssl ca -gencrl -out /etc/pki/CA/crl.pem
      查看crl文件:
          openssl crl -in /etc/pki/CA/crl.pem -noout -text

      搭建CA架構(gòu)實操

      實驗前準(zhǔn)備:
      1.SELINUX關(guān)閉
      2.IPTAB關(guān)閉
      3.時間校驗
      
      使用openssl搭建CA
      搭建完成用戶向CA申請證書 
      
      vim /etc/pki/tls/openssl.cnf   文件詳細(xì)配置
      openssl的范例配置文件
      一臺電腦可以搭建多個CA
      
      [ ca ]            #為默認(rèn)CA
      default_ca      = CA_default 
      
      [ CA_default ]   #定義默認(rèn)CA的相關(guān)信息
      
      dir             = /etc/pki/CA       # 默認(rèn)CA中相關(guān)數(shù)據(jù)的存放路徑,dir為變量指的路徑
      certs           = $dir/certs        # 存放發(fā)布的證書
      crl_dir         = $dir/crl          # 存放證書吊銷的列表的文件
      database        = $dir/index.txt    # 存放索引,數(shù)據(jù)庫 (需要手工創(chuàng)建)
      
      new_certs_dir   = $dir/newcerts     # 存放新證書路徑,新頒發(fā)的證書,存放在此目錄
      
      certificate     = $dir/cacert.pem   # CA自己的證書,rootCA只能自簽名
      serial          = $dir/serial       # 當(dāng)前序列號,每頒發(fā)一個證書都要給它加編號,
                                          # 下一個證書頒發(fā)的編號到幾了,寫到此文件
                                          # 需要手動創(chuàng)建 
      crlnumber       = $dir/crlnumber    # 證書吊銷列表的編號
      
      crl             = $dir/crl.pem           # 證書吊銷列表的文件存放的路徑
      private_key     = $dir/private/cakey.pem # CA私鑰存放路徑
      RANDFILE        = $dir/private/.rand     # 隨機數(shù)
      
      default_days    = 365                   # 證書默認(rèn)有效期
      default_crl_days= 30                    # CRL吊銷列表有效值
      default_md      = sha256                # 默認(rèn)hash算法
      preserve        = no
      
      policy          = policy_match          #頒發(fā)證書的策略
      
      [ policy_match ]    定義頒發(fā)證書的策略
      
      搭建CA的時候,需要提交CA的相關(guān)信息
      countryName             = match         # 國家  
      stateOrProvinceName     = match         # 省份
      organizationName        = match         # 組織(公司名)
      organizationalUnitName  = optional      # 部門
      commonName              = supplied      # 服務(wù)器名稱或網(wǎng)站域名
      emailAddress            = optional      # 郵箱
      
      國家,省份,組織 三項申請用戶必須和CA保持一致
      
      [ policy_anything ]  可選,可一樣可不一樣
      CA服務(wù)器
      
      1.創(chuàng)建所需的文件
        touch /etc/pki/CA/index.txt 生成證書索引數(shù)據(jù)庫文件
        echo 01 > /etc/pki/CA/serial 指定第一個頒發(fā)證書的序列號
      
      2.CA自簽證書,生成私鑰
        cd /etc/pki/CA/
        (umask 066;openssl genrsa -out private/cakey.pem 2048) #生成私鑰文件
      
      3.利用私鑰,給自己生成一個自簽名的證書
        openssl req -new -x509 -key private/cakey.pem -out cacert.pem -days 3650
        req   表示申請 
        -new  新證書
        -x509 加x509    表示自簽名,不加表示普通證書
        -key  private/cakey.pem  指定私鑰
        -out  cacert.pem         生成的證書路徑
        -days 3650    有效期
      
        寫入國家兩個字符:CN
        省份:beijing
        城市:beijing
        公司:adong
        部門:devops
        服務(wù)器名稱:ca.adong.com
        郵箱:...
      
       用戶申請證書
       1.生成私鑰
         cd /data/app
         (umask 077;openssl genrsa -out app.key 1025)
      
       2.利用私鑰生成證書申請文件
         openssl req -new -key app.key -out app.csr
      
         申請內(nèi)容 國家,省份和公司必須和CA保持一致
         國家:CN
         省份:beijing 
         城市:bj
         公司:adong
         部門:devops
         服務(wù):app.adong.com
         ...
      
       3.將用戶申請的證書文件上傳到CA服務(wù)器
         scp app.csr root@192.168.38.100:/etc/pki/CA
      
       4.CA給用戶頒發(fā)證書
         openssl ca -in app.csr -out certs/app.crt -day 100
         ca 頒發(fā)證書
         -in app.csr 證書申請文件
         -out certs/app.crt 最終生成的證書,放在/etc/pki/CA/certs目錄下  (crt證書文件)
      
         確定提交信息,是否正確,正確y回車即可
      
       5.驗證證書是否有效
         openssl ca -status 01
          Using configuration from /etc/pki/tls/openssl.cnf
          01=Valid (V)  #V表示有效
      系統(tǒng)默認(rèn)不允許一個用戶申請多個證書
      
      cat /etc/pki/CA/index.txt.attr
      unique_subject = yes  #唯一的申請主題
                            #意思是一個主機只能申請一個證書
      改為no,即可申請多個證書
      
      在CA主機申請證書
      (umask 077;openssl genrsa -out app2.key 1024)
      openssl req -new -key app2.key -out app2.csr
      openssl ca -in app2.csr -out /etc/pki/CA/certs/app2.crt -days 100
      
      cat /etc/pki/CA/index.txt
      V   191210091002Z       01  unknown /C=CN/ST=beijing/O=adong/OU=devops/CN=app.adong.com
      V   191210111559Z       02  unknown /C=CN/ST=beijing/O=adong/OU=devops/CN=ca.app2.com
      
      吊銷證書
      openssl ca -revoke /etc/pki/CA/newcerts/02.pem
      
      cat /etc/pki/CA/index.txt
      V   191210091002Z       01  unknown /C=CN/ST=beijing/O=adong/OU=devops/CN=app.adong.com
      R   191210111559Z   190901111924Z   02  unknown /C=CN/ST=beijing/O=adong/OU=devops/CN=ca.app2.com
      
      或者使用命令驗證
      openssl ca -status 02
      Using configuration from /etc/pki/tls/openssl.cnf
      02=Revoked (R)
      
      被吊銷的證書改為Revokde(R)
      
      需要生成公開的證書吊銷列表,通知其他用戶此證書已被吊銷
      
      創(chuàng)建證書吊銷列表目錄
      echo 01 > /etc/pki/CA/crlnumber
      更新證書吊銷列表
      openssl cs -gencrl -out /etc/pki/CA/crl.pem

      以上是“互聯(lián)網(wǎng)中安全和加密的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

      另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


      本文名稱:互聯(lián)網(wǎng)中安全和加密的示例分析-創(chuàng)新互聯(lián)
      網(wǎng)站網(wǎng)址:http://www.ef60e0e.cn/article/dgeggi.html
      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区
      1. <ul id="0c1fb"></ul>

        <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
        <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

        肥乡县| 鲜城| 土默特右旗| 衡南县| 朝阳市| 旬邑县| 浦江县| 古田县| 邳州市| 古蔺县| 平阴县| 自治县| 策勒县| 公主岭市| 微山县| 江北区| 中阳县| 上思县| 建湖县| 收藏| 出国| 门源| 白朗县| 巴林左旗| 遂平县| 湘西| 通化市| 偏关县| 河东区| 萝北县| 庆城县| 新郑市| 安化县| 麻城市| 临夏县| 鄂托克旗| 梧州市| 美姑县| 阿克| 湄潭县| 太湖县|