真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

加密認(rèn)證功能

加密解密的技術(shù):

成都創(chuàng)新互聯(lián)公司專注于相城網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠(chéng)為您提供相城營(yíng)銷型網(wǎng)站建設(shè),相城網(wǎng)站制作、相城網(wǎng)頁(yè)設(shè)計(jì)、相城網(wǎng)站官網(wǎng)定制、小程序定制開(kāi)發(fā)服務(wù),打造相城網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供相城網(wǎng)站排名全網(wǎng)營(yíng)銷落地服務(wù)。

對(duì)稱加密

加密方和解密方使用是同一個(gè)密鑰,加密解密的速度都很快,先將數(shù)據(jù)明文

分成數(shù)據(jù)塊兒,一般來(lái)講是大小相同的,如果到最后剩下的不能與其他數(shù)據(jù)塊兒的

大小相同,那么就給它添加一些填充物,然后對(duì)每個(gè)數(shù)據(jù)塊兒逐個(gè)加密,

然后把加密后的數(shù)據(jù)塊兒發(fā)給對(duì)方,每一次管理一塊兒,

但是,加密后的塊兒怎么處理,因?yàn)槊恳粋€(gè)塊兒都是單獨(dú)處理,對(duì)方在破解數(shù)據(jù)時(shí)

每一塊兒獨(dú)立破解,也就是說(shuō)這樣的加密過(guò)程對(duì)反破解并沒(méi)有任何幫助,

對(duì)于加密以后的數(shù)據(jù)塊兒的處理有以下兩種方法

ECB:每一塊兒?jiǎn)为?dú)加密,加密一個(gè)傳遞一個(gè),

CBC:加密或密文塊兒鏈,通過(guò)抑或運(yùn)算實(shí)現(xiàn),每一個(gè)數(shù)據(jù)塊兒,在發(fā)送給對(duì)方

之前會(huì)實(shí)現(xiàn)將此數(shù)據(jù)塊兒與此前的數(shù)據(jù)塊兒做一次抑或運(yùn)算,并把結(jié)果發(fā)送給對(duì)方

所以得不到第一個(gè)塊兒,得到其他也就沒(méi)有用,即使是第一塊,也會(huì)和一個(gè)隨機(jī)數(shù)

進(jìn)行抑或運(yùn)算

其最大好處在于,做兩次抑或運(yùn)算后可以將數(shù)據(jù)還原

 

算法:DES:數(shù)據(jù)加密標(biāo)準(zhǔn),使用56位的密鑰長(zhǎng)度

AES:高級(jí)加密標(biāo)準(zhǔn),可以使用128、192、256三種長(zhǎng)度的密鑰

3DES:對(duì)原有加密3次,

Blowfish

Twofish

RC6

IDEA

CAST5

缺陷:1、一個(gè)人跟眾多對(duì)象通信的時(shí)候需要記的密碼過(guò)多

2、密鑰分發(fā)困難,是最大的難題,沒(méi)有一種可靠的手段將密鑰送給一個(gè)

沒(méi)有見(jiàn)過(guò)面的對(duì)象

 

非對(duì)稱加密

公鑰加密算法:DSA,RSA,EIGamal

加密方和解密方使用不同的密鑰

功能:加密解密

用戶的身份認(rèn)證,RSA兩者都可以實(shí)現(xiàn),而DSA只能加密數(shù)據(jù)

公鑰,私鑰

公鑰是從私鑰中抽出的一段特征,公鑰隱含在私鑰中

現(xiàn)在主流的密鑰長(zhǎng)度是2048

 

缺陷:1、加密速度慢,比對(duì)稱加密慢3個(gè)數(shù)量級(jí) 1000倍,一個(gè)數(shù)量級(jí)10倍

2、公鑰加密一般不用于加密數(shù)據(jù),主要用于實(shí)現(xiàn)用戶認(rèn)證,數(shù)據(jù)加密

主要是通過(guò)對(duì)稱加密實(shí)現(xiàn)的

如何實(shí)現(xiàn)用戶認(rèn)證:

現(xiàn)在假設(shè),有兩個(gè)通信的對(duì)象,一個(gè)較小黑,一個(gè)較小白,現(xiàn)在小黑給小白發(fā)了

一封電子郵件,但是,小白在接受郵件的時(shí)候不希望自己的郵件的內(nèi)容被篡改,

這時(shí)小黑就將郵件內(nèi)容加密且說(shuō)自己是小黑,并產(chǎn)生一個(gè)公鑰和一個(gè)私鑰,

私鑰小黑會(huì)隨身攜帶

而且不能外泄,公鑰則連同郵件一起發(fā)給小白,這是小白拿著小黑的公鑰如果能夠

解密,則說(shuō)明小黑就是小黑...這就實(shí)現(xiàn)了認(rèn)證,但是如果小黑加密的數(shù)據(jù)很大,再加上

公鑰加密要用很久時(shí)間,等加密好,小黑也無(wú)語(yǔ)了,所以小黑加密的不是數(shù)據(jù)

而是這段數(shù)據(jù)的特征值,說(shuō)到特征值,下面就說(shuō)一下單向加密》》》

 

單向加密

雪崩效應(yīng):輸入的數(shù)據(jù)有一點(diǎn)點(diǎn)不同,結(jié)果會(huì)有巨大不同,主要目的在防暴力破解

單向加密就是去計(jì)算一段數(shù)據(jù)的特征值,加密過(guò)程是不可逆的,是去計(jì)算一段數(shù)據(jù)的特征碼,是獨(dú)一無(wú)二的,用于對(duì)

數(shù)據(jù)完整性的校驗(yàn)

無(wú)論你輸入的數(shù)據(jù)是多長(zhǎng),輸出的結(jié)果都是一樣長(zhǎng)度

MD5:message digest,輸出結(jié)果固定長(zhǎng)度128bit

SHA1:secure hash algorithm安全的哈希算法,輸出結(jié)果固定長(zhǎng)度160bit

身份認(rèn)證:

單向加密在實(shí)現(xiàn)用戶身份認(rèn)證的時(shí)候不會(huì)去加密整段數(shù)據(jù),而是先去計(jì)算這段數(shù)據(jù)的特征值,

把它的特征值用私鑰加密,加密以后附著在數(shù)據(jù)后面,一起發(fā)給對(duì)方,在對(duì)方收到以后,對(duì)方

可以驗(yàn)證兩方面的內(nèi)容,第一用戶的身份,第二數(shù)據(jù)的完整性,接收方先用發(fā)送方的公鑰對(duì)其解密

如果能解密就驗(yàn)證了對(duì)方了身份,此時(shí)接收方會(huì)獲得這段數(shù)據(jù)的特征值,然后接收方也用相同的

算法進(jìn)行運(yùn)算,得到一個(gè)數(shù)據(jù)的特征值,如果這兩個(gè)特征值相同,則說(shuō)明數(shù)據(jù)在發(fā)送過(guò)程完好無(wú)損

如果不相同,則說(shuō)明數(shù)據(jù)有改動(dòng)

假設(shè)還是小黑和小白通信,雙方都希望在數(shù)據(jù)的發(fā)送過(guò)程中,既能實(shí)現(xiàn)用戶身份驗(yàn)證,

又能實(shí)現(xiàn)數(shù)據(jù)加密,還能實(shí)現(xiàn)數(shù)據(jù)的完整性,那該怎么辦呢?

現(xiàn)在小黑在發(fā)送數(shù)據(jù)前,先將數(shù)據(jù)用單向加密,計(jì)算出特征值,然后再用私鑰解密將特征值加密

接下來(lái)會(huì)再用產(chǎn)生一個(gè)一次性的密碼,用小白的公鑰將這個(gè)密碼加密然后放在數(shù)據(jù)后,最后再用對(duì)稱加密

將全部加密,這時(shí)就是密文了,到了小白那里以后,小白先用自己的私鑰拿到那個(gè)密碼,然后再用那個(gè)

密碼解密,獲得數(shù)據(jù)的特征值,然后再用單向解密計(jì)算出一個(gè)特征值,如果這兩個(gè)值相同,則說(shuō)明

數(shù)據(jù)完好,以上過(guò)程就實(shí)現(xiàn)了三重驗(yàn)證

這三項(xiàng)結(jié)合起來(lái)是現(xiàn)在電子商務(wù)的基礎(chǔ)。

可以實(shí)現(xiàn)這整個(gè)過(guò)的工具:

opssh

gpg

但是這兩個(gè)過(guò)程還存在問(wèn)題,小白怎樣去獲得小黑的公鑰呢?在傳輸公鑰的時(shí)候也有可能

出現(xiàn)欺騙,這怎么解決了?

IKE:互聯(lián)網(wǎng)密鑰交換,實(shí)現(xiàn)雙方使眼色交換密鑰,和密鑰本身不在互聯(lián)網(wǎng)上

傳播

PKI:公鑰基礎(chǔ)設(shè)施,或公鑰基礎(chǔ)架構(gòu),CA證書(shū)頒發(fā)機(jī)構(gòu),證書(shū)內(nèi)放的就是通信人的公鑰信息

怎樣基于證書(shū)通信:

雙方在通信時(shí)都出示證件,這個(gè)證件由某個(gè)權(quán)威機(jī)構(gòu)發(fā)放,只要驗(yàn)證證件內(nèi)的有效信息

就可以驗(yàn)證對(duì)方的身份,但是在發(fā)證的時(shí)候怎樣防止中間出現(xiàn)欺騙呢?

這又是一個(gè)雞生蛋,蛋生雞的問(wèn)題,想想該如何解決呢?

所以一些操作系統(tǒng)在安裝時(shí)就已經(jīng)將一些權(quán)威的發(fā)證機(jī)構(gòu)的證書(shū)放在你的電腦里了,這樣在一定程度

上可以解決一些問(wèn)題

 

證書(shū)的格式:X509,PKCS 

證書(shū)廢棄列表:CRL

 

最常見(jiàn)的***“man in the middle”主要是雙方身份無(wú)法驗(yàn)證

會(huì)話劫持,

數(shù)據(jù)插入,

數(shù)據(jù)篡改,

這些都是常見(jiàn)的威脅

加密解密用于:

 

1、用戶密碼/數(shù)據(jù)嗅探 password/data sniffing 

2、數(shù)據(jù)操縱,data manipulation 

3、authentication manipulation 認(rèn)證 

4、equivalent to mailing on postcards 

這幾個(gè)方面

加密算法的基本法則:kerckhoff's principle

1、一般來(lái)講加密本身并不靠算法,算法固然很關(guān)鍵能將明文變成密文

但是一項(xiàng)真正的加密過(guò)程,你的數(shù)據(jù)是否會(huì)被破解,主要不能過(guò)強(qiáng)依賴于算法本身,

而要依賴于密碼,算法的研究周期很長(zhǎng),更改一個(gè)密碼很簡(jiǎn)單,但是更換一個(gè)算法就麻煩了

算法需要耗費(fèi)很多精力,只要算法不公開(kāi),就無(wú)從下手破解

2、電子商務(wù)的過(guò)程中不僅要保證數(shù)據(jù)加密,還要保證不被別人看見(jiàn)

算法:

1、隨機(jī)數(shù)來(lái)源靠得住

########openssl#########l

用C語(yǔ)言實(shí)現(xiàn)了很多種常見(jiàn)的加密算法:

三個(gè)組件:

1、libcrypto 庫(kù)文件 專門實(shí)現(xiàn)加密解密的庫(kù)文件,

2、libssl 庫(kù)文件,主要是實(shí)現(xiàn)https這樣協(xié)議 

3、openssl 多用途加密工具,還可以制作一個(gè)CA出來(lái)

 

一般來(lái)講openssl都會(huì)裝上,使用一個(gè)openssl加一個(gè)錯(cuò)誤的選項(xiàng)就能看見(jiàn)它的使用

選項(xiàng)

單項(xiàng)加密時(shí)的用法:

 

openssl enc -des3 -salt -a -in inittab -out inittab.des3 

實(shí)現(xiàn)對(duì)于一個(gè)文件加密 enc是加密 -des3是加密算法 -salt 加入雜質(zhì)

-in后面跟文件名 -out加密后放在哪個(gè)文件里

openssl enc -d -des3 -salt -a -in inittab.des3 -out inittab 

-d表示解密

openssl dgst -sha inittab 表示計(jì)算inittab文件的特征值

用戶認(rèn)證時(shí)passwd的用法,怎么去幫你生成一個(gè)類似于保存在/etc/shadow文件里的密碼一樣

openssl passwd -1 -1表示使用MD5算法

[root@server46 ~]# openssl passwd -1 

Password: 

Verifying - Password: 

$1$7HW0kv8y$IntkyNppqtTQ2fHAJ1FMk1 

 

openssl passwd -1 -salt 雜質(zhì) 這樣計(jì)算結(jié)果就一樣了

[root@server46 ~]# openssl passwd -1 

Password: 

Verifying - Password: 

$1$7HW0kv8y$IntkyNppqtTQ2fHAJ1FMk1 

[root@server46 ~]# openssl passwd -1 -salt 7HW0kv8y 

Password: 

$1$7HW0kv8y$IntkyNppqtTQ2fHAJ1FMk1

man sslpasswd可以查看用法

 

非對(duì)稱加密:

openssl怎樣發(fā)證:

切換目錄到/etc/pki/tls/certs

 

make *.key就可以產(chǎn)生一個(gè)密鑰 

make *.cert可以生成一個(gè)證書(shū),主要是看文件后綴生成文件,是redhat提供的便捷方式 

make my.key就可以生成一個(gè)密鑰 

(umask 66;openssl genrsa 1024 > my.key)

生成私鑰文件

這是在一個(gè)子shell里進(jìn)行,umask只對(duì)后面的這一個(gè)命令有效,umask執(zhí)行完以后就恢復(fù)到原來(lái)

提取公鑰:

 

openssl rsa -in my.key -pubout -out myr.pubkey 

[root@server46 certs]# (umask 66; openssl genrsa 1024 > my.key) 

Generating RSA private key, 1024 bit long modulus 

...++++++ 

........++++++ 

e is 65537 (0x10001) 

[root@server46 certs]# cat my.key 

-----BEGIN RSA PRIVATE KEY----- 

MIICXQIBAAKBgQDRSlvZZ7p7sRbczdGhcw/8z5mzEKIjDZw63ffsxCDC9XWKO0vE 

FaxbPrgwZYF+iu8QHUKVzuJoqO8MmfY7p9aGz2WT2GQ/wUTnjsbL8mNbSclV/2m8 

K0XZqSLsKzuhaBOFC+sylQvnZiXP23slNWZIuV0EVh9k2ULSV4f8B5QtywIDAQAB 

AoGATNkA4NM1pjVgL7NjReT5+dpAlX+GCVj2BKd8YXOik/ONNTSQnW9X2ikteJfM 

9KoPHdugl2FfwQ5GuFnQEBeQrUV5SnR09k2OZTsdOMVNXqamf4V/rXidOs+L3RVK 

Q4X6vpasS1CJ1/q/fCcsi1Nl0nLcV9stLXbmEzYqE6+hwAECQQDqxrbF5W9j5vVM 

ZkKmvx1ViojwTJovlkOtl6RSkqHMR3msnHhizbc+iGrGiP/vH9H+AvDK7AJPNVng 

kHAa5YGbAkEA5DXX0dIajPoAdLvmNG1kNY1fp6IJjfR8UJRWeOwjhVjul1yp47hP 

bM/f55OmowdsQamfNVwk4P5iYIcZ8uwfkQJBAJoXToLYsaF6Rumb/IcAzLoGMRa2 

0EQHdegLrVhc0UEIcH2wPPtsVab/VkV0SbaixerX9z7YZDOkqpbPdiTRGZ0CQBWv 

2DakVMmY6HovcQ0CaEd+i9yOVYIb/cRalG0hY67EaMgRkkOFvGaGyqxjJ67Ogccr 

q2mSvB51jjvGGv0u20ECQQCHvgJkF3xHkQnahqCTTgym0CNocHhVfyo6KveIfBAk 

Vz69+zsGK2kKBOseSbgRKqVmM21Iqu0aZatjEevHwZIo 

-----END RSA PRIVATE KEY----- 

[root@server46 certs]# openssl rsa -in my.key -pubout -out my.pubkey 

writing RSA key 

[root@server46 certs]# cat my.pubkey 

-----BEGIN PUBLIC KEY----- 

MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDRSlvZZ7p7sRbczdGhcw/8z5mz 

EKIjDZw63ffsxCDC9XWKO0vEFaxbPrgwZYF+iu8QHUKVzuJoqO8MmfY7p9aGz2WT 

2GQ/wUTnjsbL8mNbSclV/2m8K0XZqSLsKzuhaBOFC+sylQvnZiXP23slNWZIuV0E 

Vh9k2ULSV4f8B5QtywIDAQAB 

-----END PUBLIC KEY----- 

發(fā)證步驟:

1、首先生成一對(duì)密鑰(S/P密鑰)

2、然后把公鑰放在一個(gè)叫證書(shū)頒發(fā)請(qǐng)求里(里面包括你的公鑰,姓名,地址,等一些列描述信息)

發(fā)送到證書(shū)頒發(fā)機(jī)構(gòu)

3、CRT證書(shū)就生成了

 

自己成為CA:

1、cd /etc/pki/CA

有一個(gè) private 文件,里面專門放CA的私鑰文件

2、給自己生成一個(gè)密鑰

(umask 66; openssl genrsa 2048 > private/cakey.pem[這里只能叫cakey.pem]) 

ll private 

給自己發(fā)證書(shū):

openssl req -new -x509 -key private/cake.pem -out cacert.pem 

openssl req -new -x509 -key private/cake.pem -out cacert.pem

 

接下來(lái)會(huì)提示你輸入一些信息

寫(xiě)完之后就是一個(gè)自簽的證書(shū)

接下來(lái)就可以給別人發(fā)證了

view plaincopy to clipboardprint?

openssl req -new -x509 -key private/cake.pem -out cacert.pem -days3655 

openssl req -new -x509 -key private/cake.pem -out cacert.pem -days3655

 

3、編輯cA的配置文件

 

view plaincopy to clipboardprint?

vim /etc/pki/tls/openssl.cnf這里定義了 

vim /etc/pki/tls/openssl.cnf這里定義了

找到【 CA_default 】字段

修改 dir 改為絕對(duì)路徑

這里有些目錄沒(méi)有需要我們手動(dòng)建立,在這個(gè)配置文件內(nèi)我們都能找到

然后還可以修改默認(rèn)信息

到這里才 算是一個(gè)完整的CA

4、接下來(lái)給web服務(wù)器做一個(gè)證書(shū):

 

view plaincopy to clipboardprint?

cd /etc/httpd 

mkdir ssl 

cd ssl 

(umask 66;openssl genrsa 2048 > web.key) 

cd /etc/pki/CA 

mkdir certs crl newcerts 

touch index.txt serial 

echo 01 > serial 

openssl req -new -key wed.key -out wed.csr 這是一個(gè)證書(shū)頒發(fā)請(qǐng)求 

opssl ca -in wed.csr -out web.crt 頒發(fā)證書(shū) 

cd /etc/httpd

mkdir ssl

cd ssl

(umask 66;openssl genrsa 2048 > web.key)

cd /etc/pki/CA

mkdir certs crl newcerts

touch index.txt serial

echo 01 > serial

openssl req -new -key wed.key -out wed.csr 這是一個(gè)證書(shū)頒發(fā)請(qǐng)求

opssl ca -in wed.csr -out web.crt 頒發(fā)證書(shū)

然后敲兩次回車 就ok了


當(dāng)前標(biāo)題:加密認(rèn)證功能
當(dāng)前鏈接:http://weahome.cn/article/gdehod.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部