3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > java >内容正文

java

[转]Java加密算法

發(fā)布時間:2025/7/14 java 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [转]Java加密算法 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

?如基本的單向加密算法:??

  • BASE64 嚴格地說,屬于編碼格式,而非加密算法

  • MD5(Message Digest algorithm 5,信息摘要算法)

  • SHA(Secure Hash Algorithm,安全散列算法)

  • HMAC(Hash Message Authentication Code,散列消息鑒別碼)


??? 復(fù)雜的對稱加密(DES、PBE)、非對稱加密算法:?

  • DES(Data Encryption Standard,數(shù)據(jù)加密算法)

  • PBE(Password-based encryption,基于密碼驗證)

  • RSA(算法的名字以發(fā)明者的名字命名:Ron Rivest, AdiShamir 和Leonard Adleman)

  • DH(Diffie-Hellman算法,密鑰一致協(xié)議)

  • DSA(Digital Signature Algorithm,數(shù)字簽名)

  • ECC(Elliptic Curves Cryptography,橢圓曲線密碼編碼學(xué))



??? 本篇內(nèi)容簡要介紹BASE64、MD5、SHA、HMAC幾種方法。?
????MD5、SHA、HMAC這三種加密算法,可謂是非可逆加密,就是不可解密的加密方法。我們通常只把他們作為加密的基礎(chǔ)。單純的以上三種的加密并不可靠。?

BASE64?
按 照RFC2045的定義,Base64被定義為:Base64內(nèi)容傳送編碼被設(shè)計用來把任意序列的8位字節(jié)描述為一種不易被人直接識別的形式。(The Base64 Content-Transfer-Encoding is designed to represent arbitrary sequences of octets in a form that need not be humanly readable.)?
常見于郵件、http加密,截取http信息,你就會發(fā)現(xiàn)登錄操作的用戶名、密碼字段通過BASE64加密的。?

?

通過java代碼實現(xiàn)如下:

/***?BASE64解密*?*?@param?key*?@return*?@throws?Exception*/public?static?byte[]?decryptBASE64(String?key)?throws?Exception?{return?(new?BASE64Decoder()).decodeBuffer(key);}/***?BASE64加密*?*?@param?key*?@return*?@throws?Exception*/public?static?String?encryptBASE64(byte[]?key)?throws?Exception?{return?(new?BASE64Encoder()).encodeBuffer(key);}


主要就是BASE64Encoder、BASE64Decoder兩個類,我們只需要知道使用對應(yīng)的方法即可。另,BASE加密后產(chǎn)生的字節(jié)位數(shù)是8的倍數(shù),如果不夠位數(shù)以=符號填充。?

MD5?
MD5 -- message-digest algorithm 5 (信息-摘要算法)縮寫,廣泛用于加密和解密技術(shù),常用于文件校驗。校驗?不管文件多大,經(jīng)過MD5后都能生成唯一的MD5值。好比現(xiàn)在的ISO校驗,都 是MD5校驗。怎么用?當(dāng)然是把ISO經(jīng)過MD5后產(chǎn)生MD5的值。一般下載linux-ISO的朋友都見過下載鏈接旁邊放著MD5的串。就是用來驗證文 件是否一致的。?

?

通過java代碼實現(xiàn)如下:

/***?MD5加密*?*?@param?data*?@return*?@throws?Exception*/public?static?byte[]?encryptMD5(byte[]?data)?throws?Exception?{MessageDigest?md5?=?MessageDigest.getInstance(KEY_MD5);md5.update(data);return?md5.digest();}



通常我們不直接使用上述MD5加密。通常將MD5產(chǎn)生的字節(jié)數(shù)組交給BASE64再加密一把,得到相應(yīng)的字符串。?

SHA?
SHA(Secure Hash Algorithm,安全散列算法),數(shù)字簽名等密碼學(xué)應(yīng)用中重要的工具,被廣泛地應(yīng)用于電子商務(wù)等信息安全領(lǐng)域。雖然,SHA與MD5通過碰撞法都被破解了, 但是SHA仍然是公認的安全加密算法,較之MD5更為安全。?

?

通過java代碼實現(xiàn)如下:

/***?SHA加密*?*?@param?data*?@return*?@throws?Exception*/public?static?byte[]?encryptSHA(byte[]?data)?throws?Exception?{MessageDigest?sha?=?MessageDigest.getInstance(KEY_SHA);sha.update(data);return?sha.digest();} }



HMAC?
HMAC(Hash Message Authentication Code,散列消息鑒別碼,基于密鑰的Hash算法的認證協(xié)議。消息鑒別碼實現(xiàn)鑒別的原理是,用公開函數(shù)和密鑰產(chǎn)生一個固定長度的值作為認證標識,用這個 標識鑒別消息的完整性。使用一個密鑰生成一個固定大小的小數(shù)據(jù)塊,即MAC,并將其加入到消息中,然后傳輸。接收方利用與發(fā)送方共享的密鑰進行鑒別認證 等。?

?

通過java代碼實現(xiàn)如下:

/***?初始化HMAC密鑰*?*?@return*?@throws?Exception*/public?static?String?initMacKey()?throws?Exception?{KeyGenerator?keyGenerator?=?KeyGenerator.getInstance(KEY_MAC);SecretKey?secretKey?=?keyGenerator.generateKey();return?encryptBASE64(secretKey.getEncoded());}/***?HMAC加密*?*?@param?data*?@param?key*?@return*?@throws?Exception*/public?static?byte[]?encryptHMAC(byte[]?data,?String?key)?throws?Exception?{SecretKey?secretKey?=?new?SecretKeySpec(decryptBASE64(key),?KEY_MAC);Mac?mac?=?Mac.getInstance(secretKey.getAlgorithm());mac.init(secretKey);return?mac.doFinal(data);}



給出一個完整類,如下:

import?java.security.MessageDigest;import?javax.crypto.KeyGenerator; import?javax.crypto.Mac; import?javax.crypto.SecretKey;import?sun.misc.BASE64Decoder; import?sun.misc.BASE64Encoder;/***?基礎(chǔ)加密組件*?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?abstract?class?Coder?{public?static?final?String?KEY_SHA?=?"SHA";public?static?final?String?KEY_MD5?=?"MD5";/***?MAC算法可選以下多種算法*?*?<pre>*?HmacMD5?*?HmacSHA1?*?HmacSHA256?*?HmacSHA384?*?HmacSHA512*?</pre>*/public?static?final?String?KEY_MAC?=?"HmacMD5";/***?BASE64解密*?*?@param?key*?@return*?@throws?Exception*/public?static?byte[]?decryptBASE64(String?key)?throws?Exception?{return?(new?BASE64Decoder()).decodeBuffer(key);}/***?BASE64加密*?*?@param?key*?@return*?@throws?Exception*/public?static?String?encryptBASE64(byte[]?key)?throws?Exception?{return?(new?BASE64Encoder()).encodeBuffer(key);}/***?MD5加密*?*?@param?data*?@return*?@throws?Exception*/public?static?byte[]?encryptMD5(byte[]?data)?throws?Exception?{MessageDigest?md5?=?MessageDigest.getInstance(KEY_MD5);md5.update(data);return?md5.digest();}/***?SHA加密*?*?@param?data*?@return*?@throws?Exception*/public?static?byte[]?encryptSHA(byte[]?data)?throws?Exception?{MessageDigest?sha?=?MessageDigest.getInstance(KEY_SHA);sha.update(data);return?sha.digest();}/***?初始化HMAC密鑰*?*?@return*?@throws?Exception*/public?static?String?initMacKey()?throws?Exception?{KeyGenerator?keyGenerator?=?KeyGenerator.getInstance(KEY_MAC);SecretKey?secretKey?=?keyGenerator.generateKey();return?encryptBASE64(secretKey.getEncoded());}/***?HMAC加密*?*?@param?data*?@param?key*?@return*?@throws?Exception*/public?static?byte[]?encryptHMAC(byte[]?data,?String?key)?throws?Exception?{SecretKey?secretKey?=?new?SecretKeySpec(decryptBASE64(key),?KEY_MAC);Mac?mac?=?Mac.getInstance(secretKey.getAlgorithm());mac.init(secretKey);return?mac.doFinal(data);} }



再給出一個測試類:

import?static?org.junit.Assert.*;import?org.junit.Test;/***?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?class?CoderTest?{@Testpublic?void?test()?throws?Exception?{String?inputStr?=?"簡單加密";System.err.println("原文:\n"?+?inputStr);byte[]?inputData?=?inputStr.getBytes();String?code?=?Coder.encryptBASE64(inputData);System.err.println("BASE64加密后:\n"?+?code);byte[]?output?=?Coder.decryptBASE64(code);String?outputStr?=?new?String(output);System.err.println("BASE64解密后:\n"?+?outputStr);//?驗證BASE64加密解密一致性assertEquals(inputStr,?outputStr);//?驗證MD5對于同一內(nèi)容加密是否一致assertArrayEquals(Coder.encryptMD5(inputData),?Coder.encryptMD5(inputData));//?驗證SHA對于同一內(nèi)容加密是否一致assertArrayEquals(Coder.encryptSHA(inputData),?Coder.encryptSHA(inputData));String?key?=?Coder.initMacKey();System.err.println("Mac密鑰:\n"?+?key);//?驗證HMAC對于同一內(nèi)容,同一密鑰加密是否一致assertArrayEquals(Coder.encryptHMAC(inputData,?key),?Coder.encryptHMAC(inputData,?key));BigInteger?md5?=?new?BigInteger(Coder.encryptMD5(inputData));System.err.println("MD5:\n"?+?md5.toString(16));BigInteger?sha?=?new?BigInteger(Coder.encryptSHA(inputData));System.err.println("SHA:\n"?+?sha.toString(32));BigInteger?mac?=?new?BigInteger(Coder.encryptHMAC(inputData,?inputStr));System.err.println("HMAC:\n"?+?mac.toString(16));} }



控制臺輸出:

原文: 簡單加密 BASE64加密后: 566A5Y2V5Yqg5a+GBASE64解密后: 簡單加密 Mac密鑰: uGxdHC+6ylRDaik++leFtGwiMbuYUJ6mqHWyhSgF4trVkVBBSQvY/a22xU8XT1RUemdCWW155Bke pBIpkd7QHg==MD5: -550b4d90349ad4629462113e7934de56 SHA: 91k9vo7p400cjkgfhjh0ia9qthsjagfn HMAC: 2287d192387e95694bdbba2fa941009a



注意?
編譯時,可能會看到如下提示:?

引用


警告:sun.misc.BASE64Decoder 是 Sun 的專用 API,可能會在未來版本中刪除?

import sun.misc.BASE64Decoder;?
?????????????? ^?
警告:sun.misc.BASE64Encoder 是 Sun 的專用 API,可能會在未來版本中刪除?

import sun.misc.BASE64Encoder;?
?????????????? ^?



BASE64Encoder 和BASE64Decoder是非官方JDK實現(xiàn)類。雖然可以在JDK里能找到并使用,但是在API里查不到。JRE 中 sun 和 com.sun 開頭包的類都是未被文檔化的,他們屬于 java, javax 類庫的基礎(chǔ),其中的實現(xiàn)大多數(shù)與底層平臺有關(guān),一般來說是不推薦使用的。?


??? BASE64的加密解密是雙向的,可以求反解。?
??? MD5、SHA以及HMAC是單向加密,任何數(shù)據(jù)加密后只會產(chǎn)生唯一的一個加密串,通常用來校驗數(shù)據(jù)在傳輸過程中是否被修改。其中HMAC算法有一個密鑰,增強了數(shù)據(jù)傳輸過程中的安全性,強化了算法外的不可控因素。?
??? 單向加密的用途主要是為了校驗數(shù)據(jù)在傳輸過程中是否被修改。

??? 接下來我們介紹對稱加密算法,最常用的莫過于DES數(shù)據(jù)加密算法。?
DES?
DES-Data Encryption Standard,即數(shù)據(jù)加密算法。是IBM公司于1975年研究成功并公開發(fā)表的。DES算法的入口參數(shù)有三個:Key、Data、Mode。其中 Key為8個字節(jié)共64位,是DES算法的工作密鑰;Data也為8個字節(jié)64位,是要被加密或被解密的數(shù)據(jù);Mode為DES的工作方式,有兩種:加密 或解密。?
????????DES算法把64位的明文輸入塊變?yōu)?4位的密文輸出塊,它所使用的密鑰也是64位。?


通過java代碼實現(xiàn)如下:Coder類見

import?java.security.Key; import?java.security.SecureRandom;import?javax.crypto.Cipher; import?javax.crypto.KeyGenerator; import?javax.crypto.SecretKey; import?javax.crypto.SecretKeyFactory; import?javax.crypto.spec.DESKeySpec;/***?DES安全編碼組件*?*?<pre>*?支持?DES、DESede(TripleDES,就是3DES)、AES、Blowfish、RC2、RC4(ARCFOUR)*?DES?????????? key?size?must?be?equal?to?56*?DESede(TripleDES)? key?size?must?be?equal?to?112?or?168*?AES?????????? key?size?must?be?equal?to?128,?192?or?256,but?192?and?256?bits?may?not?be?available*?Blowfish????? key?size?must?be?multiple?of?8,?and?can?only?range?from?32?to?448?(inclusive)*?RC2?????????? key?size?must?be?between?40?and?1024?bits*?RC4(ARCFOUR)? key?size?must?be?between?40?and?1024?bits*?具體內(nèi)容?需要關(guān)注?JDK?Document?http://.../docs/technotes/guides/security/SunProviders.html*?</pre>*?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?abstract?class?DESCoder?extends?Coder?{/***?ALGORITHM?算法?<br>*?可替換為以下任意一種算法,同時key值的size相應(yīng)改變。*?*?<pre>*?DES?????????? key?size?must?be?equal?to?56*?DESede(TripleDES)? key?size?must?be?equal?to?112?or?168*?AES?????????? key?size?must?be?equal?to?128,?192?or?256,but?192?and?256?bits?may?not?be?available*?Blowfish????? key?size?must?be?multiple?of?8,?and?can?only?range?from?32?to?448?(inclusive)*?RC2?????????? key?size?must?be?between?40?and?1024?bits*?RC4(ARCFOUR)? key?size?must?be?between?40?and?1024?bits*?</pre>*?*?在Key?toKey(byte[]?key)方法中使用下述代碼*?<code>SecretKey?secretKey?=?new?SecretKeySpec(key,?ALGORITHM);</code>?替換*?<code>*?DESKeySpec?dks?=?new?DESKeySpec(key);*?SecretKeyFactory?keyFactory?=?SecretKeyFactory.getInstance(ALGORITHM);*?SecretKey?secretKey?=?keyFactory.generateSecret(dks);*?</code>*/public?static?final?String?ALGORITHM?=?"DES";/***?轉(zhuǎn)換密鑰<br>*?*?@param?key*?@return*?@throws?Exception*/private?static?Key?toKey(byte[]?key)?throws?Exception?{DESKeySpec?dks?=?new?DESKeySpec(key);SecretKeyFactory?keyFactory?=?SecretKeyFactory.getInstance(ALGORITHM);SecretKey?secretKey?=?keyFactory.generateSecret(dks);//?當(dāng)使用其他對稱加密算法時,如AES、Blowfish等算法時,用下述代碼替換上述三行代碼//?SecretKey?secretKey?=?new?SecretKeySpec(key,?ALGORITHM);return?secretKey;}/***?解密*?*?@param?data*?@param?key*?@return*?@throws?Exception*/public?static?byte[]?decrypt(byte[]?data,?String?key)?throws?Exception?{Key?k?=?toKey(decryptBASE64(key));Cipher?cipher?=?Cipher.getInstance(ALGORITHM);cipher.init(Cipher.DECRYPT_MODE,?k);return?cipher.doFinal(data);}/***?加密*?*?@param?data*?@param?key*?@return*?@throws?Exception*/public?static?byte[]?encrypt(byte[]?data,?String?key)?throws?Exception?{Key?k?=?toKey(decryptBASE64(key));Cipher?cipher?=?Cipher.getInstance(ALGORITHM);cipher.init(Cipher.ENCRYPT_MODE,?k);return?cipher.doFinal(data);}/***?生成密鑰*?*?@return*?@throws?Exception*/public?static?String?initKey()?throws?Exception?{return?initKey(null);}/***?生成密鑰*?*?@param?seed*?@return*?@throws?Exception*/public?static?String?initKey(String?seed)?throws?Exception?{SecureRandom?secureRandom?=?null;if?(seed?!=?null)?{secureRandom?=?new?SecureRandom(decryptBASE64(seed));}?else?{secureRandom?=?new?SecureRandom();}KeyGenerator?kg?=?KeyGenerator.getInstance(ALGORITHM);kg.init(secureRandom);SecretKey?secretKey?=?kg.generateKey();return?encryptBASE64(secretKey.getEncoded());} }


延續(xù)上一個類的實現(xiàn),我們通過MD5以及SHA對字符串加密生成密鑰,這是比較常見的密鑰生成方式。?
再給出一個測試類:

import?static?org.junit.Assert.*;import?org.junit.Test;/***?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?class?DESCoderTest?{@Testpublic?void?test()?throws?Exception?{String?inputStr?=?"DES";String?key?=?DESCoder.initKey();System.err.println("原文:\t"?+?inputStr);System.err.println("密鑰:\t"?+?key);byte[]?inputData?=?inputStr.getBytes();inputData?=?DESCoder.encrypt(inputData,?key);System.err.println("加密后:\t"?+?DESCoder.encryptBASE64(inputData));byte[]?outputData?=?DESCoder.decrypt(inputData,?key);String?outputStr?=?new?String(outputData);System.err.println("解密后:\t"?+?outputStr);assertEquals(inputStr,?outputStr);} }


得到的輸出內(nèi)容如下:

原文: DES 密鑰: f3wEtRrV6q0=加密后: C6qe9oNIzRY=解密后: DES


??? 由控制臺得到的輸出,我們能夠比對加密、解密后結(jié)果一致。這是一種簡單的加密解密方式,只有一個密鑰。?
??? 其實DES有很多同胞兄弟,如DESede(TripleDES)、AES、Blowfish、RC2、RC4(ARCFOUR)。這里就不過多闡述了,大同小異,只要換掉ALGORITHM換成對應(yīng)的值,同時做一個代碼替換SecretKey secretKey = new SecretKeySpec(key, ALGORITHM);就可以了,此外就是密鑰長度不同了。?

/***?DES??????????key?size?must?be?equal?to?56*?DESede(TripleDES)?key?size?must?be?equal?to?112?or?168*?AES??????????key?size?must?be?equal?to?128,?192?or?256,but?192?and?256?bits?may?not?be?available*?Blowfish?????key?size?must?be?multiple?of?8,?and?can?only?range?from?32?to?448?(inclusive)*?RC2??????????key?size?must?be?between?40?and?1024?bits*?RC4(ARCFOUR)?key?size?must?be?between?40?and?1024?bits**/

??? 除了DES,我們還知道有DESede(TripleDES,就是3DES)、AES、Blowfish、RC2、RC4(ARCFOUR)等多種對稱加密方式,其實現(xiàn)方式大同小異,這里介紹對稱加密的另一個算法——PBE?
PBE?
??? PBE——Password-based encryption(基于密碼加密)。其特點在于口令由用戶自己掌管,不借助任何物理媒體;采用隨機數(shù)(這里我們叫做鹽)雜湊多重加密等方法保證數(shù)據(jù)的安全性。是一種簡便的加密方式。?
通過java代碼實現(xiàn)如下:Coder類見?

import?java.security.Key; import?java.util.Random;import?javax.crypto.Cipher; import?javax.crypto.SecretKey; import?javax.crypto.SecretKeyFactory; import?javax.crypto.spec.PBEKeySpec; import?javax.crypto.spec.PBEParameterSpec;/***?PBE安全編碼組件*?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?abstract?class?PBECoder?extends?Coder?{/***?支持以下任意一種算法*?*?<pre>*?PBEWithMD5AndDES?*?PBEWithMD5AndTripleDES?*?PBEWithSHA1AndDESede*?PBEWithSHA1AndRC2_40*?</pre>*/public?static?final?String?ALGORITHM?=?"PBEWITHMD5andDES";/***?鹽初始化*?*?@return*?@throws?Exception*/public?static?byte[]?initSalt()?throws?Exception?{byte[]?salt?=?new?byte[8];Random?random?=?new?Random();random.nextBytes(salt);return?salt;}/***?轉(zhuǎn)換密鑰<br>*?*?@param?password*?@return*?@throws?Exception*/private?static?Key?toKey(String?password)?throws?Exception?{PBEKeySpec?keySpec?=?new?PBEKeySpec(password.toCharArray());SecretKeyFactory?keyFactory?=?SecretKeyFactory.getInstance(ALGORITHM);SecretKey?secretKey?=?keyFactory.generateSecret(keySpec);return?secretKey;}/***?加密*?*?@param?data?數(shù)據(jù)*?@param?password?密碼*?@param?salt??鹽*?@return*?@throws?Exception*/public?static?byte[]?encrypt(byte[]?data,?String?password,?byte[]?salt)throws?Exception?{Key?key?=?toKey(password);PBEParameterSpec?paramSpec?=?new?PBEParameterSpec(salt,?100);Cipher?cipher?=?Cipher.getInstance(ALGORITHM);cipher.init(Cipher.ENCRYPT_MODE,?key,?paramSpec);return?cipher.doFinal(data);}/***?解密*?*?@param?data??數(shù)據(jù)*?@param?password?密碼*?@param?salt??鹽*?@return*?@throws?Exception*/public?static?byte[]?decrypt(byte[]?data,?String?password,?byte[]?salt)throws?Exception?{Key?key?=?toKey(password);PBEParameterSpec?paramSpec?=?new?PBEParameterSpec(salt,?100);Cipher?cipher?=?Cipher.getInstance(ALGORITHM);cipher.init(Cipher.DECRYPT_MODE,?key,?paramSpec);return?cipher.doFinal(data);} }



再給出一個測試類:?

import?static?org.junit.Assert.*;import?org.junit.Test;/***?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?class?PBECoderTest?{@Testpublic?void?test()?throws?Exception?{String?inputStr?=?"abc";System.err.println("原文:?"?+?inputStr);byte[]?input?=?inputStr.getBytes();String?pwd?=?"efg";System.err.println("密碼:?"?+?pwd);byte[]?salt?=?PBECoder.initSalt();byte[]?data?=?PBECoder.encrypt(input,?pwd,?salt);System.err.println("加密后:?"?+?PBECoder.encryptBASE64(data));byte[]?output?=?PBECoder.decrypt(data,?pwd,?salt);String?outputStr?=?new?String(output);System.err.println("解密后:?"?+?outputStr);assertEquals(inputStr,?outputStr);}}



控制臺輸出:?

原文:?abc 密碼:?efg 加密后:?iCZ0uRtaAhE=解密后:?abc


??? 后續(xù)我們會介紹非對稱加密算法,如RSA、DSA、DH、ECC等。?

??? 接下來我們介紹典型的非對稱加密算法——RSA?

RSA?
??? 這種算法1978年就出現(xiàn)了,它是第一個既能用于數(shù)據(jù)加密也能用于數(shù)字簽名的算法。它易于理解和操作,也很流行。算法的名字以發(fā)明者的名字命名:Ron Rivest, AdiShamir 和Leonard Adleman。?
??? 這種加密算法的特點主要是密鑰的變化,上文我們看到DES只有一個密鑰。相當(dāng)于只有一把鑰匙,如果這把鑰匙丟了,數(shù)據(jù)也就不安全了。RSA同時有兩把鑰 匙,公鑰與私鑰。同時支持數(shù)字簽名。數(shù)字簽名的意義在于,對傳輸過來的數(shù)據(jù)進行校驗。確保數(shù)據(jù)在傳輸工程中不被修改。?

流程分析:?

  • 甲方構(gòu)建密鑰對兒,將公鑰公布給乙方,將私鑰保留。

  • 甲方使用私鑰加密數(shù)據(jù),然后用私鑰對加密后的數(shù)據(jù)簽名,發(fā)送給乙方簽名以及加密后的數(shù)據(jù);乙方使用公鑰、簽名來驗證待解密數(shù)據(jù)是否有效,如果有效使用公鑰對數(shù)據(jù)解密。

  • 乙方使用公鑰加密數(shù)據(jù),向甲方發(fā)送經(jīng)過加密后的數(shù)據(jù);甲方獲得加密數(shù)據(jù),通過私鑰解密。



  • 按如上步驟給出序列圖,如下:?



  • 通過java代碼實現(xiàn)如下:Coder類見

    import?java.security.Key; import?java.security.KeyFactory; import?java.security.KeyPair; import?java.security.KeyPairGenerator; import?java.security.PrivateKey; import?java.security.PublicKey; import?java.security.Signature; import?java.security.interfaces.RSAPrivateKey; import?java.security.interfaces.RSAPublicKey; import?java.security.spec.PKCS8EncodedKeySpec; import?java.security.spec.X509EncodedKeySpec;import?java.util.HashMap; import?java.util.Map;import?javax.crypto.Cipher;/***?RSA安全編碼組件*?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?abstract?class?RSACoder?extends?Coder?{public?static?final?String?KEY_ALGORITHM?=?"RSA";public?static?final?String?SIGNATURE_ALGORITHM?=?"MD5withRSA";private?static?final?String?PUBLIC_KEY?=?"RSAPublicKey";private?static?final?String?PRIVATE_KEY?=?"RSAPrivateKey";/***?用私鑰對信息生成數(shù)字簽名*?*?@param?data*????????????加密數(shù)據(jù)*?@param?privateKey*????????????私鑰*?*?@return*?@throws?Exception*/public?static?String?sign(byte[]?data,?String?privateKey)?throws?Exception?{//?解密由base64編碼的私鑰byte[]?keyBytes?=?decryptBASE64(privateKey);//?構(gòu)造PKCS8EncodedKeySpec對象PKCS8EncodedKeySpec?pkcs8KeySpec?=?new?PKCS8EncodedKeySpec(keyBytes);//?KEY_ALGORITHM?指定的加密算法KeyFactory?keyFactory?=?KeyFactory.getInstance(KEY_ALGORITHM);//?取私鑰匙對象PrivateKey?priKey?=?keyFactory.generatePrivate(pkcs8KeySpec);//?用私鑰對信息生成數(shù)字簽名Signature?signature?=?Signature.getInstance(SIGNATURE_ALGORITHM);signature.initSign(priKey);signature.update(data);return?encryptBASE64(signature.sign());}/***?校驗數(shù)字簽名*?*?@param?data*????????????加密數(shù)據(jù)*?@param?publicKey*????????????公鑰*?@param?sign*????????????數(shù)字簽名*?*?@return?校驗成功返回true?失敗返回false*?@throws?Exception*?*/public?static?boolean?verify(byte[]?data,?String?publicKey,?String?sign)throws?Exception?{//?解密由base64編碼的公鑰byte[]?keyBytes?=?decryptBASE64(publicKey);//?構(gòu)造X509EncodedKeySpec對象X509EncodedKeySpec?keySpec?=?new?X509EncodedKeySpec(keyBytes);//?KEY_ALGORITHM?指定的加密算法KeyFactory?keyFactory?=?KeyFactory.getInstance(KEY_ALGORITHM);//?取公鑰匙對象PublicKey?pubKey?=?keyFactory.generatePublic(keySpec);Signature?signature?=?Signature.getInstance(SIGNATURE_ALGORITHM);signature.initVerify(pubKey);signature.update(data);//?驗證簽名是否正常return?signature.verify(decryptBASE64(sign));}/***?解密<br>*?用私鑰解密*?*?@param?data*?@param?key*?@return*?@throws?Exception*/public?static?byte[]?decryptByPrivateKey(byte[]?data,?String?key)throws?Exception?{//?對密鑰解密byte[]?keyBytes?=?decryptBASE64(key);//?取得私鑰PKCS8EncodedKeySpec?pkcs8KeySpec?=?new?PKCS8EncodedKeySpec(keyBytes);KeyFactory?keyFactory?=?KeyFactory.getInstance(KEY_ALGORITHM);Key?privateKey?=?keyFactory.generatePrivate(pkcs8KeySpec);//?對數(shù)據(jù)解密Cipher?cipher?=?Cipher.getInstance(keyFactory.getAlgorithm());cipher.init(Cipher.DECRYPT_MODE,?privateKey);return?cipher.doFinal(data);}/***?解密<br>*?用私鑰解密*?*?@param?data*?@param?key*?@return*?@throws?Exception*/public?static?byte[]?decryptByPublicKey(byte[]?data,?String?key)throws?Exception?{//?對密鑰解密byte[]?keyBytes?=?decryptBASE64(key);//?取得公鑰X509EncodedKeySpec?x509KeySpec?=?new?X509EncodedKeySpec(keyBytes);KeyFactory?keyFactory?=?KeyFactory.getInstance(KEY_ALGORITHM);Key?publicKey?=?keyFactory.generatePublic(x509KeySpec);//?對數(shù)據(jù)解密Cipher?cipher?=?Cipher.getInstance(keyFactory.getAlgorithm());cipher.init(Cipher.DECRYPT_MODE,?publicKey);return?cipher.doFinal(data);}/***?加密<br>*?用公鑰加密*?*?@param?data*?@param?key*?@return*?@throws?Exception*/public?static?byte[]?encryptByPublicKey(byte[]?data,?String?key)throws?Exception?{//?對公鑰解密byte[]?keyBytes?=?decryptBASE64(key);//?取得公鑰X509EncodedKeySpec?x509KeySpec?=?new?X509EncodedKeySpec(keyBytes);KeyFactory?keyFactory?=?KeyFactory.getInstance(KEY_ALGORITHM);Key?publicKey?=?keyFactory.generatePublic(x509KeySpec);//?對數(shù)據(jù)加密Cipher?cipher?=?Cipher.getInstance(keyFactory.getAlgorithm());cipher.init(Cipher.ENCRYPT_MODE,?publicKey);return?cipher.doFinal(data);}/***?加密<br>*?用私鑰加密*?*?@param?data*?@param?key*?@return*?@throws?Exception*/public?static?byte[]?encryptByPrivateKey(byte[]?data,?String?key)throws?Exception?{//?對密鑰解密byte[]?keyBytes?=?decryptBASE64(key);//?取得私鑰PKCS8EncodedKeySpec?pkcs8KeySpec?=?new?PKCS8EncodedKeySpec(keyBytes);KeyFactory?keyFactory?=?KeyFactory.getInstance(KEY_ALGORITHM);Key?privateKey?=?keyFactory.generatePrivate(pkcs8KeySpec);//?對數(shù)據(jù)加密Cipher?cipher?=?Cipher.getInstance(keyFactory.getAlgorithm());cipher.init(Cipher.ENCRYPT_MODE,?privateKey);return?cipher.doFinal(data);}/***?取得私鑰*?*?@param?keyMap*?@return*?@throws?Exception*/public?static?String?getPrivateKey(Map<String,?Object>?keyMap)throws?Exception?{Key?key?=?(Key)?keyMap.get(PRIVATE_KEY);return?encryptBASE64(key.getEncoded());}/***?取得公鑰*?*?@param?keyMap*?@return*?@throws?Exception*/public?static?String?getPublicKey(Map<String,?Object>?keyMap)throws?Exception?{Key?key?=?(Key)?keyMap.get(PUBLIC_KEY);return?encryptBASE64(key.getEncoded());}/***?初始化密鑰*?*?@return*?@throws?Exception*/public?static?Map<String,?Object>?initKey()?throws?Exception?{KeyPairGenerator?keyPairGen?=?KeyPairGenerator.getInstance(KEY_ALGORITHM);keyPairGen.initialize(1024);KeyPair?keyPair?=?keyPairGen.generateKeyPair();//?公鑰RSAPublicKey?publicKey?=?(RSAPublicKey)?keyPair.getPublic();//?私鑰RSAPrivateKey?privateKey?=?(RSAPrivateKey)?keyPair.getPrivate();Map<String,?Object>?keyMap?=?new?HashMap<String,?Object>(2);keyMap.put(PUBLIC_KEY,?publicKey);keyMap.put(PRIVATE_KEY,?privateKey);return?keyMap;} }


    再給出一個測試類:

    import?static?org.junit.Assert.*;import?org.junit.Before; import?org.junit.Test;import?java.util.Map;/***?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?class?RSACoderTest?{private?String?publicKey;private?String?privateKey;@Beforepublic?void?setUp()?throws?Exception?{Map<String,?Object>?keyMap?=?RSACoder.initKey();publicKey?=?RSACoder.getPublicKey(keyMap);privateKey?=?RSACoder.getPrivateKey(keyMap);System.err.println("公鑰:?\n\r"?+?publicKey);System.err.println("私鑰:?\n\r"?+?privateKey);}@Testpublic?void?test()?throws?Exception?{System.err.println("公鑰加密——私鑰解密");String?inputStr?=?"abc";byte[]?data?=?inputStr.getBytes();byte[]?encodedData?=?RSACoder.encryptByPublicKey(data,?publicKey);byte[]?decodedData?=?RSACoder.decryptByPrivateKey(encodedData,privateKey);String?outputStr?=?new?String(decodedData);System.err.println("加密前:?"?+?inputStr?+?"\n\r"?+?"解密后:?"?+?outputStr);assertEquals(inputStr,?outputStr);}@Testpublic?void?testSign()?throws?Exception?{System.err.println("私鑰加密——公鑰解密");String?inputStr?=?"sign";byte[]?data?=?inputStr.getBytes();byte[]?encodedData?=?RSACoder.encryptByPrivateKey(data,?privateKey);byte[]?decodedData?=?RSACoder.decryptByPublicKey(encodedData,?publicKey);String?outputStr?=?new?String(decodedData);System.err.println("加密前:?"?+?inputStr?+?"\n\r"?+?"解密后:?"?+?outputStr);assertEquals(inputStr,?outputStr);System.err.println("私鑰簽名——公鑰驗證簽名");//?產(chǎn)生簽名String?sign?=?RSACoder.sign(encodedData,?privateKey);System.err.println("簽名:\r"?+?sign);//?驗證簽名boolean?status?=?RSACoder.verify(encodedData,?publicKey,?sign);System.err.println("狀態(tài):\r"?+?status);assertTrue(status);}}


    控制臺輸出:

    公鑰:?MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCYU/+I0+z1aBl5X6DUUOHQ7FZpmBSDbKTtx89J EcB64jFCkunELT8qiKly7fzEqD03g8ALlu5XvX+bBqHFy7YPJJP0ekE2X3wjUnh2NxlqpH3/B/xm 1ZdSlCwDIkbijhBVDjA/bu5BObhZqQmDwIxlQInL9oVz+o6FbAZCyHBd7wIDAQAB私鑰:?MIICdgIBADANBgkqhkiG9w0BAQEFAASCAmAwggJcAgEAAoGBAJhT/4jT7PVoGXlfoNRQ4dDsVmmY FINspO3Hz0kRwHriMUKS6cQtPyqIqXLt/MSoPTeDwAuW7le9f5sGocXLtg8kk/R6QTZffCNSeHY3 GWqkff8H/GbVl1KULAMiRuKOEFUOMD9u7kE5uFmpCYPAjGVAicv2hXP6joVsBkLIcF3vAgMBAAEC gYBvZHWoZHmS2EZQqKqeuGr58eobG9hcZzWQoJ4nq/CarBAjw/VovUHE490uK3S9ht4FW7Yzg3LV /MB06Huifh6qf/X9NQA7SeZRRC8gnCQk6JuDIEVJOud5jU+9tyumJakDKodQ3Jf2zQtNr+5ZdEPl uwWgv9c4kmpjhAdyMuQmYQJBANn6pcgvyYaia52dnu+yBUsGkaFfwXkzFSExIbi0MXTkhEb/ER/D rLytukkUu5S5ecz/KBa8U4xIslZDYQbLz5ECQQCy5dutt7RsxN4+dxCWn0/1FrkWl2G329Ucewm3 QU9CKu4D+7Kqdj+Ha3lXP8F0Etaaapi7+EfkRUpukn2ItZV/AkEAlk+I0iphxT1rCB0Q5CjWDY5S Df2B5JmdEG5Y2o0nLXwG2w44OLct/k2uD4cEcuITY5Dvi/4BftMCZwm/dnhEgQJACIktJSnJwxLV o9dchENPtlsCM9C/Sd2EWpqISSUlmfugZbJBwR5pQ5XeMUqKeXZYpP+HEBj1nS+tMH9u2/IGEwJA fL8mZiZXan/oBKrblAbplNcKWGRVD/3y65042PAEeghahlJMiYquV5DzZajuuT0wbJ5xQuZB01+X nfpFpBJ2dw==公鑰加密——私鑰解密 加密前:?abc解密后:?abc 公鑰:?MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDdOj40yEB48XqWxmPILmJAc7UecIN7F32etSHF 9rwbuEh3+iTPOGSxhoSQpOED0vOb0ZIMkBXZSgsxLaBSin2RZ09YKWRjtpCA0kDkiD11gj4tzTiM l9qq1kwSK7ZkGAgodEn3yIILVmQDuEImHOXFtulvJ71ka07u3LuwUNdB/wIDAQAB私鑰:?MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBAN06PjTIQHjxepbGY8guYkBztR5w g3sXfZ61IcX2vBu4SHf6JM84ZLGGhJCk4QPS85vRkgyQFdlKCzEtoFKKfZFnT1gpZGO2kIDSQOSI PXWCPi3NOIyX2qrWTBIrtmQYCCh0SffIggtWZAO4QiYc5cW26W8nvWRrTu7cu7BQ10H/AgMBAAEC gYEAz2JWBizjI31bqhP4XiP9PuY5F3vqBW4T+L9cFbQiyumKJc58yzTWUAUGKIIn3enXLG7dNqGr mbJro4JeFIJ3CiVDpXR9+FluIgI4SXm7ioGKF2NOMA9LR5Fu82W+pLfpTN2y2SaLYWEDZyp53BxY j9gUxaxi1MQs+C1ZgDF2xmECQQDy70bQntbRfysP+ppCtd56YRnES1Tyekw0wryS2tr+ivQJl7JF gp5rPAOXpgrq36xHDwUspQ0sJ0vj0O7ywxr1AkEA6SAaLhrJJrYucC0jxwAhUYyaPN+aOsWymaRh 9jA/Wc0wp29SbGTh5CcMuGpXm1g0M+FKW3dGiHgS3rVUKim4owJAbnxgapUzAgiiHxxMeDaavnHW 9C2GrtjsO7qtZOTgYI/1uT8itvZW8lJTF+9OW8/qXE76fXl7ai9dFnl5kzMk2QJBALfHz/vCsArt mkRiwY6zApE4Z6tPl1V33ymSVovvUzHnOdD1SKQdD5t+UV/crb3QVi8ED0t2B0u0ZSPfDT/D7kMC QDpwdj9k2F5aokLHBHUNJPFDAp7a5QMaT64gv/d48ITJ68Co+v5WzLMpzJBYXK6PAtqIhxbuPEc2 I2k1Afmrwyw=私鑰加密——公鑰解密 加密前:?sign解密后:?sign 私鑰簽名——公鑰驗證簽名 簽名: ud1RsIwmSC1pN22I4IXteg1VD2FbiehKUfNxgVSHzvQNIK+d20FCkHCqh9djP3h94iWnIUY0ifU+ mbJkhAl/i5krExOE0hknOnPMcEP+lZV1RbJI2zG2YooSp2XDleqrQk5e/QF2Mx0Zxt8Xsg7ucVpn i3wwbYWs9wSzIf0UjlM=狀態(tài): true



    ??? 簡要總結(jié)一下,使用公鑰加密、私鑰解密,完成了乙方到甲方的一次數(shù)據(jù)傳遞,通過私鑰加密、公鑰解密,同時通過私鑰簽名、公鑰驗證簽名,完成了一次甲方到乙方的數(shù)據(jù)傳遞與驗證,兩次數(shù)據(jù)傳遞完成一整套的數(shù)據(jù)交互!?

    類似數(shù)字簽名,數(shù)字信封是這樣描述的:?

    數(shù)字信封?
    ????????數(shù)字信封用加密技術(shù)來保證只有特定的收信人才能閱讀信的內(nèi)容。?
    流程:?
    ??? 信息發(fā)送方采用對稱密鑰來加密信息,然后再用接收方的公鑰來加密此對稱密鑰(這部分稱為數(shù)字信封),再將它和信息一起發(fā)送給接收方;接收方先用相應(yīng)的私鑰打開數(shù)字信封,得到對稱密鑰,然后使用對稱密鑰再解開信息。

    ??? 接下來我們分析DH加密算法,一種適基于密鑰一致協(xié)議的加密算法。?
    DH?
    Diffie- Hellman算法(D-H算法),密鑰一致協(xié)議。是由公開密鑰密碼體制的奠基人Diffie和Hellman所提出的一種思想。簡單的說就是允許兩名用 戶在公開媒體上交換信息以生成"一致"的、可以共享的密鑰。換句話說,就是由甲方產(chǎn)出一對密鑰(公鑰、私鑰),乙方依照甲方公鑰產(chǎn)生乙方密鑰對(公鑰、私 鑰)。以此為基線,作為數(shù)據(jù)傳輸保密基礎(chǔ),同時雙方使用同一種對稱加密算法構(gòu)建本地密鑰(SecretKey)對數(shù)據(jù)加密。這樣,在互通了本地密鑰 (SecretKey)算法后,甲乙雙方公開自己的公鑰,使用對方的公鑰和剛才產(chǎn)生的私鑰加密數(shù)據(jù),同時可以使用對方的公鑰和自己的私鑰對數(shù)據(jù)解密。不單 單是甲乙雙方兩方,可以擴展為多方共享數(shù)據(jù)通訊,這樣就完成了網(wǎng)絡(luò)交互數(shù)據(jù)的安全通訊!該算法源于中國的同余定理——中國馀數(shù)定理。??

    流程分析:?

    1.甲方構(gòu)建密鑰對兒,將公鑰公布給乙方,將私鑰保留;雙方約定數(shù)據(jù)加密算法;乙方通過甲方公鑰構(gòu)建密鑰對兒,將公鑰公布給甲方,將私鑰保留。?
    2.甲方使用私鑰、乙方公鑰、約定數(shù)據(jù)加密算法構(gòu)建本地密鑰,然后通過本地密鑰加密數(shù)據(jù),發(fā)送給乙方加密后的數(shù)據(jù);乙方使用私鑰、甲方公鑰、約定數(shù)據(jù)加密算法構(gòu)建本地密鑰,然后通過本地密鑰對數(shù)據(jù)解密。?
    3.乙方使用私鑰、甲方公鑰、約定數(shù)據(jù)加密算法構(gòu)建本地密鑰,然后通過本地密鑰加密數(shù)據(jù),發(fā)送給甲方加密后的數(shù)據(jù);甲方使用私鑰、乙方公鑰、約定數(shù)據(jù)加密算法構(gòu)建本地密鑰,然后通過本地密鑰對數(shù)據(jù)解密。?

  • ?


  • 通過java代碼實現(xiàn)如下:Coder類見

    import?java.security.Key; import?java.security.KeyFactory; import?java.security.KeyPair; import?java.security.KeyPairGenerator; import?java.security.PublicKey; import?java.security.spec.PKCS8EncodedKeySpec; import?java.security.spec.X509EncodedKeySpec; import?java.util.HashMap; import?java.util.Map;import?javax.crypto.Cipher; import?javax.crypto.KeyAgreement; import?javax.crypto.SecretKey; import?javax.crypto.interfaces.DHPrivateKey; import?javax.crypto.interfaces.DHPublicKey; import?javax.crypto.spec.DHParameterSpec;/***?DH安全編碼組件*?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?abstract?class?DHCoder?extends?Coder?{public?static?final?String?ALGORITHM?=?"DH";/***?默認密鑰字節(jié)數(shù)*?*?<pre>*?DH*?Default?Keysize?1024??*?Keysize?must?be?a?multiple?of?64,?ranging?from?512?to?1024?(inclusive).*?</pre>*/private?static?final?int?KEY_SIZE?=?1024;/***?DH加密下需要一種對稱加密算法對數(shù)據(jù)加密,這里我們使用DES,也可以使用其他對稱加密算法。*/public?static?final?String?SECRET_ALGORITHM?=?"DES";private?static?final?String?PUBLIC_KEY?=?"DHPublicKey";private?static?final?String?PRIVATE_KEY?=?"DHPrivateKey";/***?初始化甲方密鑰*?*?@return*?@throws?Exception*/public?static?Map<String,?Object>?initKey()?throws?Exception?{KeyPairGenerator?keyPairGenerator?=?KeyPairGenerator.getInstance(ALGORITHM);keyPairGenerator.initialize(KEY_SIZE);KeyPair?keyPair?=?keyPairGenerator.generateKeyPair();//?甲方公鑰DHPublicKey?publicKey?=?(DHPublicKey)?keyPair.getPublic();//?甲方私鑰DHPrivateKey?privateKey?=?(DHPrivateKey)?keyPair.getPrivate();Map<String,?Object>?keyMap?=?new?HashMap<String,?Object>(2);keyMap.put(PUBLIC_KEY,?publicKey);keyMap.put(PRIVATE_KEY,?privateKey);return?keyMap;}/***?初始化乙方密鑰*?*?@param?key*????????????甲方公鑰*?@return*?@throws?Exception*/public?static?Map<String,?Object>?initKey(String?key)?throws?Exception?{//?解析甲方公鑰byte[]?keyBytes?=?decryptBASE64(key);X509EncodedKeySpec?x509KeySpec?=?new?X509EncodedKeySpec(keyBytes);KeyFactory?keyFactory?=?KeyFactory.getInstance(ALGORITHM);PublicKey?pubKey?=?keyFactory.generatePublic(x509KeySpec);//?由甲方公鑰構(gòu)建乙方密鑰DHParameterSpec?dhParamSpec?=?((DHPublicKey)?pubKey).getParams();KeyPairGenerator?keyPairGenerator?=?KeyPairGenerator.getInstance(keyFactory.getAlgorithm());keyPairGenerator.initialize(dhParamSpec);KeyPair?keyPair?=?keyPairGenerator.generateKeyPair();//?乙方公鑰DHPublicKey?publicKey?=?(DHPublicKey)?keyPair.getPublic();//?乙方私鑰DHPrivateKey?privateKey?=?(DHPrivateKey)?keyPair.getPrivate();Map<String,?Object>?keyMap?=?new?HashMap<String,?Object>(2);keyMap.put(PUBLIC_KEY,?publicKey);keyMap.put(PRIVATE_KEY,?privateKey);return?keyMap;}/***?加密<br>*?*?@param?data*????????????待加密數(shù)據(jù)*?@param?publicKey*????????????甲方公鑰*?@param?privateKey*????????????乙方私鑰*?@return*?@throws?Exception*/public?static?byte[]?encrypt(byte[]?data,?String?publicKey,String?privateKey)?throws?Exception?{//?生成本地密鑰SecretKey?secretKey?=?getSecretKey(publicKey,?privateKey);//?數(shù)據(jù)加密Cipher?cipher?=?Cipher.getInstance(secretKey.getAlgorithm());cipher.init(Cipher.ENCRYPT_MODE,?secretKey);return?cipher.doFinal(data);}/***?解密<br>*?*?@param?data*????????????待解密數(shù)據(jù)*?@param?publicKey*????????????乙方公鑰*?@param?privateKey*????????????乙方私鑰*?@return*?@throws?Exception*/public?static?byte[]?decrypt(byte[]?data,?String?publicKey,String?privateKey)?throws?Exception?{//?生成本地密鑰SecretKey?secretKey?=?getSecretKey(publicKey,?privateKey);//?數(shù)據(jù)解密Cipher?cipher?=?Cipher.getInstance(secretKey.getAlgorithm());cipher.init(Cipher.DECRYPT_MODE,?secretKey);return?cipher.doFinal(data);}/***?構(gòu)建密鑰*?*?@param?publicKey*????????????公鑰*?@param?privateKey*????????????私鑰*?@return*?@throws?Exception*/private?static?SecretKey?getSecretKey(String?publicKey,?String?privateKey)throws?Exception?{//?初始化公鑰byte[]?pubKeyBytes?=?decryptBASE64(publicKey);KeyFactory?keyFactory?=?KeyFactory.getInstance(ALGORITHM);X509EncodedKeySpec?x509KeySpec?=?new?X509EncodedKeySpec(pubKeyBytes);PublicKey?pubKey?=?keyFactory.generatePublic(x509KeySpec);//?初始化私鑰byte[]?priKeyBytes?=?decryptBASE64(privateKey);PKCS8EncodedKeySpec?pkcs8KeySpec?=?new?PKCS8EncodedKeySpec(priKeyBytes);Key?priKey?=?keyFactory.generatePrivate(pkcs8KeySpec);KeyAgreement?keyAgree?=?KeyAgreement.getInstance(keyFactory.getAlgorithm());keyAgree.init(priKey);keyAgree.doPhase(pubKey,?true);//?生成本地密鑰SecretKey?secretKey?=?keyAgree.generateSecret(SECRET_ALGORITHM);return?secretKey;}/***?取得私鑰*?*?@param?keyMap*?@return*?@throws?Exception*/public?static?String?getPrivateKey(Map<String,?Object>?keyMap)throws?Exception?{Key?key?=?(Key)?keyMap.get(PRIVATE_KEY);return?encryptBASE64(key.getEncoded());}/***?取得公鑰*?*?@param?keyMap*?@return*?@throws?Exception*/public?static?String?getPublicKey(Map<String,?Object>?keyMap)throws?Exception?{Key?key?=?(Key)?keyMap.get(PUBLIC_KEY);return?encryptBASE64(key.getEncoded());} }



    再給出一個測試類:

    import?static?org.junit.Assert.*;import?java.util.Map;import?org.junit.Test;/***?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?class?DHCoderTest?{@Testpublic?void?test()?throws?Exception?{//?生成甲方密鑰對兒Map<String,?Object>?aKeyMap?=?DHCoder.initKey();String?aPublicKey?=?DHCoder.getPublicKey(aKeyMap);String?aPrivateKey?=?DHCoder.getPrivateKey(aKeyMap);System.err.println("甲方公鑰:\r"?+?aPublicKey);System.err.println("甲方私鑰:\r"?+?aPrivateKey);//?由甲方公鑰產(chǎn)生本地密鑰對兒Map<String,?Object>?bKeyMap?=?DHCoder.initKey(aPublicKey);String?bPublicKey?=?DHCoder.getPublicKey(bKeyMap);String?bPrivateKey?=?DHCoder.getPrivateKey(bKeyMap);System.err.println("乙方公鑰:\r"?+?bPublicKey);System.err.println("乙方私鑰:\r"?+?bPrivateKey);String?aInput?=?"abc?";System.err.println("原文:?"?+?aInput);//?由甲方公鑰,乙方私鑰構(gòu)建密文byte[]?aCode?=?DHCoder.encrypt(aInput.getBytes(),?aPublicKey,bPrivateKey);//?由乙方公鑰,甲方私鑰解密byte[]?aDecode?=?DHCoder.decrypt(aCode,?bPublicKey,?aPrivateKey);String?aOutput?=?(new?String(aDecode));System.err.println("解密:?"?+?aOutput);assertEquals(aInput,?aOutput);System.err.println("?===============反過來加密解密==================?");String?bInput?=?"def?";System.err.println("原文:?"?+?bInput);//?由乙方公鑰,甲方私鑰構(gòu)建密文byte[]?bCode?=?DHCoder.encrypt(bInput.getBytes(),?bPublicKey,aPrivateKey);//?由甲方公鑰,乙方私鑰解密byte[]?bDecode?=?DHCoder.decrypt(bCode,?aPublicKey,?bPrivateKey);String?bOutput?=?(new?String(bDecode));System.err.println("解密:?"?+?bOutput);assertEquals(bInput,?bOutput);}}



    控制臺輸出:

    甲方公鑰: MIHfMIGXBgkqhkiG9w0BAwEwgYkCQQD8poLOjhLKuibvzPcRDlJtsHiwXt7LzR60ogjzrhYXrgHz W5Gkfm32NBPF4S7QiZvNEyrNUNmRUb3EPuc3WS4XAkBnhHGyepz0TukaScUUfbGpqvJE8FpDTWSG kx0tFCcbnjUDC3H9c9oXkGmzLik1Yw4cIGI1TQ2iCmxBblC+eUykAgIBgANDAAJAdAWBVmIzqcko Ej6qFjLDL2+Y3FPq1iRbnOyOpDj71yKaK1K+FhTv04B0zy4DKcvAASV7/Gv0W+bgqdmffRkqrQ==甲方私鑰: MIHRAgEAMIGXBgkqhkiG9w0BAwEwgYkCQQD8poLOjhLKuibvzPcRDlJtsHiwXt7LzR60ogjzrhYX rgHzW5Gkfm32NBPF4S7QiZvNEyrNUNmRUb3EPuc3WS4XAkBnhHGyepz0TukaScUUfbGpqvJE8FpD TWSGkx0tFCcbnjUDC3H9c9oXkGmzLik1Yw4cIGI1TQ2iCmxBblC+eUykAgIBgAQyAjACJRfy1LyR eHyD+4Hfb+xR0uoIGR1oL9i9Nk6g2AAuaDPgEVWHn+QXID13yL/uDos=乙方公鑰: MIHfMIGXBgkqhkiG9w0BAwEwgYkCQQD8poLOjhLKuibvzPcRDlJtsHiwXt7LzR60ogjzrhYXrgHz W5Gkfm32NBPF4S7QiZvNEyrNUNmRUb3EPuc3WS4XAkBnhHGyepz0TukaScUUfbGpqvJE8FpDTWSG kx0tFCcbnjUDC3H9c9oXkGmzLik1Yw4cIGI1TQ2iCmxBblC+eUykAgIBgANDAAJAVEYSfBA+I9nr dWw3OBv475C+eBrWBBYqt0m6/eu4ptuDQHwV4MmUtKAC2wc2nNrdb1wmBhY1X8RnWkJ1XmdDbQ==乙方私鑰: MIHSAgEAMIGXBgkqhkiG9w0BAwEwgYkCQQD8poLOjhLKuibvzPcRDlJtsHiwXt7LzR60ogjzrhYX rgHzW5Gkfm32NBPF4S7QiZvNEyrNUNmRUb3EPuc3WS4XAkBnhHGyepz0TukaScUUfbGpqvJE8FpD TWSGkx0tFCcbnjUDC3H9c9oXkGmzLik1Yw4cIGI1TQ2iCmxBblC+eUykAgIBgAQzAjEAqaZiCdXp 2iNpdBlHRaO9ir70wo2n32xNlIzIX19VLSPCDdeUWkgRv4CEj/8k+/yd原文:?abc? 解密:?abc?===============反過來加密解密==================? 原文:?def? 解密:?def



    如我所言,甲乙雙方在獲得對方公鑰后可以對發(fā)送給對方的數(shù)據(jù)加密,同時也能對接收到的數(shù)據(jù)解密,達到了數(shù)據(jù)安全通信的目的!

    ??? 接下來我們介紹DSA數(shù)字簽名,非對稱加密的另一種實現(xiàn)。?
    DSA?
    DSA-Digital Signature Algorithm 是Schnorr和ElGamal簽名算法的變種,被美國NIST作為DSS(DigitalSignature Standard)。簡單的說,這是一種更高級的驗證方式,用作數(shù)字簽名。不單單只有公鑰、私鑰,還有數(shù)字簽名。私鑰加密生成數(shù)字簽名,公鑰驗證數(shù)據(jù)及簽 名。如果數(shù)據(jù)和簽名不匹配則認為驗證失敗!數(shù)字簽名的作用就是校驗數(shù)據(jù)在傳輸過程中不被修改。數(shù)字簽名,是單向加密的升級!?


  • 通過java代碼實現(xiàn)如下:Coder類見

    import?java.security.Key; import?java.security.KeyFactory; import?java.security.KeyPair; import?java.security.KeyPairGenerator; import?java.security.PrivateKey; import?java.security.PublicKey; import?java.security.SecureRandom; import?java.security.Signature; import?java.security.interfaces.DSAPrivateKey; import?java.security.interfaces.DSAPublicKey; import?java.security.spec.PKCS8EncodedKeySpec; import?java.security.spec.X509EncodedKeySpec; import?java.util.HashMap; import?java.util.Map;/***?DSA安全編碼組件*?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?abstract?class?DSACoder?extends?Coder?{public?static?final?String?ALGORITHM?=?"DSA";/***?默認密鑰字節(jié)數(shù)*?*?<pre>*?DSA?*?Default?Keysize?1024??*?Keysize?must?be?a?multiple?of?64,?ranging?from?512?to?1024?(inclusive).*?</pre>*/private?static?final?int?KEY_SIZE?=?1024;/***?默認種子*/private?static?final?String?DEFAULT_SEED?=?"0f22507a10bbddd07d8a3082122966e3";private?static?final?String?PUBLIC_KEY?=?"DSAPublicKey";private?static?final?String?PRIVATE_KEY?=?"DSAPrivateKey";/***?用私鑰對信息生成數(shù)字簽名*?*?@param?data*????????????加密數(shù)據(jù)*?@param?privateKey*????????????私鑰*?*?@return*?@throws?Exception*/public?static?String?sign(byte[]?data,?String?privateKey)?throws?Exception?{//?解密由base64編碼的私鑰byte[]?keyBytes?=?decryptBASE64(privateKey);//?構(gòu)造PKCS8EncodedKeySpec對象PKCS8EncodedKeySpec?pkcs8KeySpec?=?new?PKCS8EncodedKeySpec(keyBytes);//?KEY_ALGORITHM?指定的加密算法KeyFactory?keyFactory?=?KeyFactory.getInstance(ALGORITHM);//?取私鑰匙對象PrivateKey?priKey?=?keyFactory.generatePrivate(pkcs8KeySpec);//?用私鑰對信息生成數(shù)字簽名Signature?signature?=?Signature.getInstance(keyFactory.getAlgorithm());signature.initSign(priKey);signature.update(data);return?encryptBASE64(signature.sign());}/***?校驗數(shù)字簽名*?*?@param?data*????????????加密數(shù)據(jù)*?@param?publicKey*????????????公鑰*?@param?sign*????????????數(shù)字簽名*?*?@return?校驗成功返回true?失敗返回false*?@throws?Exception*?*/public?static?boolean?verify(byte[]?data,?String?publicKey,?String?sign)throws?Exception?{//?解密由base64編碼的公鑰byte[]?keyBytes?=?decryptBASE64(publicKey);//?構(gòu)造X509EncodedKeySpec對象X509EncodedKeySpec?keySpec?=?new?X509EncodedKeySpec(keyBytes);//?ALGORITHM?指定的加密算法KeyFactory?keyFactory?=?KeyFactory.getInstance(ALGORITHM);//?取公鑰匙對象PublicKey?pubKey?=?keyFactory.generatePublic(keySpec);Signature?signature?=?Signature.getInstance(keyFactory.getAlgorithm());signature.initVerify(pubKey);signature.update(data);//?驗證簽名是否正常return?signature.verify(decryptBASE64(sign));}/***?生成密鑰*?*?@param?seed*????????????種子*?@return?密鑰對象*?@throws?Exception*/public?static?Map<String,?Object>?initKey(String?seed)?throws?Exception?{KeyPairGenerator?keygen?=?KeyPairGenerator.getInstance(ALGORITHM);//?初始化隨機產(chǎn)生器SecureRandom?secureRandom?=?new?SecureRandom();secureRandom.setSeed(seed.getBytes());keygen.initialize(KEY_SIZE,?secureRandom);KeyPair?keys?=?keygen.genKeyPair();DSAPublicKey?publicKey?=?(DSAPublicKey)?keys.getPublic();DSAPrivateKey?privateKey?=?(DSAPrivateKey)?keys.getPrivate();Map<String,?Object>?map?=?new?HashMap<String,?Object>(2);map.put(PUBLIC_KEY,?publicKey);map.put(PRIVATE_KEY,?privateKey);return?map;}/***?默認生成密鑰*?*?@return?密鑰對象*?@throws?Exception*/public?static?Map<String,?Object>?initKey()?throws?Exception?{return?initKey(DEFAULT_SEED);}/***?取得私鑰*?*?@param?keyMap*?@return*?@throws?Exception*/public?static?String?getPrivateKey(Map<String,?Object>?keyMap)throws?Exception?{Key?key?=?(Key)?keyMap.get(PRIVATE_KEY);return?encryptBASE64(key.getEncoded());}/***?取得公鑰*?*?@param?keyMap*?@return*?@throws?Exception*/public?static?String?getPublicKey(Map<String,?Object>?keyMap)throws?Exception?{Key?key?=?(Key)?keyMap.get(PUBLIC_KEY);return?encryptBASE64(key.getEncoded());} }



    再給出一個測試類:

    import?static?org.junit.Assert.*;import?java.util.Map;import?org.junit.Test;/***?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?class?DSACoderTest?{@Testpublic?void?test()?throws?Exception?{String?inputStr?=?"abc";byte[]?data?=?inputStr.getBytes();//?構(gòu)建密鑰Map<String,?Object>?keyMap?=?DSACoder.initKey();//?獲得密鑰String?publicKey?=?DSACoder.getPublicKey(keyMap);String?privateKey?=?DSACoder.getPrivateKey(keyMap);System.err.println("公鑰:\r"?+?publicKey);System.err.println("私鑰:\r"?+?privateKey);//?產(chǎn)生簽名String?sign?=?DSACoder.sign(data,?privateKey);System.err.println("簽名:\r"?+?sign);//?驗證簽名boolean?status?=?DSACoder.verify(data,?publicKey,?sign);System.err.println("狀態(tài):\r"?+?status);assertTrue(status);}}


    控制臺輸出:

    公鑰: MIIBtzCCASwGByqGSM44BAEwggEfAoGBAP1/U4EddRIpUt9KnC7s5Of2EbdSPO9EAMMeP4C2USZp RV1AIlH7WT2NWPq/xfW6MPbLm1Vs14E7gB00b/JmYLdrmVClpJ+f6AR7ECLCT7up1/63xhv4O1fn xqimFQ8E+4P208UewwI1VBNaFpEy9nXzrith1yrv8iIDGZ3RSAHHAhUAl2BQjxUjC8yykrmCouuE C/BYHPUCgYEA9+GghdabPd7LvKtcNrhXuXmUr7v6OuqC+VdMCz0HgmdRWVeOutRZT+ZxBxCBgLRJ FnEj6EwoFhO3zwkyjMim4TwWeotUfI0o4KOuHiuzpnWRbqN/C/ohNWLx+2J6ASQ7zKTxvqhRkImo g9/hWuWfBpKLZl6Ae1UlZAFMO/7PSSoDgYQAAoGAIu4RUlcQLp49PI0MrbssOY+3uySVnp0TULSv 5T4VaHoKzsLHgGTrwOvsGA+V3yCNl2WDu3D84bSLF7liTWgOj+SMOEaPk4VyRTlLXZWGPsf1Mfd9 21XAbMeVyKDSHHVGbMjBScajf3bXooYQMlyoHiOt/WrCo+mv7efstMM0PGo=私鑰: MIIBTAIBADCCASwGByqGSM44BAEwggEfAoGBAP1/U4EddRIpUt9KnC7s5Of2EbdSPO9EAMMeP4C2 USZpRV1AIlH7WT2NWPq/xfW6MPbLm1Vs14E7gB00b/JmYLdrmVClpJ+f6AR7ECLCT7up1/63xhv4 O1fnxqimFQ8E+4P208UewwI1VBNaFpEy9nXzrith1yrv8iIDGZ3RSAHHAhUAl2BQjxUjC8yykrmC ouuEC/BYHPUCgYEA9+GghdabPd7LvKtcNrhXuXmUr7v6OuqC+VdMCz0HgmdRWVeOutRZT+ZxBxCB gLRJFnEj6EwoFhO3zwkyjMim4TwWeotUfI0o4KOuHiuzpnWRbqN/C/ohNWLx+2J6ASQ7zKTxvqhR kImog9/hWuWfBpKLZl6Ae1UlZAFMO/7PSSoEFwIVAIegLUtmm2oQKQJTOiLugHTSjl/q簽名: MC0CFQCMg0J/uZmF8GuRpr3TNq48w60nDwIUJCyYNah+HtbU6NcQfy8Ac6LeLQs=狀態(tài): true



    注意狀態(tài)為true,就驗證成功!

    ECC?
    ECC-Elliptic Curves Cryptography,橢圓曲線密碼編碼學(xué),是目前已知的公鑰體制中,對每比特所提供加密強度最高的一種體制。在軟件注冊保護方面起到很大的作用,一般的序列號通常由該算法產(chǎn)生。?
    ??? 當(dāng)我開始整理《Java加密技術(shù)(二)》的時候,我就已經(jīng)在開始研究ECC了,但是關(guān)于Java實現(xiàn)ECC算法的資料實在是太少了,無論是國內(nèi)還是國外的 資料,無論是官方還是非官方的解釋,最終只有一種答案——ECC算法在jdk1.5后加入支持,目前僅僅只能完成密鑰的生成與解析。 如果想要獲得ECC算法實現(xiàn),需要調(diào)用硬件完成加密/解密(ECC算法相當(dāng)耗費資源,如果單純使用CPU進行加密/解密,效率低下),涉及到Java Card領(lǐng)域,PKCS#11。 其實,PKCS#11配置很簡單,但缺乏硬件設(shè)備,無法嘗試!?

    ??? 盡管如此,我照舊提供相應(yīng)的Java實現(xiàn)代碼,以供大家參考。?

    通過java代碼實現(xiàn)如下:Coder類見

    import?java.math.BigInteger; import?java.security.Key; import?java.security.KeyFactory; import?java.security.interfaces.ECPrivateKey; import?java.security.interfaces.ECPublicKey; import?java.security.spec.ECFieldF2m; import?java.security.spec.ECParameterSpec; import?java.security.spec.ECPoint; import?java.security.spec.ECPrivateKeySpec; import?java.security.spec.ECPublicKeySpec; import?java.security.spec.EllipticCurve; import?java.security.spec.PKCS8EncodedKeySpec; import?java.security.spec.X509EncodedKeySpec; import?java.util.HashMap; import?java.util.Map;import?javax.crypto.Cipher; import?javax.crypto.NullCipher;import?sun.security.ec.ECKeyFactory; import?sun.security.ec.ECPrivateKeyImpl; import?sun.security.ec.ECPublicKeyImpl;/***?ECC安全編碼組件*?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?abstract?class?ECCCoder?extends?Coder?{public?static?final?String?ALGORITHM?=?"EC";private?static?final?String?PUBLIC_KEY?=?"ECCPublicKey";private?static?final?String?PRIVATE_KEY?=?"ECCPrivateKey";/***?解密<br>*?用私鑰解密*?*?@param?data*?@param?key*?@return*?@throws?Exception*/public?static?byte[]?decrypt(byte[]?data,?String?key)?throws?Exception?{//?對密鑰解密byte[]?keyBytes?=?decryptBASE64(key);//?取得私鑰PKCS8EncodedKeySpec?pkcs8KeySpec?=?new?PKCS8EncodedKeySpec(keyBytes);KeyFactory?keyFactory?=?ECKeyFactory.INSTANCE;ECPrivateKey?priKey?=?(ECPrivateKey)?keyFactory.generatePrivate(pkcs8KeySpec);ECPrivateKeySpec?ecPrivateKeySpec?=?new?ECPrivateKeySpec(priKey.getS(),priKey.getParams());//?對數(shù)據(jù)解密//?TODO?Chipher不支持EC算法?未能實現(xiàn)Cipher?cipher?=?new?NullCipher();//?Cipher.getInstance(ALGORITHM,?keyFactory.getProvider());cipher.init(Cipher.DECRYPT_MODE,?priKey,?ecPrivateKeySpec.getParams());return?cipher.doFinal(data);}/***?加密<br>*?用公鑰加密*?*?@param?data*?@param?privateKey*?@return*?@throws?Exception*/public?static?byte[]?encrypt(byte[]?data,?String?privateKey)throws?Exception?{//?對公鑰解密byte[]?keyBytes?=?decryptBASE64(privateKey);//?取得公鑰X509EncodedKeySpec?x509KeySpec?=?new?X509EncodedKeySpec(keyBytes);KeyFactory?keyFactory?=?ECKeyFactory.INSTANCE;ECPublicKey?pubKey?=?(ECPublicKey)?keyFactory.generatePublic(x509KeySpec);ECPublicKeySpec?ecPublicKeySpec?=?new?ECPublicKeySpec(pubKey.getW(),pubKey.getParams());//?對數(shù)據(jù)加密//?TODO?Chipher不支持EC算法?未能實現(xiàn)Cipher?cipher?=?new?NullCipher();//?Cipher.getInstance(ALGORITHM,?keyFactory.getProvider());cipher.init(Cipher.ENCRYPT_MODE,?pubKey,?ecPublicKeySpec.getParams());return?cipher.doFinal(data);}/***?取得私鑰*?*?@param?keyMap*?@return*?@throws?Exception*/public?static?String?getPrivateKey(Map<String,?Object>?keyMap)throws?Exception?{Key?key?=?(Key)?keyMap.get(PRIVATE_KEY);return?encryptBASE64(key.getEncoded());}/***?取得公鑰*?*?@param?keyMap*?@return*?@throws?Exception*/public?static?String?getPublicKey(Map<String,?Object>?keyMap)throws?Exception?{Key?key?=?(Key)?keyMap.get(PUBLIC_KEY);return?encryptBASE64(key.getEncoded());}/***?初始化密鑰*?*?@return*?@throws?Exception*/public?static?Map<String,?Object>?initKey()?throws?Exception?{BigInteger?x1?=?new?BigInteger("2fe13c0537bbc11acaa07d793de4e6d5e5c94eee8",?16);BigInteger?x2?=?new?BigInteger("289070fb05d38ff58321f2e800536d538ccdaa3d9",?16);ECPoint?g?=?new?ECPoint(x1,?x2);//?the?order?of?generatorBigInteger?n?=?new?BigInteger("5846006549323611672814741753598448348329118574063",?10);//?the?cofactorint?h?=?2;int?m?=?163;int[]?ks?=?{?7,?6,?3?};ECFieldF2m?ecField?=?new?ECFieldF2m(m,?ks);//?y^2+xy=x^3+x^2+1BigInteger?a?=?new?BigInteger("1",?2);BigInteger?b?=?new?BigInteger("1",?2);EllipticCurve?ellipticCurve?=?new?EllipticCurve(ecField,?a,?b);ECParameterSpec?ecParameterSpec?=?new?ECParameterSpec(ellipticCurve,?g,n,?h);//?公鑰ECPublicKey?publicKey?=?new?ECPublicKeyImpl(g,?ecParameterSpec);BigInteger?s?=?new?BigInteger("1234006549323611672814741753598448348329118574063",?10);//?私鑰ECPrivateKey?privateKey?=?new?ECPrivateKeyImpl(s,?ecParameterSpec);Map<String,?Object>?keyMap?=?new?HashMap<String,?Object>(2);keyMap.put(PUBLIC_KEY,?publicKey);keyMap.put(PRIVATE_KEY,?privateKey);return?keyMap;}}



    ??? 請注意上述代碼中的TODO內(nèi)容,再次提醒注意,Chipher不支持EC算法?,以上代碼僅供參考。Chipher、Signature、KeyPairGenerator、KeyAgreement、SecretKey均不支持EC算法。為了確保程序能夠正常執(zhí)行,我們使用了NullCipher類,驗證程序。

    照舊提供一個測試類:

    import?static?org.junit.Assert.*;import?java.math.BigInteger; import?java.security.spec.ECFieldF2m; import?java.security.spec.ECParameterSpec; import?java.security.spec.ECPoint; import?java.security.spec.ECPrivateKeySpec; import?java.security.spec.ECPublicKeySpec; import?java.security.spec.EllipticCurve; import?java.util.Map;import?org.junit.Test;/***?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?class?ECCCoderTest?{@Testpublic?void?test()?throws?Exception?{String?inputStr?=?"abc";byte[]?data?=?inputStr.getBytes();Map<String,?Object>?keyMap?=?ECCCoder.initKey();String?publicKey?=?ECCCoder.getPublicKey(keyMap);String?privateKey?=?ECCCoder.getPrivateKey(keyMap);System.err.println("公鑰:?\n"?+?publicKey);System.err.println("私鑰:?\n"?+?privateKey);byte[]?encodedData?=?ECCCoder.encrypt(data,?publicKey);byte[]?decodedData?=?ECCCoder.decrypt(encodedData,?privateKey);String?outputStr?=?new?String(decodedData);System.err.println("加密前:?"?+?inputStr?+?"\n\r"?+?"解密后:?"?+?outputStr);assertEquals(inputStr,?outputStr);} }



    控制臺輸出:

    公鑰:? MEAwEAYHKoZIzj0CAQYFK4EEAAEDLAAEAv4TwFN7vBGsqgfXk95ObV5clO7oAokHD7BdOP9YMh8u gAU21TjM2qPZ私鑰:? MDICAQAwEAYHKoZIzj0CAQYFK4EEAAEEGzAZAgEBBBTYJsR3BN7TFw7JHcAHFkwNmfil7w==加密前:?abc解密后:?abc

    ??? 本篇的主要內(nèi)容為Java證書體系的實現(xiàn)。?

    在構(gòu)建Java代碼實現(xiàn)前,我們需要完成證書的制作。?
    1.生成keyStroe文件?
    在命令行下執(zhí)行以下命令:

    keytool?-genkey?-validity?36000?-alias?www.zlex.org?-keyalg?RSA?-keystore?d:\zlex.keystore



    其中?
    -genkey表示生成密鑰?
    -validity指定證書有效期,這里是36000天?
    -alias指定別名,這里是www.zlex.org?
    -keyalg指定算法,這里是RSA?
    -keystore指定存儲位置,這里是d:\zlex.keystore?

    在這里我使用的密碼為?123456?

    控制臺輸出:

    輸入keystore密碼: 再次輸入新密碼: 您的名字與姓氏是什么?[Unknown]:??www.zlex.org 您的組織單位名稱是什么?[Unknown]:??zlex 您的組織名稱是什么?[Unknown]:??zlex 您所在的城市或區(qū)域名稱是什么?[Unknown]:??BJ 您所在的州或省份名稱是什么?[Unknown]:??BJ 該單位的兩字母國家代碼是什么[Unknown]:??CN CN=www.zlex.org,?OU=zlex,?O=zlex,?L=BJ,?ST=BJ,?C=CN?正確嗎?[否]:??Y輸入<tomcat>的主密碼(如果和?keystore?密碼相同,按回車): 再次輸入新密碼:


    這時,在D盤下會生成一個zlex.keystore的文件。?

    2.生成自簽名證書?
    光有keyStore文件是不夠的,還需要證書文件,證書才是直接提供給外界使用的公鑰憑證。?
    導(dǎo)出證書:

    keytool?-export?-keystore?d:\zlex.keystore?-alias?www.zlex.org?-file?d:\zlex.cer?-rfc



    其中?
    -export指定為導(dǎo)出操作?
    -keystore指定keystore文件?
    -alias指定導(dǎo)出keystore文件中的別名?
    -file指向?qū)С雎窂?
    -rfc以文本格式輸出,也就是以BASE64編碼輸出?
    這里的密碼是?123456?

    控制臺輸出:

    輸入keystore密碼: 保存在文件中的認證?<d:\zlex.cer>



    當(dāng)然,使用方是需要導(dǎo)入證書的!?
    可以通過自簽名證書完成CAS單點登錄系統(tǒng)的構(gòu)建!?

    Ok,準備工作完成,開始Java實現(xiàn)!?

    通過java代碼實現(xiàn)如下:Coder類見

    import?java.io.FileInputStream; import?java.security.KeyStore; import?java.security.PrivateKey; import?java.security.PublicKey; import?java.security.Signature; import?java.security.cert.Certificate; import?java.security.cert.CertificateFactory; import?java.security.cert.X509Certificate; import?java.util.Date;import?javax.crypto.Cipher;/***?證書組件*?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?abstract?class?CertificateCoder?extends?Coder?{/***?Java密鑰庫(Java?Key?Store,JKS)KEY_STORE*/public?static?final?String?KEY_STORE?=?"JKS";public?static?final?String?X509?=?"X.509";/***?由KeyStore獲得私鑰*?*?@param?keyStorePath*?@param?alias*?@param?password*?@return*?@throws?Exception*/private?static?PrivateKey?getPrivateKey(String?keyStorePath,?String?alias,String?password)?throws?Exception?{KeyStore?ks?=?getKeyStore(keyStorePath,?password);PrivateKey?key?=?(PrivateKey)?ks.getKey(alias,?password.toCharArray());return?key;}/***?由Certificate獲得公鑰*?*?@param?certificatePath*?@return*?@throws?Exception*/private?static?PublicKey?getPublicKey(String?certificatePath)throws?Exception?{Certificate?certificate?=?getCertificate(certificatePath);PublicKey?key?=?certificate.getPublicKey();return?key;}/***?獲得Certificate*?*?@param?certificatePath*?@return*?@throws?Exception*/private?static?Certificate?getCertificate(String?certificatePath)throws?Exception?{CertificateFactory?certificateFactory?=?CertificateFactory.getInstance(X509);FileInputStream?in?=?new?FileInputStream(certificatePath);Certificate?certificate?=?certificateFactory.generateCertificate(in);in.close();return?certificate;}/***?獲得Certificate*?*?@param?keyStorePath*?@param?alias*?@param?password*?@return*?@throws?Exception*/private?static?Certificate?getCertificate(String?keyStorePath,String?alias,?String?password)?throws?Exception?{KeyStore?ks?=?getKeyStore(keyStorePath,?password);Certificate?certificate?=?ks.getCertificate(alias);return?certificate;}/***?獲得KeyStore*?*?@param?keyStorePath*?@param?password*?@return*?@throws?Exception*/private?static?KeyStore?getKeyStore(String?keyStorePath,?String?password)throws?Exception?{FileInputStream?is?=?new?FileInputStream(keyStorePath);KeyStore?ks?=?KeyStore.getInstance(KEY_STORE);ks.load(is,?password.toCharArray());is.close();return?ks;}/***?私鑰加密*?*?@param?data*?@param?keyStorePath*?@param?alias*?@param?password*?@return*?@throws?Exception*/public?static?byte[]?encryptByPrivateKey(byte[]?data,?String?keyStorePath,String?alias,?String?password)?throws?Exception?{//?取得私鑰PrivateKey?privateKey?=?getPrivateKey(keyStorePath,?alias,?password);//?對數(shù)據(jù)加密Cipher?cipher?=?Cipher.getInstance(privateKey.getAlgorithm());cipher.init(Cipher.ENCRYPT_MODE,?privateKey);return?cipher.doFinal(data);}/***?私鑰解密*?*?@param?data*?@param?keyStorePath*?@param?alias*?@param?password*?@return*?@throws?Exception*/public?static?byte[]?decryptByPrivateKey(byte[]?data,?String?keyStorePath,String?alias,?String?password)?throws?Exception?{//?取得私鑰PrivateKey?privateKey?=?getPrivateKey(keyStorePath,?alias,?password);//?對數(shù)據(jù)加密Cipher?cipher?=?Cipher.getInstance(privateKey.getAlgorithm());cipher.init(Cipher.DECRYPT_MODE,?privateKey);return?cipher.doFinal(data);}/***?公鑰加密*?*?@param?data*?@param?certificatePath*?@return*?@throws?Exception*/public?static?byte[]?encryptByPublicKey(byte[]?data,?String?certificatePath)throws?Exception?{//?取得公鑰PublicKey?publicKey?=?getPublicKey(certificatePath);//?對數(shù)據(jù)加密Cipher?cipher?=?Cipher.getInstance(publicKey.getAlgorithm());cipher.init(Cipher.ENCRYPT_MODE,?publicKey);return?cipher.doFinal(data);}/***?公鑰解密*?*?@param?data*?@param?certificatePath*?@return*?@throws?Exception*/public?static?byte[]?decryptByPublicKey(byte[]?data,?String?certificatePath)throws?Exception?{//?取得公鑰PublicKey?publicKey?=?getPublicKey(certificatePath);//?對數(shù)據(jù)加密Cipher?cipher?=?Cipher.getInstance(publicKey.getAlgorithm());cipher.init(Cipher.DECRYPT_MODE,?publicKey);return?cipher.doFinal(data);}/***?驗證Certificate*?*?@param?certificatePath*?@return*/public?static?boolean?verifyCertificate(String?certificatePath)?{return?verifyCertificate(new?Date(),?certificatePath);}/***?驗證Certificate是否過期或無效*?*?@param?date*?@param?certificatePath*?@return*/public?static?boolean?verifyCertificate(Date?date,?String?certificatePath)?{boolean?status?=?true;try?{//?取得證書Certificate?certificate?=?getCertificate(certificatePath);//?驗證證書是否過期或無效status?=?verifyCertificate(date,?certificate);}?catch?(Exception?e)?{status?=?false;}return?status;}/***?驗證證書是否過期或無效*?*?@param?date*?@param?certificate*?@return*/private?static?boolean?verifyCertificate(Date?date,?Certificate?certificate)?{boolean?status?=?true;try?{X509Certificate?x509Certificate?=?(X509Certificate)?certificate;x509Certificate.checkValidity(date);}?catch?(Exception?e)?{status?=?false;}return?status;}/***?簽名*?*?@param?keyStorePath*?@param?alias*?@param?password*?*?@return*?@throws?Exception*/public?static?String?sign(byte[]?sign,?String?keyStorePath,?String?alias,String?password)?throws?Exception?{//?獲得證書X509Certificate?x509Certificate?=?(X509Certificate)?getCertificate(keyStorePath,?alias,?password);//?獲取私鑰KeyStore?ks?=?getKeyStore(keyStorePath,?password);//?取得私鑰PrivateKey?privateKey?=?(PrivateKey)?ks.getKey(alias,?password.toCharArray());//?構(gòu)建簽名Signature?signature?=?Signature.getInstance(x509Certificate.getSigAlgName());signature.initSign(privateKey);signature.update(sign);return?encryptBASE64(signature.sign());}/***?驗證簽名*?*?@param?data*?@param?sign*?@param?certificatePath*?@return*?@throws?Exception*/public?static?boolean?verify(byte[]?data,?String?sign,String?certificatePath)?throws?Exception?{//?獲得證書X509Certificate?x509Certificate?=?(X509Certificate)?getCertificate(certificatePath);//?獲得公鑰PublicKey?publicKey?=?x509Certificate.getPublicKey();//?構(gòu)建簽名Signature?signature?=?Signature.getInstance(x509Certificate.getSigAlgName());signature.initVerify(publicKey);signature.update(data);return?signature.verify(decryptBASE64(sign));}/***?驗證Certificate*?*?@param?keyStorePath*?@param?alias*?@param?password*?@return*/public?static?boolean?verifyCertificate(Date?date,?String?keyStorePath,String?alias,?String?password)?{boolean?status?=?true;try?{Certificate?certificate?=?getCertificate(keyStorePath,?alias,password);status?=?verifyCertificate(date,?certificate);}?catch?(Exception?e)?{status?=?false;}return?status;}/***?驗證Certificate*?*?@param?keyStorePath*?@param?alias*?@param?password*?@return*/public?static?boolean?verifyCertificate(String?keyStorePath,?String?alias,String?password)?{return?verifyCertificate(new?Date(),?keyStorePath,?alias,?password);} }



    再給出一個測試類:

    import?static?org.junit.Assert.*;import?org.junit.Test;/***?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?class?CertificateCoderTest?{private?String?password?=?"123456";private?String?alias?=?"www.zlex.org";private?String?certificatePath?=?"d:/zlex.cer";private?String?keyStorePath?=?"d:/zlex.keystore";@Testpublic?void?test()?throws?Exception?{System.err.println("公鑰加密——私鑰解密");String?inputStr?=?"Ceritifcate";byte[]?data?=?inputStr.getBytes();byte[]?encrypt?=?CertificateCoder.encryptByPublicKey(data,certificatePath);byte[]?decrypt?=?CertificateCoder.decryptByPrivateKey(encrypt,keyStorePath,?alias,?password);String?outputStr?=?new?String(decrypt);System.err.println("加密前:?"?+?inputStr?+?"\n\r"?+?"解密后:?"?+?outputStr);//?驗證數(shù)據(jù)一致assertArrayEquals(data,?decrypt);//?驗證證書有效assertTrue(CertificateCoder.verifyCertificate(certificatePath));}@Testpublic?void?testSign()?throws?Exception?{System.err.println("私鑰加密——公鑰解密");String?inputStr?=?"sign";byte[]?data?=?inputStr.getBytes();byte[]?encodedData?=?CertificateCoder.encryptByPrivateKey(data,keyStorePath,?alias,?password);byte[]?decodedData?=?CertificateCoder.decryptByPublicKey(encodedData,certificatePath);String?outputStr?=?new?String(decodedData);System.err.println("加密前:?"?+?inputStr?+?"\n\r"?+?"解密后:?"?+?outputStr);assertEquals(inputStr,?outputStr);System.err.println("私鑰簽名——公鑰驗證簽名");//?產(chǎn)生簽名String?sign?=?CertificateCoder.sign(encodedData,?keyStorePath,?alias,password);System.err.println("簽名:\r"?+?sign);//?驗證簽名boolean?status?=?CertificateCoder.verify(encodedData,?sign,certificatePath);System.err.println("狀態(tài):\r"?+?status);assertTrue(status);} }



    控制臺輸出:

    公鑰加密——私鑰解密 加密前:?Ceritificate解密后:?Ceritificate私鑰加密——公鑰解密 加密前:?sign解密后:?sign 私鑰簽名——公鑰驗證簽名 簽名: pqBn5m6PJlfOjH0A6U2o2mUmBsfgyEY1NWCbiyA/I5Gc3gaVNVIdj/zkGNZRqTjhf3+J9a9z9EI7 6F2eWYd7punHx5oh6hfNgcKbVb52EfItl4QEN+djbXiPynn07+Lbg1NOjULnpEd6ZhLP1YwrEAuM OfvX0e7/wplxLbySaKQ=狀態(tài): true



    由此完成了證書驗證體系!?

    同樣,我們可以對代碼做簽名——代碼簽名!?
    通過工具JarSigner可以完成代碼簽名。?
    這里我們對tools.jar做代碼簽名,命令如下:

    jarsigner?-storetype?jks?-keystore?zlex.keystore?-verbose?tools.jar?www.zlex.org


    控制臺輸出:

    輸入密鑰庫的口令短語:正在更新:?META-INF/WWW_ZLEX.SF正在更新:?META-INF/WWW_ZLEX.RSA正在簽名:?org/zlex/security/Security.class正在簽名:?org/zlex/tool/Main$1.class正在簽名:?org/zlex/tool/Main$2.class正在簽名:?org/zlex/tool/Main.class警告: 簽名者證書將在六個月內(nèi)過期。



    此時,我們可以對簽名后的jar做驗證!?
    驗證tools.jar,命令如下:

    jarsigner?-verify?-verbose?-certs?tools.jar


    控制臺輸出:

    ?????????402?Sat?Jun?20?16:25:14?CST?2009?META-INF/MANIFEST.MF532?Sat?Jun?20?16:25:14?CST?2009?META-INF/WWW_ZLEX.SF889?Sat?Jun?20?16:25:14?CST?2009?META-INF/WWW_ZLEX.RSA sm???????590?Wed?Dec?10?13:03:42?CST?2008?org/zlex/security/Security.classX.509,?CN=www.zlex.org,?OU=zlex,?O=zlex,?L=BJ,?ST=BJ,?C=CN[證書將在?09-9-18?下午3:27?到期]sm???????705?Tue?Dec?16?18:00:56?CST?2008?org/zlex/tool/Main$1.classX.509,?CN=www.zlex.org,?OU=zlex,?O=zlex,?L=BJ,?ST=BJ,?C=CN[證書將在?09-9-18?下午3:27?到期]sm???????779?Tue?Dec?16?18:00:56?CST?2008?org/zlex/tool/Main$2.classX.509,?CN=www.zlex.org,?OU=zlex,?O=zlex,?L=BJ,?ST=BJ,?C=CN[證書將在?09-9-18?下午3:27?到期]sm?????12672?Tue?Dec?16?18:00:56?CST?2008?org/zlex/tool/Main.classX.509,?CN=www.zlex.org,?OU=zlex,?O=zlex,?L=BJ,?ST=BJ,?C=CN[證書將在?09-9-18?下午3:27?到期]s?=?已驗證簽名m?=?在清單中列出條目k?=?在密鑰庫中至少找到了一個證書i?=?在身份作用域內(nèi)至少找到了一個證書jar?已驗證。警告: 此?jar?包含簽名者證書將在六個月內(nèi)過期的條目。



    代碼簽名認證的用途主要是對發(fā)布的軟件做驗證,支持 Sun Java .jar (Java Applet) 文件(J2SE)和 J2ME MIDlet Suite 文件。?

    ??? 在中,我們模擬了一個基于RSA非對稱加密網(wǎng)絡(luò)的安全通信。現(xiàn)在我們深度了解一下現(xiàn)有的安全網(wǎng)絡(luò)通信——SSL。?
    ??? 我們需要構(gòu)建一個由CA機構(gòu)簽發(fā)的有效證書,這里我們使用上文中生成的自簽名證書zlex.cer?
    ??? 這里,我們將證書導(dǎo)入到我們的密鑰庫。?

    keytool?-import?-alias?www.zlex.org?-file?d:/zlex.cer?-keystore?d:/zlex.keystore



    其中?
    -import表示導(dǎo)入?
    -alias指定別名,這里是www.zlex.org?
    -file指定算法,這里是d:/zlex.cer?
    -keystore指定存儲位置,這里是d:/zlex.keystore?
    在這里我使用的密碼為654321?

    控制臺輸出:

    輸入keystore密碼: 再次輸入新密碼: 所有者:CN=www.zlex.org,?OU=zlex,?O=zlex,?L=BJ,?ST=BJ,?C=CN 簽發(fā)人:CN=www.zlex.org,?OU=zlex,?O=zlex,?L=BJ,?ST=BJ,?C=CN 序列號:4a1e48df 有效期:?Thu?May?28?16:18:39?CST?2009?至Wed?Aug?26?16:18:39?CST?2009 證書指紋:MD5:19:CA:E6:36:E2:DF:AD:96:31:97:2F:A9:AD:FC:37:6ASHA1:49:88:30:59:29:45:F1:69:CA:97:A9:6D:8A:CF:08:D2:C3:D5:C0:C4簽名算法名稱:SHA1withRSA版本:?3 信任這個認證??[否]:??y 認證已添加至keystore中



    OK,最復(fù)雜的準備工作已經(jīng)完成。?
    接下來我們將域名www.zlex.org定位到本機上。打開C:\Windows\System32\drivers\etc\hosts文件,將www.zlex.org綁定在本機上。在文件末尾追加127.0.0.1?????? www.zlex.org。現(xiàn)在通過地址欄訪問http://www.zlex.org,或者通過ping命令,如果能夠定位到本機,域名映射就搞定了。?
    現(xiàn)在,配置tomcat。先將zlex.keystore拷貝到tomcat的conf目錄下,然后配置server.xml。將如下內(nèi)容加入配置文件

    <ConnectorSSLEnabled="true"URIEncoding="UTF-8"clientAuth="false"keystoreFile="conf/zlex.keystore"keystorePass="123456"maxThreads="150"port="443"protocol="HTTP/1.1"scheme="https"secure="true"sslProtocol="TLS"?/>


    注意clientAuth="false"測試階段,置為false,正式使用時建議使用true。現(xiàn)在啟動tomcat,訪問https://www.zlex.org/。?
    顯然,證書未能通過認證,這個時候你可以選擇安裝證書(上文中的zlex.cer文件就是證書),作為受信任的根證書頒發(fā)機構(gòu)導(dǎo)入,再次重啟瀏覽器(IE,其他瀏覽器對于域名www.zlex.org不支持本地方式訪問),訪問https://www.zlex.org/,你會看到地址欄中會有個小鎖,就說明安裝成功。所有的瀏覽器聯(lián)網(wǎng)操作已經(jīng)在RSA加密解密系統(tǒng)的保護之下了。但似乎我們感受不到。?
    這個時候很多人開始懷疑,如果我們要手工做一個這樣的https的訪問是不是需要把瀏覽器的這些個功能都實現(xiàn)呢?不需要!?

    接著上篇內(nèi)容,給出如下代碼實現(xiàn):

    import?java.io.FileInputStream; import?java.security.KeyStore; import?java.security.PrivateKey; import?java.security.PublicKey; import?java.security.Signature; import?java.security.cert.Certificate; import?java.security.cert.CertificateFactory; import?java.security.cert.X509Certificate; import?java.util.Date;import?javax.crypto.Cipher; import?javax.net.ssl.HttpsURLConnection; import?javax.net.ssl.KeyManagerFactory; import?javax.net.ssl.SSLContext; import?javax.net.ssl.SSLSocketFactory; import?javax.net.ssl.TrustManagerFactory;/***?證書組件*?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?abstract?class?CertificateCoder?extends?Coder?{/***?Java密鑰庫(Java?Key?Store,JKS)KEY_STORE*/public?static?final?String?KEY_STORE?=?"JKS";public?static?final?String?X509?=?"X.509";public?static?final?String?SunX509?=?"SunX509";public?static?final?String?SSL?=?"SSL";/***?由KeyStore獲得私鑰*?*?@param?keyStorePath*?@param?alias*?@param?password*?@return*?@throws?Exception*/private?static?PrivateKey?getPrivateKey(String?keyStorePath,?String?alias,String?password)?throws?Exception?{KeyStore?ks?=?getKeyStore(keyStorePath,?password);PrivateKey?key?=?(PrivateKey)?ks.getKey(alias,?password.toCharArray());return?key;}/***?由Certificate獲得公鑰*?*?@param?certificatePath*?@return*?@throws?Exception*/private?static?PublicKey?getPublicKey(String?certificatePath)throws?Exception?{Certificate?certificate?=?getCertificate(certificatePath);PublicKey?key?=?certificate.getPublicKey();return?key;}/***?獲得Certificate*?*?@param?certificatePath*?@return*?@throws?Exception*/private?static?Certificate?getCertificate(String?certificatePath)throws?Exception?{CertificateFactory?certificateFactory?=?CertificateFactory.getInstance(X509);FileInputStream?in?=?new?FileInputStream(certificatePath);Certificate?certificate?=?certificateFactory.generateCertificate(in);in.close();return?certificate;}/***?獲得Certificate*?*?@param?keyStorePath*?@param?alias*?@param?password*?@return*?@throws?Exception*/private?static?Certificate?getCertificate(String?keyStorePath,String?alias,?String?password)?throws?Exception?{KeyStore?ks?=?getKeyStore(keyStorePath,?password);Certificate?certificate?=?ks.getCertificate(alias);return?certificate;}/***?獲得KeyStore*?*?@param?keyStorePath*?@param?password*?@return*?@throws?Exception*/private?static?KeyStore?getKeyStore(String?keyStorePath,?String?password)throws?Exception?{FileInputStream?is?=?new?FileInputStream(keyStorePath);KeyStore?ks?=?KeyStore.getInstance(KEY_STORE);ks.load(is,?password.toCharArray());is.close();return?ks;}/***?私鑰加密*?*?@param?data*?@param?keyStorePath*?@param?alias*?@param?password*?@return*?@throws?Exception*/public?static?byte[]?encryptByPrivateKey(byte[]?data,?String?keyStorePath,String?alias,?String?password)?throws?Exception?{//?取得私鑰PrivateKey?privateKey?=?getPrivateKey(keyStorePath,?alias,?password);//?對數(shù)據(jù)加密Cipher?cipher?=?Cipher.getInstance(privateKey.getAlgorithm());cipher.init(Cipher.ENCRYPT_MODE,?privateKey);return?cipher.doFinal(data);}/***?私鑰解密*?*?@param?data*?@param?keyStorePath*?@param?alias*?@param?password*?@return*?@throws?Exception*/public?static?byte[]?decryptByPrivateKey(byte[]?data,?String?keyStorePath,String?alias,?String?password)?throws?Exception?{//?取得私鑰PrivateKey?privateKey?=?getPrivateKey(keyStorePath,?alias,?password);//?對數(shù)據(jù)加密Cipher?cipher?=?Cipher.getInstance(privateKey.getAlgorithm());cipher.init(Cipher.DECRYPT_MODE,?privateKey);return?cipher.doFinal(data);}/***?公鑰加密*?*?@param?data*?@param?certificatePath*?@return*?@throws?Exception*/public?static?byte[]?encryptByPublicKey(byte[]?data,?String?certificatePath)throws?Exception?{//?取得公鑰PublicKey?publicKey?=?getPublicKey(certificatePath);//?對數(shù)據(jù)加密Cipher?cipher?=?Cipher.getInstance(publicKey.getAlgorithm());cipher.init(Cipher.ENCRYPT_MODE,?publicKey);return?cipher.doFinal(data);}/***?公鑰解密*?*?@param?data*?@param?certificatePath*?@return*?@throws?Exception*/public?static?byte[]?decryptByPublicKey(byte[]?data,?String?certificatePath)throws?Exception?{//?取得公鑰PublicKey?publicKey?=?getPublicKey(certificatePath);//?對數(shù)據(jù)加密Cipher?cipher?=?Cipher.getInstance(publicKey.getAlgorithm());cipher.init(Cipher.DECRYPT_MODE,?publicKey);return?cipher.doFinal(data);}/***?驗證Certificate*?*?@param?certificatePath*?@return*/public?static?boolean?verifyCertificate(String?certificatePath)?{return?verifyCertificate(new?Date(),?certificatePath);}/***?驗證Certificate是否過期或無效*?*?@param?date*?@param?certificatePath*?@return*/public?static?boolean?verifyCertificate(Date?date,?String?certificatePath)?{boolean?status?=?true;try?{//?取得證書Certificate?certificate?=?getCertificate(certificatePath);//?驗證證書是否過期或無效status?=?verifyCertificate(date,?certificate);}?catch?(Exception?e)?{status?=?false;}return?status;}/***?驗證證書是否過期或無效*?*?@param?date*?@param?certificate*?@return*/private?static?boolean?verifyCertificate(Date?date,?Certificate?certificate)?{boolean?status?=?true;try?{X509Certificate?x509Certificate?=?(X509Certificate)?certificate;x509Certificate.checkValidity(date);}?catch?(Exception?e)?{status?=?false;}return?status;}/***?簽名*?*?@param?keyStorePath*?@param?alias*?@param?password*?*?@return*?@throws?Exception*/public?static?String?sign(byte[]?sign,?String?keyStorePath,?String?alias,String?password)?throws?Exception?{//?獲得證書X509Certificate?x509Certificate?=?(X509Certificate)?getCertificate(keyStorePath,?alias,?password);//?獲取私鑰KeyStore?ks?=?getKeyStore(keyStorePath,?password);//?取得私鑰PrivateKey?privateKey?=?(PrivateKey)?ks.getKey(alias,?password.toCharArray());//?構(gòu)建簽名Signature?signature?=?Signature.getInstance(x509Certificate.getSigAlgName());signature.initSign(privateKey);signature.update(sign);return?encryptBASE64(signature.sign());}/***?驗證簽名*?*?@param?data*?@param?sign*?@param?certificatePath*?@return*?@throws?Exception*/public?static?boolean?verify(byte[]?data,?String?sign,String?certificatePath)?throws?Exception?{//?獲得證書X509Certificate?x509Certificate?=?(X509Certificate)?getCertificate(certificatePath);//?獲得公鑰PublicKey?publicKey?=?x509Certificate.getPublicKey();//?構(gòu)建簽名Signature?signature?=?Signature.getInstance(x509Certificate.getSigAlgName());signature.initVerify(publicKey);signature.update(data);return?signature.verify(decryptBASE64(sign));}/***?驗證Certificate*?*?@param?keyStorePath*?@param?alias*?@param?password*?@return*/public?static?boolean?verifyCertificate(Date?date,?String?keyStorePath,String?alias,?String?password)?{boolean?status?=?true;try?{Certificate?certificate?=?getCertificate(keyStorePath,?alias,password);status?=?verifyCertificate(date,?certificate);}?catch?(Exception?e)?{status?=?false;}return?status;}/***?驗證Certificate*?*?@param?keyStorePath*?@param?alias*?@param?password*?@return*/public?static?boolean?verifyCertificate(String?keyStorePath,?String?alias,String?password)?{return?verifyCertificate(new?Date(),?keyStorePath,?alias,?password);}/***?獲得SSLSocektFactory*?*?@param?password*????????????密碼*?@param?keyStorePath*????????????密鑰庫路徑*?*?@param?trustKeyStorePath*????????????信任庫路徑*?@return*?@throws?Exception*/private?static?SSLSocketFactory?getSSLSocketFactory(String?password,String?keyStorePath,?String?trustKeyStorePath)?throws?Exception?{//?初始化密鑰庫KeyManagerFactory?keyManagerFactory?=?KeyManagerFactory.getInstance(SunX509);KeyStore?keyStore?=?getKeyStore(keyStorePath,?password);keyManagerFactory.init(keyStore,?password.toCharArray());//?初始化信任庫TrustManagerFactory?trustManagerFactory?=?TrustManagerFactory.getInstance(SunX509);KeyStore?trustkeyStore?=?getKeyStore(trustKeyStorePath,?password);trustManagerFactory.init(trustkeyStore);//?初始化SSL上下文SSLContext?ctx?=?SSLContext.getInstance(SSL);ctx.init(keyManagerFactory.getKeyManagers(),?trustManagerFactory.getTrustManagers(),?null);SSLSocketFactory?sf?=?ctx.getSocketFactory();return?sf;}/***?為HttpsURLConnection配置SSLSocketFactory*?*?@param?conn*????????????HttpsURLConnection*?@param?password*????????????密碼*?@param?keyStorePath*????????????密鑰庫路徑*?*?@param?trustKeyStorePath*????????????信任庫路徑*?@throws?Exception*/public?static?void?configSSLSocketFactory(HttpsURLConnection?conn,String?password,?String?keyStorePath,?String?trustKeyStorePath)throws?Exception?{conn.setSSLSocketFactory(getSSLSocketFactory(password,?keyStorePath,trustKeyStorePath));} }



    增加了configSSLSocketFactory方法供外界調(diào)用,該方法為 HttpsURLConnection配置了SSLSocketFactory。當(dāng)HttpsURLConnection配置了 SSLSocketFactory后,我們就可以通過HttpsURLConnection的getInputStream、 getOutputStream,像往常使用HttpURLConnection做操作了。尤其要說明一點,未配置SSLSocketFactory 前,HttpsURLConnection的getContentLength()獲得值永遠都是-1。?

    給出相應(yīng)測試類:

    import?static?org.junit.Assert.*;import?java.io.DataInputStream; import?java.io.InputStream; import?java.net.URL;import?javax.net.ssl.HttpsURLConnection;import?org.junit.Test;/***?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?class?CertificateCoderTest?{private?String?password?=?"123456";private?String?alias?=?"www.zlex.org";private?String?certificatePath?=?"d:/zlex.cer";private?String?keyStorePath?=?"d:/zlex.keystore";private?String?clientKeyStorePath?=?"d:/zlex-client.keystore";private?String?clientPassword?=?"654321";@Testpublic?void?test()?throws?Exception?{System.err.println("公鑰加密——私鑰解密");String?inputStr?=?"Ceritifcate";byte[]?data?=?inputStr.getBytes();byte[]?encrypt?=?CertificateCoder.encryptByPublicKey(data,certificatePath);byte[]?decrypt?=?CertificateCoder.decryptByPrivateKey(encrypt,keyStorePath,?alias,?password);String?outputStr?=?new?String(decrypt);System.err.println("加密前:?"?+?inputStr?+?"\n\r"?+?"解密后:?"?+?outputStr);//?驗證數(shù)據(jù)一致assertArrayEquals(data,?decrypt);//?驗證證書有效assertTrue(CertificateCoder.verifyCertificate(certificatePath));}@Testpublic?void?testSign()?throws?Exception?{System.err.println("私鑰加密——公鑰解密");String?inputStr?=?"sign";byte[]?data?=?inputStr.getBytes();byte[]?encodedData?=?CertificateCoder.encryptByPrivateKey(data,keyStorePath,?alias,?password);byte[]?decodedData?=?CertificateCoder.decryptByPublicKey(encodedData,certificatePath);String?outputStr?=?new?String(decodedData);System.err.println("加密前:?"?+?inputStr?+?"\n\r"?+?"解密后:?"?+?outputStr);assertEquals(inputStr,?outputStr);System.err.println("私鑰簽名——公鑰驗證簽名");//?產(chǎn)生簽名String?sign?=?CertificateCoder.sign(encodedData,?keyStorePath,?alias,password);System.err.println("簽名:\r"?+?sign);//?驗證簽名boolean?status?=?CertificateCoder.verify(encodedData,?sign,certificatePath);System.err.println("狀態(tài):\r"?+?status);assertTrue(status);}@Testpublic?void?testHttps()?throws?Exception?{URL?url?=?new?URL("https://www.zlex.org/examples/");HttpsURLConnection?conn?=?(HttpsURLConnection)?url.openConnection();conn.setDoInput(true);conn.setDoOutput(true);CertificateCoder.configSSLSocketFactory(conn,?clientPassword,clientKeyStorePath,?clientKeyStorePath);InputStream?is?=?conn.getInputStream();int?length?=?conn.getContentLength();DataInputStream?dis?=?new?DataInputStream(is);byte[]?data?=?new?byte[length];dis.readFully(data);dis.close();System.err.println(new?String(data));conn.disconnect();} }


    注意testHttps方法,幾乎和我們往常做HTTP訪問沒有差別,我們來看控制臺輸出:

    <!--Licensed?to?the?Apache?Software?Foundation?(ASF)?under?one?or?morecontributor?license?agreements.??See?the?NOTICE?file?distributed?withthis?work?for?additional?information?regarding?copyright?ownership.The?ASF?licenses?this?file?to?You?under?the?Apache?License,?Version?2.0(the?"License");?you?may?not?use?this?file?except?in?compliance?withthe?License.??You?may?obtain?a?copy?of?the?License?athttp://www.apache.org/licenses/LICENSE-2.0Unless?required?by?applicable?law?or?agreed?to?in?writing,?softwaredistributed?under?the?License?is?distributed?on?an?"AS?IS"?BASIS,WITHOUT?WARRANTIES?OR?CONDITIONS?OF?ANY?KIND,?either?express?or?implied.See?the?License?for?the?specific?language?governing?permissions?andlimitations?under?the?License. --> <!DOCTYPE?HTML?PUBLIC?"-//W3C//DTD?HTML?4.0?Transitional//EN"> <HTML><HEAD><TITLE>Apache?Tomcat?Examples</TITLE> <META?http-equiv=Content-Type?content="text/html"> </HEAD> <BODY> <P> <H3>Apache?Tomcat?Examples</H3> <P></P> <ul> <li><a?href="http://javaeye.shaduwang.com/?snowolf/blog/servlets">Servlets?examples</a></li> <li><a?href="http://javaeye.shaduwang.com/?snowolf/blog/jsp">JSP?Examples</a></li> </ul> </BODY></HTML>


    通過瀏覽器直接訪問https://www.zlex.org/examples/你 也會獲得上述內(nèi)容。也就是說應(yīng)用甲方作為服務(wù)器構(gòu)建tomcat服務(wù),乙方可以通過上述方式訪問甲方受保護的SSL應(yīng)用,并且不需要考慮具體的加密解密問 題。甲乙雙方可以經(jīng)過相應(yīng)配置,通過雙方的tomcat配置有效的SSL服務(wù),簡化上述代碼實現(xiàn),完全通過證書配置完成SSL雙向認證!

    ??? 我們使用自簽名證書完成了認證。接下來,我們使用第三方CA簽名機構(gòu)完成證書簽名。?
    ??? 這里我們使用thawte提供的測試用21天免費ca證書。?
    ??? 1.要在該網(wǎng)站上注明你的域名,這里使用www.zlex.org作為測試用域名(請勿使用該域名作為你的域名地址,該域名受法律保護!請使用其他非注冊域名!)。?
    ??? 2.如果域名有效,你會收到郵件要求你訪問https://www.thawte.com/cgi/server/try.exe獲得ca證書。?
    ??? 3.復(fù)述密鑰庫的創(chuàng)建。

    keytool?-genkey?-validity?36000?-alias?www.zlex.org?-keyalg?RSA?-keystore?d:\zlex.keystore



    在這里我使用的密碼為?123456?

    控制臺輸出:

    輸入keystore密碼: 再次輸入新密碼: 您的名字與姓氏是什么?[Unknown]:??www.zlex.org 您的組織單位名稱是什么?[Unknown]:??zlex 您的組織名稱是什么?[Unknown]:??zlex 您所在的城市或區(qū)域名稱是什么?[Unknown]:??BJ 您所在的州或省份名稱是什么?[Unknown]:??BJ 該單位的兩字母國家代碼是什么[Unknown]:??CN CN=www.zlex.org,?OU=zlex,?O=zlex,?L=BJ,?ST=BJ,?C=CN?正確嗎?[否]:??Y輸入<tomcat>的主密碼(如果和?keystore?密碼相同,按回車): 再次輸入新密碼:



    ??? 4.通過如下命令,從zlex.keystore中導(dǎo)出CA證書申請。?
    ???

    keytool?-certreq?-alias?www.zlex.org?-file?d:\zlex.csr?-keystore?d:\zlex.keystore?-v

    你會獲得zlex.csr文件,可以用記事本打開,內(nèi)容如下格式:

    -----BEGIN?NEW?CERTIFICATE?REQUEST----- MIIBnDCCAQUCAQAwXDELMAkGA1UEBhMCQ04xCzAJBgNVBAgTAkJKMQswCQYDVQQHEwJCSjENMAsG A1UEChMEemxleDENMAsGA1UECxMEemxleDEVMBMGA1UEAxMMd3d3LnpsZXgub3JnMIGfMA0GCSqG SIb3DQEBAQUAA4GNADCBiQKBgQCR6DXU9Mp+mCKO7cv9JPsj0n1Ec/GpM09qvhpgX3FNad/ZWSDc vU77YXZSoF9hQp3w1LC+eeKgd2MlVpXTvbVwBNVd2HiQPp37ic6BUUjSaX8LHtCl7l0BIEye9qQ2 j8G0kak7e8ZA0s7nb3Ymq/K8BV7v0MQIdhIc1bifK9ZDewIDAQABoAAwDQYJKoZIhvcNAQEFBQAD gYEAMA1r2fbZPtNx37U9TRwadCH2TZZecwKJS/hskNm6ryPKIAp9APWwAyj8WJHRBz5SpZM4zmYO oMCI8BcnY2A4JP+R7/SwXTdH/xcg7NVghd9A2SCgqMpF7KMfc5dE3iygdiPu+UhY200Dvpjx8gmJ 1UbH3+nqMUyCrZgURFslOUY= -----END?NEW?CERTIFICATE?REQUEST-----


    ??? 5.將上述文件內(nèi)容拷貝到https://www.thawte.com/cgi/server/try.exe中,點擊next,獲得回應(yīng)內(nèi)容,這里是p7b格式。?
    內(nèi)容如下:

    -----BEGIN?PKCS7----- MIIF3AYJKoZIhvcNAQcCoIIFzTCCBckCAQExADALBgkqhkiG9w0BBwGgggWxMIID EDCCAnmgAwIBAgIQA/mx/pKoaB+KGX2hveFU9zANBgkqhkiG9w0BAQUFADCBhzEL MAkGA1UEBhMCWkExIjAgBgNVBAgTGUZPUiBURVNUSU5HIFBVUlBPU0VTIE9OTFkx HTAbBgNVBAoTFFRoYXd0ZSBDZXJ0aWZpY2F0aW9uMRcwFQYDVQQLEw5URVNUIFRF U1QgVEVTVDEcMBoGA1UEAxMTVGhhd3RlIFRlc3QgQ0EgUm9vdDAeFw0wOTA1Mjgw MDIxMzlaFw0wOTA2MTgwMDIxMzlaMFwxCzAJBgNVBAYTAkNOMQswCQYDVQQIEwJC SjELMAkGA1UEBxMCQkoxDTALBgNVBAoTBHpsZXgxDTALBgNVBAsTBHpsZXgxFTAT BgNVBAMTDHd3dy56bGV4Lm9yZzCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEA keg11PTKfpgiju3L/ST7I9J9RHPxqTNPar4aYF9xTWnf2Vkg3L1O+2F2UqBfYUKd 8NSwvnnioHdjJVaV0721cATVXdh4kD6d+4nOgVFI0ml/Cx7Qpe5dASBMnvakNo/B tJGpO3vGQNLO5292JqvyvAVe79DECHYSHNW4nyvWQ3sCAwEAAaOBpjCBozAMBgNV HRMBAf8EAjAAMB0GA1UdJQQWMBQGCCsGAQUFBwMBBggrBgEFBQcDAjBABgNVHR8E OTA3MDWgM6Axhi9odHRwOi8vY3JsLnRoYXd0ZS5jb20vVGhhd3RlUHJlbWl1bVNl cnZlckNBLmNybDAyBggrBgEFBQcBAQQmMCQwIgYIKwYBBQUHMAGGFmh0dHA6Ly9v Y3NwLnRoYXd0ZS5jb20wDQYJKoZIhvcNAQEFBQADgYEATPuxZbtJJSPmXvfrr1yz xqM06IwTZ6UU0lZRG7I0WufMjNMKdpn8hklUhE17mxAhGSpewLVVeLR7uzBLFkuC X7wMXxhoYdJZtNai72izU6Rd1oknao7diahvRxPK4IuQ7y2oZ511/4T4vgY6iRAj q4q76HhPJrVRL/sduaiu+gYwggKZMIICAqADAgECAgEAMA0GCSqGSIb3DQEBBAUA MIGHMQswCQYDVQQGEwJaQTEiMCAGA1UECBMZRk9SIFRFU1RJTkcgUFVSUE9TRVMg T05MWTEdMBsGA1UEChMUVGhhd3RlIENlcnRpZmljYXRpb24xFzAVBgNVBAsTDlRF U1QgVEVTVCBURVNUMRwwGgYDVQQDExNUaGF3dGUgVGVzdCBDQSBSb290MB4XDTk2 MDgwMTAwMDAwMFoXDTIwMTIzMTIxNTk1OVowgYcxCzAJBgNVBAYTAlpBMSIwIAYD VQQIExlGT1IgVEVTVElORyBQVVJQT1NFUyBPTkxZMR0wGwYDVQQKExRUaGF3dGUg Q2VydGlmaWNhdGlvbjEXMBUGA1UECxMOVEVTVCBURVNUIFRFU1QxHDAaBgNVBAMT E1RoYXd0ZSBUZXN0IENBIFJvb3QwgZ8wDQYJKoZIhvcNAQEBBQADgY0AMIGJAoGB ALV9kG+Os6x/DOhm+tKUQfzVMWGhE95sFmEtkMMTX2Zi4n6i6BvzoReJ5njzt1LF cqu4EUk9Ji20egKKfmqRzmQFLP7+1niSdfJEUE7cKY40QoI99270PTrLjJeaMcCl +AYl+kD+RL5BtuKKU3PurYcsCsre6aTvjMcqpTJOGeSPAgMBAAGjEzARMA8GA1Ud EwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEEBQADgYEAgozj7BkD9O8si2V0v+EZ/t7E fz/LC8y6mD7IBUziHy5/53ymGAGLtyhXHvX+UIE6UWbHro3IqVkrmY5uC93Z2Wew A/6edK3KFUcUikrLeewM7gmqsiASEKx2mKRKlu12jXyNS5tXrPWRDvUKtFC1uL9a 12rFAQS2BkIk7aU+ghYxAA== -----END?PKCS7-----

    將其存儲為zlex.p7b?
    ??? 6.將由CA簽發(fā)的證書導(dǎo)入密鑰庫。

    keytool?-import?-trustcacerts?-alias?www.zlex.org?-file?d:\zlex.p7b?-keystore?d:\zlex.keystore?-v



    在這里我使用的密碼為?123456?

    ??? 控制臺輸出:

    輸入keystore密碼:回復(fù)中的最高級認證:所有者:CN=Thawte?Test?CA?Root,?OU=TEST?TEST?TEST,?O=Thawte?Certification,?ST=FORTESTING?PURPOSES?ONLY,?C=ZA 簽發(fā)人:CN=Thawte?Test?CA?Root,?OU=TEST?TEST?TEST,?O=Thawte?Certification,?ST=FORTESTING?PURPOSES?ONLY,?C=ZA 序列號:0 有效期:?Thu?Aug?01?08:00:00?CST?1996?至Fri?Jan?01?05:59:59?CST?2021 證書指紋:MD5:5E:E0:0E:1D:17:B7:CA:A5:7D:36:D6:02:DF:4D:26:A4SHA1:39:C6:9D:27:AF:DC:EB:47:D6:33:36:6A:B2:05:F1:47:A9:B4:DA:EA簽名算法名稱:MD5withRSA版本:?3擴展:#1:?ObjectId:?2.5.29.19?Criticality=true BasicConstraints:[CA:truePathLen:2147483647 ]...?是不可信的。?還是要安裝回復(fù)??[否]:??Y 認證回復(fù)已安裝在?keystore中 [正在存儲?d:\zlex.keystore]



    ??? 7.域名定位?
    ??? 將域名www.zlex.org定位到本機上。打開C:\Windows\System32\drivers\etc\hosts文件,將 www.zlex.org綁定在本機上。在文件末尾追加127.0.0.1?????? www.zlex.org。現(xiàn)在通過地址欄訪問http://www.zlex.org,或者通過ping命令,如果能夠定位到本機,域名映射就搞定 了。?

    ??? 8.配置server.xml

    <ConnectorkeystoreFile="conf/zlex.keystore"keystorePass="123456"?truststoreFile="conf/zlex.keystore"????truststorePass="123456"?????SSLEnabled="true"URIEncoding="UTF-8"clientAuth="false" maxThreads="150"port="443"protocol="HTTP/1.1"scheme="https"secure="true"sslProtocol="TLS"?/>



    將文件zlex.keystore拷貝到tomcat的conf目錄下,重新啟動tomcat。訪問https://www.zlex.org/,我們發(fā)現(xiàn)聯(lián)網(wǎng)有些遲鈍。大約5秒鐘后,網(wǎng)頁正常顯示,同時有如下圖所示:?
    ?
    瀏覽器驗證了該CA機構(gòu)的有效性。?

    打開證書,如下圖所示:?
    ?

    調(diào)整測試類:?

    import?static?org.junit.Assert.*;import?java.io.DataInputStream; import?java.io.InputStream; import?java.net.URL;import?javax.net.ssl.HttpsURLConnection;import?org.junit.Test;/***?*?@author?梁棟*?@version?1.0*?@since?1.0*/ public?class?CertificateCoderTest?{private?String?password?=?"123456";private?String?alias?=?"www.zlex.org";private?String?certificatePath?=?"d:/zlex.cer";private?String?keyStorePath?=?"d:/zlex.keystore";@Testpublic?void?test()?throws?Exception?{System.err.println("公鑰加密——私鑰解密");String?inputStr?=?"Ceritifcate";byte[]?data?=?inputStr.getBytes();byte[]?encrypt?=?CertificateCoder.encryptByPublicKey(data,certificatePath);byte[]?decrypt?=?CertificateCoder.decryptByPrivateKey(encrypt,keyStorePath,?alias,?password);String?outputStr?=?new?String(decrypt);System.err.println("加密前:?"?+?inputStr?+?"\n\r"?+?"解密后:?"?+?outputStr);//?驗證數(shù)據(jù)一致assertArrayEquals(data,?decrypt);//?驗證證書有效assertTrue(CertificateCoder.verifyCertificate(certificatePath));}@Testpublic?void?testSign()?throws?Exception?{System.err.println("私鑰加密——公鑰解密");String?inputStr?=?"sign";byte[]?data?=?inputStr.getBytes();byte[]?encodedData?=?CertificateCoder.encryptByPrivateKey(data,keyStorePath,?alias,?password);byte[]?decodedData?=?CertificateCoder.decryptByPublicKey(encodedData,certificatePath);String?outputStr?=?new?String(decodedData);System.err.println("加密前:?"?+?inputStr?+?"\n\r"?+?"解密后:?"?+?outputStr);assertEquals(inputStr,?outputStr);System.err.println("私鑰簽名——公鑰驗證簽名");//?產(chǎn)生簽名String?sign?=?CertificateCoder.sign(encodedData,?keyStorePath,?alias,password);System.err.println("簽名:\r"?+?sign);//?驗證簽名boolean?status?=?CertificateCoder.verify(encodedData,?sign,certificatePath);System.err.println("狀態(tài):\r"?+?status);assertTrue(status);}@Testpublic?void?testHttps()?throws?Exception?{URL?url?=?new?URL("https://www.zlex.org/examples/");HttpsURLConnection?conn?=?(HttpsURLConnection)?url.openConnection();conn.setDoInput(true);conn.setDoOutput(true);CertificateCoder.configSSLSocketFactory(conn,?password,?keyStorePath,keyStorePath);InputStream?is?=?conn.getInputStream();int?length?=?conn.getContentLength();DataInputStream?dis?=?new?DataInputStream(is);byte[]?data?=?new?byte[length];dis.readFully(data);dis.close();conn.disconnect();System.err.println(new?String(data));} }



    再次執(zhí)行,驗證通過!?
    由此,我們了基于SSL協(xié)議的認證過程。測試類的testHttps方法模擬了一次瀏覽器的HTTPS訪問。

    (原文地址:http://www.open-open.com/lib/view/open1397274257325.html)

    總結(jié)

    以上是生活随笔為你收集整理的[转]Java加密算法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

    欧美刺激性大交 | 最近的中文字幕在线看视频 | 亚洲中文字幕无码一久久区 | 十八禁真人啪啪免费网站 | 无码播放一区二区三区 | 亚洲中文字幕成人无码 | 精品国产精品久久一区免费式 | 国产办公室秘书无码精品99 | 精品熟女少妇av免费观看 | 色婷婷综合中文久久一本 | 欧美成人免费全部网站 | 日本一本二本三区免费 | 欧美人与善在线com | 88国产精品欧美一区二区三区 | 亚洲成a人片在线观看无码3d | 日本xxxx色视频在线观看免费 | 亚洲男人av天堂午夜在 | 久久99精品国产麻豆蜜芽 | 欧美成人免费全部网站 | 99国产欧美久久久精品 | 99久久精品国产一区二区蜜芽 | 亚洲熟妇色xxxxx欧美老妇 | 无码福利日韩神码福利片 | 亚洲国产精品美女久久久久 | 免费无码的av片在线观看 | 黄网在线观看免费网站 | 亚洲一区二区三区香蕉 | 强开小婷嫩苞又嫩又紧视频 | 国产一精品一av一免费 | 亚洲国产av美女网站 | 国产极品美女高潮无套在线观看 | 亚洲爆乳大丰满无码专区 | 九一九色国产 | 久久99精品国产.久久久久 | 国产麻豆精品精东影业av网站 | 丰满人妻精品国产99aⅴ | 久久久久久av无码免费看大片 | 亚洲经典千人经典日产 | 色婷婷综合激情综在线播放 | 国产人妻久久精品二区三区老狼 | 亚洲精品成a人在线观看 | 人人爽人人爽人人片av亚洲 | 久久国语露脸国产精品电影 | 亚洲 欧美 激情 小说 另类 | 人妻aⅴ无码一区二区三区 | 国产精品永久免费视频 | 大胆欧美熟妇xx | 午夜无码人妻av大片色欲 | 国产精品理论片在线观看 | 无套内射视频囯产 | 日本大乳高潮视频在线观看 | 无码国产色欲xxxxx视频 | 一本色道久久综合狠狠躁 | 欧美成人午夜精品久久久 | 久久久精品国产sm最大网站 | 一个人免费观看的www视频 | 中文字幕av无码一区二区三区电影 | 久久久久久久人妻无码中文字幕爆 | 无码国模国产在线观看 | 久久熟妇人妻午夜寂寞影院 | 日本又色又爽又黄的a片18禁 | 日本精品少妇一区二区三区 | 精品久久综合1区2区3区激情 | 伊人久久大香线蕉av一区二区 | 亚洲人成网站在线播放942 | 欧美丰满老熟妇xxxxx性 | 波多野结衣一区二区三区av免费 | 亚洲欧美中文字幕5发布 | 久久综合九色综合欧美狠狠 | 亚洲精品综合一区二区三区在线 | 人妻夜夜爽天天爽三区 | 97久久国产亚洲精品超碰热 | 亚洲成av人综合在线观看 | 动漫av一区二区在线观看 | 成 人影片 免费观看 | 内射后入在线观看一区 | 国产在线精品一区二区高清不卡 | 麻豆果冻传媒2021精品传媒一区下载 | 国产精品久久久午夜夜伦鲁鲁 | 亚洲色在线无码国产精品不卡 | 女高中生第一次破苞av | 2019午夜福利不卡片在线 | 欧美喷潮久久久xxxxx | 国产在线精品一区二区高清不卡 | 领导边摸边吃奶边做爽在线观看 | 亚洲国产精品久久人人爱 | aⅴ在线视频男人的天堂 | 久久精品国产日本波多野结衣 | 亚洲成a人片在线观看无码3d | 98国产精品综合一区二区三区 | 欧美日韩久久久精品a片 | 国产成人无码午夜视频在线观看 | 波多野结衣乳巨码无在线观看 | 性生交大片免费看女人按摩摩 | 高清国产亚洲精品自在久久 | 牲欲强的熟妇农村老妇女视频 | 久久亚洲精品成人无码 | 久久国语露脸国产精品电影 | 乱码av麻豆丝袜熟女系列 | 精品国产一区二区三区av 性色 | 国产黄在线观看免费观看不卡 | 欧美日韩视频无码一区二区三 | 乱码av麻豆丝袜熟女系列 | av无码不卡在线观看免费 | 亚洲高清偷拍一区二区三区 | 日本饥渴人妻欲求不满 | 国产午夜精品一区二区三区嫩草 | 最新国产乱人伦偷精品免费网站 | 一二三四社区在线中文视频 | 欧美zoozzooz性欧美 | 婷婷丁香六月激情综合啪 | 亚洲综合精品香蕉久久网 | 成人免费视频在线观看 | 啦啦啦www在线观看免费视频 | 人妻中文无码久热丝袜 | 福利一区二区三区视频在线观看 | 野狼第一精品社区 | 精品无码国产一区二区三区av | 牲交欧美兽交欧美 | 自拍偷自拍亚洲精品被多人伦好爽 | 自拍偷自拍亚洲精品10p | 99久久精品无码一区二区毛片 | a国产一区二区免费入口 | √8天堂资源地址中文在线 | 国产又爽又猛又粗的视频a片 | 亚洲一区二区三区偷拍女厕 | 国产亚av手机在线观看 | 精品成人av一区二区三区 | 欧美一区二区三区视频在线观看 | 99精品无人区乱码1区2区3区 | 日日麻批免费40分钟无码 | 国产suv精品一区二区五 | 少妇性l交大片欧洲热妇乱xxx | 人妻与老人中文字幕 | 久久久精品国产sm最大网站 | 亚洲一区av无码专区在线观看 | 国产成人综合色在线观看网站 | 荫蒂添的好舒服视频囗交 | 久热国产vs视频在线观看 | 日本成熟视频免费视频 | 少妇高潮一区二区三区99 | 99久久久国产精品无码免费 | 国产成人无码区免费内射一片色欲 | 亚洲爆乳精品无码一区二区三区 | 亚洲日本va午夜在线电影 | 55夜色66夜色国产精品视频 | 日韩亚洲欧美中文高清在线 | 一本色道久久综合狠狠躁 | 亚洲天堂2017无码 | 久久人人爽人人人人片 | 日日夜夜撸啊撸 | www国产亚洲精品久久久日本 | 精品一区二区不卡无码av | 性生交片免费无码看人 | 国色天香社区在线视频 | 丰满岳乱妇在线观看中字无码 | 性色av无码免费一区二区三区 | 亚洲精品国偷拍自产在线麻豆 | 免费人成网站视频在线观看 | 日本精品人妻无码77777 天堂一区人妻无码 | 大肉大捧一进一出视频出来呀 | 成 人 网 站国产免费观看 | 国精产品一品二品国精品69xx | 三上悠亚人妻中文字幕在线 | 国产精品人妻一区二区三区四 | 久久久久久九九精品久 | 久久久久国色av免费观看性色 | 国产卡一卡二卡三 | 无码人妻黑人中文字幕 | 久久伊人色av天堂九九小黄鸭 | 少妇厨房愉情理9仑片视频 | 中文字幕乱码中文乱码51精品 | 久久99精品国产麻豆蜜芽 | 亚洲爆乳精品无码一区二区三区 | 日日摸天天摸爽爽狠狠97 | 无码精品人妻一区二区三区av | 国产亚洲精品久久久久久国模美 | 精品国产一区二区三区四区 | 精品欧洲av无码一区二区三区 | 波多野结衣一区二区三区av免费 | 国产三级精品三级男人的天堂 | 蜜桃无码一区二区三区 | 一个人看的视频www在线 | 午夜熟女插插xx免费视频 | 一本无码人妻在中文字幕免费 | 青春草在线视频免费观看 | 国产成人久久精品流白浆 | 伊人久久大香线蕉午夜 | 欧美xxxxx精品 | 日本精品人妻无码77777 天堂一区人妻无码 | 中文无码精品a∨在线观看不卡 | 日韩精品无码一本二本三本色 | 亚洲の无码国产の无码步美 | 好男人社区资源 | 日韩av无码中文无码电影 | 成人无码精品一区二区三区 | 欧美日韩在线亚洲综合国产人 | 国产无套粉嫩白浆在线 | 亚洲精品久久久久中文第一幕 | 欧美乱妇无乱码大黄a片 | 日日干夜夜干 | 国内精品人妻无码久久久影院 | 成人免费无码大片a毛片 | 亚洲成av人片天堂网无码】 | 中文字幕日韩精品一区二区三区 | 久久综合香蕉国产蜜臀av | 午夜成人1000部免费视频 | 亚洲无人区一区二区三区 | 中文字幕无线码 | 亚洲中文字幕无码中文字在线 | 人人妻人人澡人人爽欧美精品 | 精品无码成人片一区二区98 | 色五月丁香五月综合五月 | 国产精品第一国产精品 | 国产suv精品一区二区五 | 日日噜噜噜噜夜夜爽亚洲精品 | 国产亚av手机在线观看 | 夜夜躁日日躁狠狠久久av | 1000部啪啪未满十八勿入下载 | 高清无码午夜福利视频 | 欧美国产亚洲日韩在线二区 | 人人澡人人透人人爽 | 麻豆精品国产精华精华液好用吗 | 草草网站影院白丝内射 | 伊人久久大香线蕉av一区二区 | 日本一区二区三区免费播放 | 国产色视频一区二区三区 | 国产欧美精品一区二区三区 | 2019nv天堂香蕉在线观看 | 色欲久久久天天天综合网精品 | 亚洲啪av永久无码精品放毛片 | 又粗又大又硬又长又爽 | 久久国产精品精品国产色婷婷 | 国产亚洲精品久久久久久大师 | 人妻无码αv中文字幕久久琪琪布 | 久久亚洲国产成人精品性色 | 亚洲中文字幕在线无码一区二区 | 国内丰满熟女出轨videos | 牛和人交xxxx欧美 | 精品无码成人片一区二区98 | 色欲人妻aaaaaaa无码 | 97se亚洲精品一区 | 国产在线精品一区二区三区直播 | 久激情内射婷内射蜜桃人妖 | 131美女爱做视频 | 亚洲一区av无码专区在线观看 | 精品亚洲成av人在线观看 | 精品熟女少妇av免费观看 | 久久精品人妻少妇一区二区三区 | 一个人看的www免费视频在线观看 | 高清国产亚洲精品自在久久 | 红桃av一区二区三区在线无码av | 国产两女互慰高潮视频在线观看 | 人人澡人人妻人人爽人人蜜桃 | 色综合久久中文娱乐网 | 免费看男女做好爽好硬视频 | 免费看男女做好爽好硬视频 | 国产高清不卡无码视频 | 亚洲熟女一区二区三区 | 精品无码国产自产拍在线观看蜜 | 高中生自慰www网站 | 亚洲综合无码久久精品综合 | 亚洲 另类 在线 欧美 制服 | 男人的天堂av网站 | 亚洲日韩av一区二区三区四区 | www国产亚洲精品久久久日本 | 日产精品高潮呻吟av久久 | 亚洲 日韩 欧美 成人 在线观看 | 日日摸日日碰夜夜爽av | 蜜臀av在线观看 在线欧美精品一区二区三区 | 精品国产av色一区二区深夜久久 | 日本精品高清一区二区 | 亚洲色欲色欲欲www在线 | 在线观看国产一区二区三区 | 国产午夜手机精彩视频 | 爆乳一区二区三区无码 | 人妻aⅴ无码一区二区三区 | 免费观看黄网站 | 人妻插b视频一区二区三区 | 无码人中文字幕 | 无码国内精品人妻少妇 | 亚洲色欲久久久综合网东京热 | 夜先锋av资源网站 | 国产真人无遮挡作爱免费视频 | 亚洲中文字幕无码中文字在线 | 性啪啪chinese东北女人 | 红桃av一区二区三区在线无码av | 国产免费无码一区二区视频 | 性开放的女人aaa片 | av人摸人人人澡人人超碰下载 | 人妻无码αv中文字幕久久琪琪布 | 中文字幕无码视频专区 | 天天躁夜夜躁狠狠是什么心态 | 国产亚洲美女精品久久久2020 | 午夜无码人妻av大片色欲 | 狂野欧美性猛xxxx乱大交 | 天堂а√在线地址中文在线 | 国产成人av免费观看 | 国产97色在线 | 免 | 无套内谢老熟女 | 粗大的内捧猛烈进出视频 | 一二三四社区在线中文视频 | 久久精品丝袜高跟鞋 | 日本精品人妻无码77777 天堂一区人妻无码 | 狂野欧美性猛交免费视频 | 久久精品国产亚洲精品 | 欧美日韩一区二区综合 | 国产口爆吞精在线视频 | 女人被爽到呻吟gif动态图视看 | 亚洲精品国产第一综合99久久 | 人人妻人人澡人人爽精品欧美 | 国产xxx69麻豆国语对白 | 国产性生交xxxxx无码 | 国产成人综合在线女婷五月99播放 | 国产综合色产在线精品 | 天干天干啦夜天干天2017 | 成熟人妻av无码专区 | 亚洲另类伦春色综合小说 | 国产精品久久久久久久9999 | 欧美人与牲动交xxxx | 精品久久久久久人妻无码中文字幕 | 国产亚洲精品久久久久久久久动漫 | 在线观看国产午夜福利片 | 波多野结衣高清一区二区三区 | yw尤物av无码国产在线观看 | 婷婷综合久久中文字幕蜜桃三电影 | 人人妻人人澡人人爽精品欧美 | 欧美性生交xxxxx久久久 | 狠狠cao日日穞夜夜穞av | 久久亚洲国产成人精品性色 | 亚洲国产精品美女久久久久 | 国产一区二区三区精品视频 | 人人妻人人澡人人爽欧美一区九九 | 人妻少妇被猛烈进入中文字幕 | 丰满诱人的人妻3 | 亚洲啪av永久无码精品放毛片 | 最新版天堂资源中文官网 | 婷婷丁香六月激情综合啪 | 久久99久久99精品中文字幕 | 奇米影视7777久久精品人人爽 | 日本又色又爽又黄的a片18禁 | 国产在线精品一区二区三区直播 | 在线亚洲高清揄拍自拍一品区 | 久久无码人妻影院 | 日韩少妇内射免费播放 | 国产人妻精品午夜福利免费 | 国产绳艺sm调教室论坛 | 亚洲爆乳大丰满无码专区 | 国产深夜福利视频在线 | 丰满少妇人妻久久久久久 | 亚洲国精产品一二二线 | 精品国产青草久久久久福利 | 日韩无码专区 | 丰满护士巨好爽好大乳 | 成人无码精品1区2区3区免费看 | 中文无码成人免费视频在线观看 | av人摸人人人澡人人超碰下载 | 欧美三级不卡在线观看 | 国产香蕉尹人视频在线 | 桃花色综合影院 | 国产精品永久免费视频 | 日韩视频 中文字幕 视频一区 | 又紧又大又爽精品一区二区 | 中文字幕 亚洲精品 第1页 | 麻豆av传媒蜜桃天美传媒 | 午夜免费福利小电影 | 99久久无码一区人妻 | 国产人妻精品一区二区三区不卡 | 荫蒂被男人添的好舒服爽免费视频 | 久久久久久久女国产乱让韩 | 麻豆国产人妻欲求不满 | 国产人妖乱国产精品人妖 | 人妻少妇精品无码专区二区 | 国产办公室秘书无码精品99 | 成年女人永久免费看片 | 性欧美牲交在线视频 | 国产成人精品优优av | 无码人妻精品一区二区三区下载 | 蜜臀av在线播放 久久综合激激的五月天 | 成熟女人特级毛片www免费 | 无码国产色欲xxxxx视频 | 久久国产精品精品国产色婷婷 | 国产suv精品一区二区五 | √天堂资源地址中文在线 | 久久无码中文字幕免费影院蜜桃 | 国产精品第一区揄拍无码 | 国产9 9在线 | 中文 | 国产av无码专区亚洲a∨毛片 | 三上悠亚人妻中文字幕在线 | 亚洲精品无码人妻无码 | 小鲜肉自慰网站xnxx | 国内少妇偷人精品视频 | 国产亚洲tv在线观看 | 俺去俺来也www色官网 | 色综合久久久无码网中文 | 精品国产成人一区二区三区 | 色综合视频一区二区三区 | 97资源共享在线视频 | 内射后入在线观看一区 | 蜜桃视频插满18在线观看 | 乱人伦人妻中文字幕无码久久网 | 四虎国产精品一区二区 | 日韩人妻无码一区二区三区久久99 | 国产成人人人97超碰超爽8 | 黑森林福利视频导航 | 我要看www免费看插插视频 | 欧美黑人巨大xxxxx | 日本免费一区二区三区最新 | 99国产精品白浆在线观看免费 | 波多野结衣av一区二区全免费观看 | 国产精品亚洲lv粉色 | 国产精品自产拍在线观看 | 日本大香伊一区二区三区 | 亚洲人成无码网www | 久久天天躁狠狠躁夜夜免费观看 | 国产片av国语在线观看 | a国产一区二区免费入口 | 欧美日韩一区二区免费视频 | 麻花豆传媒剧国产免费mv在线 | 内射老妇bbwx0c0ck | 成人精品视频一区二区 | 久久久婷婷五月亚洲97号色 | 波多野结衣高清一区二区三区 | 东京热男人av天堂 | 亚欧洲精品在线视频免费观看 | 性欧美牲交在线视频 | 国产精品人人妻人人爽 | 久久久久久久久蜜桃 | 久久久精品欧美一区二区免费 | 欧美成人免费全部网站 | 人人妻在人人 | 国产尤物精品视频 | 99国产精品白浆在线观看免费 | 性做久久久久久久久 | 日本又色又爽又黄的a片18禁 | 国产内射爽爽大片视频社区在线 | 又大又硬又爽免费视频 | 啦啦啦www在线观看免费视频 | 思思久久99热只有频精品66 | 波多野结衣aⅴ在线 | 欧美日韩一区二区免费视频 | 中文毛片无遮挡高清免费 | 国产人妻人伦精品1国产丝袜 | 清纯唯美经典一区二区 | 久久久久亚洲精品中文字幕 | 中文字幕乱码人妻无码久久 | 久久久久99精品成人片 | 99久久久无码国产aaa精品 | 亚洲国产精品一区二区第一页 | 奇米影视7777久久精品 | 牲交欧美兽交欧美 | 国产乱码精品一品二品 | 午夜成人1000部免费视频 | 国产成人无码午夜视频在线观看 | 久久久久久亚洲精品a片成人 | 久久精品一区二区三区四区 | 亚洲一区二区三区偷拍女厕 | 国产福利视频一区二区 | 黑人粗大猛烈进出高潮视频 | 国产亚洲视频中文字幕97精品 | 国产女主播喷水视频在线观看 | 国产成人无码午夜视频在线观看 | 国产免费观看黄av片 | 人人妻在人人 | aⅴ亚洲 日韩 色 图网站 播放 | 久久久久久av无码免费看大片 | 98国产精品综合一区二区三区 | 蜜臀av在线播放 久久综合激激的五月天 | 国产免费久久精品国产传媒 | 伦伦影院午夜理论片 | 一本大道伊人av久久综合 | 国产精品久久久久影院嫩草 | 97精品人妻一区二区三区香蕉 | 色综合视频一区二区三区 | 99麻豆久久久国产精品免费 | 成人欧美一区二区三区 | 亚洲理论电影在线观看 | 午夜精品一区二区三区在线观看 | 久久久国产一区二区三区 | 国产成人无码av一区二区 | 亚洲小说春色综合另类 | 国产在线aaa片一区二区99 | 高清无码午夜福利视频 | 欧美人与物videos另类 | 99久久久无码国产精品免费 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 国产手机在线αⅴ片无码观看 | 性欧美牲交xxxxx视频 | 国内精品九九久久久精品 | 日韩人妻无码中文字幕视频 | 国产莉萝无码av在线播放 | 动漫av一区二区在线观看 | 精品无码av一区二区三区 | 国产人妖乱国产精品人妖 | 97se亚洲精品一区 | 亚洲毛片av日韩av无码 | 国产9 9在线 | 中文 | 嫩b人妻精品一区二区三区 | 国产性生大片免费观看性 | 日欧一片内射va在线影院 | 日本大乳高潮视频在线观看 | 久久久精品欧美一区二区免费 | 色爱情人网站 | 欧美xxxx黑人又粗又长 | 亚洲一区二区三区在线观看网站 | 亚洲成a人片在线观看日本 | 国产激情艳情在线看视频 | 丰满少妇女裸体bbw | 青草青草久热国产精品 | 丰满人妻翻云覆雨呻吟视频 | 全黄性性激高免费视频 | 超碰97人人射妻 | 在线精品亚洲一区二区 | 亚洲日韩av一区二区三区四区 | 欧美黑人巨大xxxxx | 少妇被粗大的猛进出69影院 | 国产无遮挡又黄又爽又色 | 天天摸天天透天天添 | 无码纯肉视频在线观看 | 日韩 欧美 动漫 国产 制服 | 人人爽人人澡人人人妻 | 人人爽人人爽人人片av亚洲 | 国产成人一区二区三区在线观看 | 国产真实伦对白全集 | 波多野结衣高清一区二区三区 | 女人被男人爽到呻吟的视频 | 曰韩无码二三区中文字幕 | 久久99精品久久久久久 | a在线亚洲男人的天堂 | 国产一精品一av一免费 | 亚洲色欲久久久综合网东京热 | 高清无码午夜福利视频 | 日日躁夜夜躁狠狠躁 | 国产人妻人伦精品 | 国产9 9在线 | 中文 | 欧美三级不卡在线观看 | 久久久久人妻一区精品色欧美 | 18黄暴禁片在线观看 | 亚洲人成影院在线观看 | 精品国产精品久久一区免费式 | 欧美日韩综合一区二区三区 | 中文字幕无码av激情不卡 | 国产又粗又硬又大爽黄老大爷视 | 久9re热视频这里只有精品 | 99久久99久久免费精品蜜桃 | 男女下面进入的视频免费午夜 | 天天综合网天天综合色 | 欧美 亚洲 国产 另类 | 澳门永久av免费网站 | 亚洲の无码国产の无码影院 | 国产特级毛片aaaaaaa高清 | 国产九九九九九九九a片 | 国产成人精品无码播放 | 俺去俺来也www色官网 | 免费网站看v片在线18禁无码 | 青青青手机频在线观看 | 亚洲欧美国产精品久久 | 亚洲综合在线一区二区三区 | 两性色午夜视频免费播放 | 天下第一社区视频www日本 | 欧美老妇交乱视频在线观看 | 久久午夜夜伦鲁鲁片无码免费 | 国产亚洲精品久久久久久国模美 | 狠狠cao日日穞夜夜穞av | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 国产性生大片免费观看性 | 国产97人人超碰caoprom | 澳门永久av免费网站 | 国产精品久久久一区二区三区 | 国产一区二区三区精品视频 | 狠狠色噜噜狠狠狠7777奇米 | 色老头在线一区二区三区 | 免费观看又污又黄的网站 | 久久久久久久人妻无码中文字幕爆 | 欧美怡红院免费全部视频 | 欧美日韩一区二区三区自拍 | 日韩无套无码精品 | 亚洲欧洲日本综合aⅴ在线 | 俄罗斯老熟妇色xxxx | 成人无码精品一区二区三区 | 人人妻人人澡人人爽欧美一区 | 乱人伦人妻中文字幕无码久久网 | 思思久久99热只有频精品66 | 国产av一区二区精品久久凹凸 | 又大又硬又黄的免费视频 | 最近的中文字幕在线看视频 | 伊人久久大香线蕉av一区二区 | 色综合久久久久综合一本到桃花网 | 免费国产黄网站在线观看 | 久久人人97超碰a片精品 | 任你躁国产自任一区二区三区 | 国产激情一区二区三区 | 成人欧美一区二区三区黑人免费 | 少妇无码一区二区二三区 | 日韩精品一区二区av在线 | 亚洲精品久久久久久一区二区 | 精品无码一区二区三区爱欲 | 国产三级精品三级男人的天堂 | 亚洲熟妇自偷自拍另类 | 成熟女人特级毛片www免费 | 少妇邻居内射在线 | 欧美刺激性大交 | 国产精品内射视频免费 | 欧美性黑人极品hd | 粉嫩少妇内射浓精videos | 午夜不卡av免费 一本久久a久久精品vr综合 | 丝袜美腿亚洲一区二区 | 天天综合网天天综合色 | 久久人人爽人人爽人人片ⅴ | 欧美精品国产综合久久 | 日日麻批免费40分钟无码 | 正在播放东北夫妻内射 | 日本免费一区二区三区最新 | 久久这里只有精品视频9 | 性欧美牲交xxxxx视频 | 噜噜噜亚洲色成人网站 | 久久无码中文字幕免费影院蜜桃 | 国内精品久久毛片一区二区 | 国产人妻精品一区二区三区 | 亚洲精品成人福利网站 | 国产精品爱久久久久久久 | 成人综合网亚洲伊人 | 免费无码的av片在线观看 | 色窝窝无码一区二区三区色欲 | 欧洲美熟女乱又伦 | 婷婷五月综合激情中文字幕 | 98国产精品综合一区二区三区 | 国产人妻精品一区二区三区不卡 | 一个人免费观看的www视频 | 国产精品人人妻人人爽 | 中国大陆精品视频xxxx | 午夜无码区在线观看 | 国产成人无码一二三区视频 | 无码福利日韩神码福利片 | 日本丰满熟妇videos | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 色妞www精品免费视频 | 日本熟妇浓毛 | 国产精品久久国产三级国 | 国产精品美女久久久网av | 国产亚洲日韩欧美另类第八页 | 少妇太爽了在线观看 | 精品一区二区三区波多野结衣 | 午夜性刺激在线视频免费 | 呦交小u女精品视频 | 欧洲极品少妇 | 荡女精品导航 | 亚洲色欲久久久综合网东京热 | 久久久久久久女国产乱让韩 | 欧美日韩综合一区二区三区 | 无遮无挡爽爽免费视频 | 玩弄中年熟妇正在播放 | 狠狠色噜噜狠狠狠7777奇米 | 精品人妻人人做人人爽夜夜爽 | 中文字幕无线码免费人妻 | 人人爽人人爽人人片av亚洲 | 2020久久超碰国产精品最新 | 无码精品人妻一区二区三区av | 久久久久成人精品免费播放动漫 | 无码人妻精品一区二区三区不卡 | 18禁止看的免费污网站 | 精品熟女少妇av免费观看 | 色婷婷香蕉在线一区二区 | 人妻体内射精一区二区三四 | 亚洲精品一区二区三区四区五区 | www国产亚洲精品久久网站 | 永久免费观看国产裸体美女 | 久久久久se色偷偷亚洲精品av | 少妇愉情理伦片bd | 国产精品久免费的黄网站 | 女人被男人爽到呻吟的视频 | 亚洲精品午夜国产va久久成人 | 欧洲欧美人成视频在线 | 亚洲精品午夜无码电影网 | 丁香花在线影院观看在线播放 | 1000部啪啪未满十八勿入下载 | 成年美女黄网站色大免费全看 | 人妻互换免费中文字幕 | 亚洲色欲久久久综合网东京热 | 夜夜夜高潮夜夜爽夜夜爰爰 | 成人欧美一区二区三区黑人免费 | 国产高潮视频在线观看 | 欧美人与牲动交xxxx | 国产亚洲精品久久久久久 | 国产激情综合五月久久 | 在教室伦流澡到高潮hnp视频 | 成人欧美一区二区三区黑人 | 欧美日本精品一区二区三区 | 又粗又大又硬又长又爽 | 亚洲日韩乱码中文无码蜜桃臀网站 | 波多野结衣av在线观看 | 国产乱子伦视频在线播放 | 亚洲成色在线综合网站 | 夫妻免费无码v看片 | 丰满少妇高潮惨叫视频 | 国产婷婷色一区二区三区在线 | 国产午夜福利亚洲第一 | 久久无码人妻影院 | 亚洲色无码一区二区三区 | 精品乱码久久久久久久 | 日日鲁鲁鲁夜夜爽爽狠狠 | 国产色精品久久人妻 | 少妇厨房愉情理9仑片视频 | 亚洲精品一区二区三区在线观看 | a在线观看免费网站大全 | 色综合久久久无码中文字幕 | 日韩精品无码免费一区二区三区 | 中文字幕乱码人妻二区三区 | 亚洲人成网站免费播放 | 人妻夜夜爽天天爽三区 | 99久久99久久免费精品蜜桃 | 性啪啪chinese东北女人 | 国产亚洲人成a在线v网站 | 久久亚洲精品中文字幕无男同 | 一本色道久久综合狠狠躁 | 1000部啪啪未满十八勿入下载 | 国产精品嫩草久久久久 | 国产sm调教视频在线观看 | 国产亚洲欧美日韩亚洲中文色 | 无套内谢的新婚少妇国语播放 | 久久精品中文字幕一区 | 色婷婷av一区二区三区之红樱桃 | 国产无av码在线观看 | 天天躁夜夜躁狠狠是什么心态 | 给我免费的视频在线观看 | 中文字幕无码日韩专区 | 国产欧美熟妇另类久久久 | 国产一区二区三区影院 | 国产精品怡红院永久免费 | 麻花豆传媒剧国产免费mv在线 | 久久精品视频在线看15 | 又大又黄又粗又爽的免费视频 | 国产猛烈高潮尖叫视频免费 | 免费乱码人妻系列无码专区 | 亚洲精品国偷拍自产在线观看蜜桃 | 人人妻人人澡人人爽欧美一区九九 | 精品久久久中文字幕人妻 | 亚洲国产精品成人久久蜜臀 | 中文字幕乱码人妻无码久久 | 无码一区二区三区在线观看 | 国产精品亚洲а∨无码播放麻豆 | 国产午夜无码精品免费看 | 免费无码肉片在线观看 | 欧美放荡的少妇 | 无码精品国产va在线观看dvd | 美女极度色诱视频国产 | 丰满人妻被黑人猛烈进入 | 国产又粗又硬又大爽黄老大爷视 | 国产乱码精品一品二品 | 亚洲综合精品香蕉久久网 | 一个人看的视频www在线 | 亚洲爆乳大丰满无码专区 | 人妻尝试又大又粗久久 | 老熟妇仑乱视频一区二区 | 久久人人97超碰a片精品 | 巨爆乳无码视频在线观看 | 亚洲国产精品无码久久久久高潮 | 俺去俺来也在线www色官网 | 久久综合香蕉国产蜜臀av | 国产乱人伦偷精品视频 | aⅴ在线视频男人的天堂 | 国产精品久久久午夜夜伦鲁鲁 | 无套内谢老熟女 | 国产在线精品一区二区三区直播 | 久久99国产综合精品 | 亚洲欧美中文字幕5发布 | 亚洲毛片av日韩av无码 | 18无码粉嫩小泬无套在线观看 | 99国产精品白浆在线观看免费 | aⅴ在线视频男人的天堂 | 又大又黄又粗又爽的免费视频 | 亚洲小说春色综合另类 | 九九热爱视频精品 | 亚洲国产av精品一区二区蜜芽 | 性欧美疯狂xxxxbbbb | 亚洲日韩乱码中文无码蜜桃臀网站 | 在线播放无码字幕亚洲 | 精品乱子伦一区二区三区 | 最近的中文字幕在线看视频 | 东京无码熟妇人妻av在线网址 | 97久久超碰中文字幕 | 久久精品国产99精品亚洲 | 欧美国产日韩久久mv | 免费人成在线视频无码 | 色狠狠av一区二区三区 | 国产精品.xx视频.xxtv | 成年美女黄网站色大免费全看 | 成人精品一区二区三区中文字幕 | 中文字幕 亚洲精品 第1页 | 天堂久久天堂av色综合 | 久久zyz资源站无码中文动漫 | 婷婷综合久久中文字幕蜜桃三电影 | 青青青手机频在线观看 | 综合激情五月综合激情五月激情1 | 青草视频在线播放 | 亚洲国产高清在线观看视频 | 久久精品人人做人人综合 | 色五月丁香五月综合五月 | 日日碰狠狠丁香久燥 | 无码精品国产va在线观看dvd | 亚洲成a人片在线观看无码3d | 久久久精品欧美一区二区免费 | 中文字幕无线码免费人妻 | 97资源共享在线视频 | 丰满肥臀大屁股熟妇激情视频 | 伊在人天堂亚洲香蕉精品区 | 国产成人无码一二三区视频 | 欧美亚洲日韩国产人成在线播放 | 精品欧美一区二区三区久久久 | 亚洲国产精华液网站w | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 丰腴饱满的极品熟妇 | 天天爽夜夜爽夜夜爽 | 一区二区传媒有限公司 | 内射巨臀欧美在线视频 | 麻花豆传媒剧国产免费mv在线 | 日本免费一区二区三区最新 | 国产熟女一区二区三区四区五区 | 97精品国产97久久久久久免费 | 日本一区二区更新不卡 | 国产凸凹视频一区二区 | 大肉大捧一进一出视频出来呀 | 红桃av一区二区三区在线无码av | 亚洲国产综合无码一区 | 夜先锋av资源网站 | 婷婷色婷婷开心五月四房播播 | 牲欲强的熟妇农村老妇女视频 | 97精品人妻一区二区三区香蕉 | 丰满诱人的人妻3 | 午夜福利电影 | 草草网站影院白丝内射 | 亚洲国产精品无码久久久久高潮 | 久久午夜无码鲁丝片 | 亚洲精品无码人妻无码 | 国产美女极度色诱视频www | 日日夜夜撸啊撸 | 永久黄网站色视频免费直播 | 女人高潮内射99精品 | 国内精品人妻无码久久久影院 | 色一情一乱一伦一视频免费看 | 国产成人无码午夜视频在线观看 | 国产精品美女久久久久av爽李琼 | 中文字幕无线码免费人妻 | 婷婷色婷婷开心五月四房播播 | 国产 精品 自在自线 | 精品乱子伦一区二区三区 | 漂亮人妻洗澡被公强 日日躁 | 亚洲欧洲中文日韩av乱码 | 少妇性l交大片欧洲热妇乱xxx | 欧美亚洲日韩国产人成在线播放 | 人妻无码αv中文字幕久久琪琪布 | 熟妇女人妻丰满少妇中文字幕 | 爱做久久久久久 | 夜夜影院未满十八勿进 | 亚洲爆乳大丰满无码专区 | 久久久久99精品成人片 | 国产成人一区二区三区别 | 色噜噜亚洲男人的天堂 | 我要看www免费看插插视频 | 无码国产乱人伦偷精品视频 | 丝袜美腿亚洲一区二区 | 色综合久久久久综合一本到桃花网 | 曰韩无码二三区中文字幕 | 人妻插b视频一区二区三区 | 无码午夜成人1000部免费视频 | 女人被爽到呻吟gif动态图视看 | 国产精品久久精品三级 | 亚洲色大成网站www国产 | 成人综合网亚洲伊人 | 久久无码人妻影院 | 丰腴饱满的极品熟妇 | 成人女人看片免费视频放人 | 最近的中文字幕在线看视频 | 亚洲区欧美区综合区自拍区 | 麻豆av传媒蜜桃天美传媒 | 99久久人妻精品免费一区 | 亚洲爆乳大丰满无码专区 | 国产精品人妻一区二区三区四 | 欧美激情一区二区三区成人 | 兔费看少妇性l交大片免费 | 无码av岛国片在线播放 | 日韩精品成人一区二区三区 | 日本免费一区二区三区最新 | 色综合久久网 | 久久综合九色综合97网 | 亚洲 欧美 激情 小说 另类 | 无码免费一区二区三区 | 日本爽爽爽爽爽爽在线观看免 | 在线播放免费人成毛片乱码 | 无码国内精品人妻少妇 | 亚洲a无码综合a国产av中文 | 国产午夜手机精彩视频 | 亚洲日韩av一区二区三区中文 | 久久精品国产大片免费观看 | 在线播放亚洲第一字幕 | 无码人妻av免费一区二区三区 | 久久伊人色av天堂九九小黄鸭 | 在线播放亚洲第一字幕 | 300部国产真实乱 | 久久综合九色综合欧美狠狠 | 欧美国产日韩亚洲中文 | 亚洲 a v无 码免 费 成 人 a v | 日本xxxx色视频在线观看免费 | 国产精品香蕉在线观看 | 夜夜躁日日躁狠狠久久av | 97精品国产97久久久久久免费 | 大地资源中文第3页 | 久久综合网欧美色妞网 | 激情内射亚州一区二区三区爱妻 | 国产 浪潮av性色四虎 | 精品国产青草久久久久福利 | 免费观看又污又黄的网站 | 久久亚洲国产成人精品性色 | 中文字幕乱码中文乱码51精品 | 国产精品亚洲一区二区三区喷水 | 麻豆果冻传媒2021精品传媒一区下载 | 免费无码av一区二区 | 亚洲欧美精品aaaaaa片 | 国产精品二区一区二区aⅴ污介绍 | 亚洲一区二区三区香蕉 | 精品无人国产偷自产在线 | 国精产品一区二区三区 | 99久久人妻精品免费二区 | 国产无遮挡吃胸膜奶免费看 | 天堂在线观看www | 国产精品va在线播放 | 亚洲成av人影院在线观看 | 撕开奶罩揉吮奶头视频 | 亚洲男人av香蕉爽爽爽爽 | av香港经典三级级 在线 | 国产一精品一av一免费 | 人妻中文无码久热丝袜 | 亚洲欧美日韩国产精品一区二区 | 狠狠色噜噜狠狠狠7777奇米 | 国产成人午夜福利在线播放 | 日本肉体xxxx裸交 | 久久久久久亚洲精品a片成人 | av无码久久久久不卡免费网站 | 人妻尝试又大又粗久久 | 久久国语露脸国产精品电影 | 色婷婷久久一区二区三区麻豆 | 天堂а√在线地址中文在线 | 国模大胆一区二区三区 | 高清无码午夜福利视频 | 国产精品毛片一区二区 | 狂野欧美性猛交免费视频 | 男人的天堂2018无码 | 国产午夜手机精彩视频 | 亚洲自偷自拍另类第1页 | 无码福利日韩神码福利片 | 久久国产精品偷任你爽任你 | 色五月丁香五月综合五月 | 色综合久久久久综合一本到桃花网 | 久久久精品成人免费观看 | 久热国产vs视频在线观看 | 中文精品久久久久人妻不卡 | 亚洲国产精品无码一区二区三区 | 精品成人av一区二区三区 | 国产成人无码区免费内射一片色欲 | 久久亚洲精品中文字幕无男同 | 亚洲精品成a人在线观看 | 双乳奶水饱满少妇呻吟 | 久久久久人妻一区精品色欧美 | 国产熟妇另类久久久久 | 欧美国产日韩亚洲中文 | 国产精品美女久久久 | 亚洲人成影院在线观看 | 亚洲第一网站男人都懂 | 亚洲va中文字幕无码久久不卡 | 亚洲s色大片在线观看 | 黑人巨大精品欧美一区二区 | 东北女人啪啪对白 | 成年美女黄网站色大免费视频 | 久久午夜无码鲁丝片 | 久久国产精品_国产精品 | 中文字幕无码av波多野吉衣 | av香港经典三级级 在线 | 性做久久久久久久免费看 | 国产精品香蕉在线观看 | 国产内射爽爽大片视频社区在线 | 在线а√天堂中文官网 | 日本又色又爽又黄的a片18禁 | 国内揄拍国内精品少妇国语 | 久久精品国产日本波多野结衣 | 狂野欧美性猛xxxx乱大交 | 俺去俺来也www色官网 | 国产亚洲精品精品国产亚洲综合 | 无遮挡国产高潮视频免费观看 | 日本高清一区免费中文视频 | а√天堂www在线天堂小说 | 亚洲熟妇色xxxxx欧美老妇 | 国产精品久久久久久久9999 | 亚洲精品中文字幕乱码 | 精品无码国产一区二区三区av | 亚洲精品美女久久久久久久 | 最近免费中文字幕中文高清百度 | 国产农村妇女高潮大叫 | аⅴ资源天堂资源库在线 | 亚洲午夜无码久久 | 国产成人精品必看 | 久久久久久av无码免费看大片 | 久久精品人人做人人综合试看 | 国产亚洲精品久久久久久久 | 九月婷婷人人澡人人添人人爽 | 装睡被陌生人摸出水好爽 | 人妻尝试又大又粗久久 | 欧美日本精品一区二区三区 | 久久五月精品中文字幕 | 国产精品久久久一区二区三区 | 麻豆精品国产精华精华液好用吗 | 久久午夜夜伦鲁鲁片无码免费 | 亚洲小说春色综合另类 | 国产成人一区二区三区别 | 精品无人区无码乱码毛片国产 | 任你躁在线精品免费 | 国产黑色丝袜在线播放 | 亚洲欧美精品aaaaaa片 | 国产午夜无码视频在线观看 | 久久久久久九九精品久 | 欧美黑人性暴力猛交喷水 | 日本一区二区三区免费高清 | 久久久无码中文字幕久... | 在线播放免费人成毛片乱码 | 亚洲精品综合五月久久小说 | 精品无人国产偷自产在线 | 丝袜 中出 制服 人妻 美腿 | 亚洲熟妇色xxxxx亚洲 | 97夜夜澡人人爽人人喊中国片 | 久久国产精品精品国产色婷婷 | 无码人妻丰满熟妇区五十路百度 | 性生交片免费无码看人 | 老熟妇乱子伦牲交视频 | 老太婆性杂交欧美肥老太 | 麻豆国产人妻欲求不满 | 桃花色综合影院 | 人妻少妇被猛烈进入中文字幕 | 亚洲小说春色综合另类 | 久久国产精品_国产精品 | 天堂а√在线地址中文在线 | 亚拍精品一区二区三区探花 | 又大又黄又粗又爽的免费视频 | 帮老师解开蕾丝奶罩吸乳网站 | 欧洲精品码一区二区三区免费看 | 亚洲色www成人永久网址 | 色一情一乱一伦一视频免费看 | 日本熟妇大屁股人妻 | 婷婷丁香六月激情综合啪 | 久久综合香蕉国产蜜臀av | 99久久无码一区人妻 | 国产肉丝袜在线观看 | 丁香花在线影院观看在线播放 | 中文字幕 人妻熟女 | 久久99精品国产麻豆蜜芽 | 真人与拘做受免费视频一 | 一本久久伊人热热精品中文字幕 | 国产小呦泬泬99精品 | 中文精品无码中文字幕无码专区 | 免费中文字幕日韩欧美 | 国产免费久久精品国产传媒 | 欧美老熟妇乱xxxxx | 最新版天堂资源中文官网 | 国产亚洲人成a在线v网站 | 国产超碰人人爽人人做人人添 | 大肉大捧一进一出视频出来呀 | 亚洲中文字幕无码中文字在线 | 亚洲欧美日韩成人高清在线一区 | 久久久久免费看成人影片 | 任你躁国产自任一区二区三区 | 久久久久久国产精品无码下载 | 人人妻人人澡人人爽人人精品 | 性生交片免费无码看人 | 免费无码肉片在线观看 | 亚洲国产日韩a在线播放 | 成熟女人特级毛片www免费 | 九九综合va免费看 | 十八禁视频网站在线观看 | 国产亚洲日韩欧美另类第八页 | 午夜无码区在线观看 | 色婷婷香蕉在线一区二区 | 成人免费无码大片a毛片 | 久久久久亚洲精品男人的天堂 | 一本色道久久综合狠狠躁 | 国产精品免费大片 | 亚洲无人区午夜福利码高清完整版 | 亚洲自偷精品视频自拍 | 欧美国产亚洲日韩在线二区 | 窝窝午夜理论片影院 | 内射白嫩少妇超碰 | 久久久久se色偷偷亚洲精品av | 色一情一乱一伦一区二区三欧美 | 女人被爽到呻吟gif动态图视看 | 性做久久久久久久免费看 | 国产av一区二区精品久久凹凸 | 国产亚洲美女精品久久久2020 | 国产亚洲欧美日韩亚洲中文色 | 一区二区三区乱码在线 | 欧洲 | 狠狠亚洲超碰狼人久久 | 精品国产乱码久久久久乱码 | 亚洲欧美日韩综合久久久 | 欧美喷潮久久久xxxxx | 日本一卡二卡不卡视频查询 | 成人精品视频一区二区三区尤物 | 精品无人国产偷自产在线 | 少妇无码av无码专区在线观看 | аⅴ资源天堂资源库在线 | 欧美自拍另类欧美综合图片区 | 丰满人妻一区二区三区免费视频 | 麻豆精品国产精华精华液好用吗 | 亚洲一区二区三区国产精华液 | 欧美日本免费一区二区三区 | 又大又紧又粉嫩18p少妇 | 亚洲va中文字幕无码久久不卡 | 色综合久久久无码网中文 | 蜜臀aⅴ国产精品久久久国产老师 | 精品无码成人片一区二区98 | 偷窥日本少妇撒尿chinese | 成人欧美一区二区三区黑人 | 377p欧洲日本亚洲大胆 | 四虎永久在线精品免费网址 | 国产超级va在线观看视频 | 亚洲无人区一区二区三区 | 国产激情精品一区二区三区 | 特黄特色大片免费播放器图片 | 六十路熟妇乱子伦 | 久久精品一区二区三区四区 | 亚洲精品一区二区三区在线 | 午夜男女很黄的视频 | 成人免费视频在线观看 | 日本一卡2卡3卡四卡精品网站 | 国产又爽又黄又刺激的视频 | 亚洲成a人片在线观看无码3d | 欧美丰满熟妇xxxx | 日本爽爽爽爽爽爽在线观看免 | 久久99热只有频精品8 | 成人亚洲精品久久久久软件 | 欧美老熟妇乱xxxxx | 亚洲欧美国产精品专区久久 | 欧美日韩一区二区三区自拍 | 一本加勒比波多野结衣 | 亚洲日韩一区二区 | 小鲜肉自慰网站xnxx | 7777奇米四色成人眼影 | 日日麻批免费40分钟无码 | 2020久久香蕉国产线看观看 | 东京热男人av天堂 | 婷婷丁香六月激情综合啪 | 性做久久久久久久久 | 国产香蕉97碰碰久久人人 | 在线观看欧美一区二区三区 | av小次郎收藏 | 大乳丰满人妻中文字幕日本 | 亚洲经典千人经典日产 | 亚洲综合精品香蕉久久网 | 97久久精品无码一区二区 | 一本色道久久综合狠狠躁 | 曰韩少妇内射免费播放 | 激情五月综合色婷婷一区二区 | 国产综合色产在线精品 | 动漫av网站免费观看 | 国产午夜福利100集发布 | 久久99精品久久久久久 | 国产精品毛片一区二区 | 久久久无码中文字幕久... | 精品亚洲韩国一区二区三区 | 玩弄中年熟妇正在播放 | 乱人伦人妻中文字幕无码久久网 | 人人妻人人澡人人爽欧美一区九九 | 窝窝午夜理论片影院 | 中文久久乱码一区二区 | 久久久国产精品无码免费专区 | 少妇无套内谢久久久久 | 乱人伦人妻中文字幕无码 | 亚洲精品国偷拍自产在线麻豆 | 丰满岳乱妇在线观看中字无码 | 欧美黑人乱大交 | 亚洲精品一区二区三区婷婷月 | 久久综合网欧美色妞网 | 中文字幕无码免费久久99 | 亚无码乱人伦一区二区 | 成人免费无码大片a毛片 | 欧美精品一区二区精品久久 | 精品国产乱码久久久久乱码 | 伦伦影院午夜理论片 | 国产精品高潮呻吟av久久 | 在线 国产 欧美 亚洲 天堂 | 粗大的内捧猛烈进出视频 | 亚洲 激情 小说 另类 欧美 | www成人国产高清内射 | 色窝窝无码一区二区三区色欲 | 亚洲精品成人福利网站 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 色综合天天综合狠狠爱 | 久久人人97超碰a片精品 | 亚洲精品一区二区三区婷婷月 | 1000部夫妻午夜免费 | 久久99精品国产麻豆蜜芽 | 99久久久国产精品无码免费 | 国产人妻人伦精品 | 99国产精品白浆在线观看免费 | 丝袜足控一区二区三区 | 久久久久久久久888 | 麻豆国产人妻欲求不满 | 国产绳艺sm调教室论坛 | 国产精品福利视频导航 | 激情国产av做激情国产爱 | 免费国产成人高清在线观看网站 | 亚洲精品一区三区三区在线观看 | 国产国产精品人在线视 | 乌克兰少妇xxxx做受 | 色欲av亚洲一区无码少妇 | 久久无码专区国产精品s | 久久zyz资源站无码中文动漫 | 99久久精品国产一区二区蜜芽 | 高潮毛片无遮挡高清免费视频 | 中国女人内谢69xxxxxa片 | 亚洲第一网站男人都懂 | 欧美高清在线精品一区 | 野外少妇愉情中文字幕 | 成人亚洲精品久久久久 | 精品久久久无码人妻字幂 | 国产无遮挡吃胸膜奶免费看 | 久久午夜无码鲁丝片秋霞 | 黑森林福利视频导航 | 桃花色综合影院 | 亚洲一区二区三区香蕉 | 午夜理论片yy44880影院 | 国产成人亚洲综合无码 | 夫妻免费无码v看片 | 国产亚洲日韩欧美另类第八页 | 国产高清不卡无码视频 | 未满小14洗澡无码视频网站 | 波多野结衣一区二区三区av免费 | 中文字幕无码视频专区 | 人妻与老人中文字幕 | 国产人妖乱国产精品人妖 | 色情久久久av熟女人妻网站 | 亚洲一区二区三区在线观看网站 | 麻豆国产人妻欲求不满 | 老司机亚洲精品影院 | 色婷婷香蕉在线一区二区 | 中文字幕人成乱码熟女app | 欧美兽交xxxx×视频 | 在线a亚洲视频播放在线观看 | 狠狠色欧美亚洲狠狠色www | 狠狠色色综合网站 | 国产精品资源一区二区 | 亚洲国产精品久久久天堂 | 少妇无码av无码专区在线观看 | 亚洲精品无码国产 | 成人女人看片免费视频放人 | 成熟人妻av无码专区 | 国产乱人伦偷精品视频 | 日韩av无码中文无码电影 | 免费观看激色视频网站 | 亚洲精品久久久久久一区二区 | 久久精品成人欧美大片 | 激情爆乳一区二区三区 | 亚洲一区二区三区四区 | 国产在线一区二区三区四区五区 | 国内精品人妻无码久久久影院 | 日韩精品一区二区av在线 | 少妇被黑人到高潮喷出白浆 | 55夜色66夜色国产精品视频 | 国产精品va在线播放 | 日本精品少妇一区二区三区 | 色欲久久久天天天综合网精品 | 亚洲人交乣女bbw | 黑人粗大猛烈进出高潮视频 | 午夜精品一区二区三区的区别 | 白嫩日本少妇做爰 | 亚洲日本va午夜在线电影 | 好爽又高潮了毛片免费下载 | 成 人 网 站国产免费观看 | 久久久久av无码免费网 | 午夜精品久久久久久久久 | 76少妇精品导航 | 无遮无挡爽爽免费视频 | 欧美成人高清在线播放 | 亚洲人成网站在线播放942 | 女高中生第一次破苞av | 精品夜夜澡人妻无码av蜜桃 | 久久五月精品中文字幕 | 亚洲大尺度无码无码专区 | 国产亚洲精品久久久ai换 | 国产成人无码av片在线观看不卡 | 国产香蕉尹人综合在线观看 | av无码不卡在线观看免费 | 久久精品国产精品国产精品污 | 99久久精品午夜一区二区 | 久久久成人毛片无码 | 国产99久久精品一区二区 | 亚洲高清偷拍一区二区三区 | 国产在热线精品视频 | 无码人妻精品一区二区三区不卡 | 狠狠色噜噜狠狠狠狠7777米奇 | 久久亚洲国产成人精品性色 | 男人扒开女人内裤强吻桶进去 | 欧美日韩一区二区免费视频 | 久久精品国产99精品亚洲 | 少妇的肉体aa片免费 | 最新版天堂资源中文官网 | 荫蒂添的好舒服视频囗交 | 偷窥村妇洗澡毛毛多 | 女高中生第一次破苞av | 亚欧洲精品在线视频免费观看 | a片在线免费观看 | 无码人妻丰满熟妇区毛片18 | 亚洲啪av永久无码精品放毛片 | 97精品人妻一区二区三区香蕉 | 99久久久无码国产精品免费 | 国产无av码在线观看 | 久久精品国产日本波多野结衣 | 精品无人区无码乱码毛片国产 | 国产激情一区二区三区 | 夜先锋av资源网站 | 欧美日韩久久久精品a片 | 内射爽无广熟女亚洲 | 亚洲另类伦春色综合小说 | 亚洲中文字幕无码中字 | 欧美 丝袜 自拍 制服 另类 | 日韩人妻少妇一区二区三区 | 亚洲一区二区三区在线观看网站 | 日本又色又爽又黄的a片18禁 | 亚洲熟妇色xxxxx欧美老妇y | 色诱久久久久综合网ywww | 国产亚洲欧美日韩亚洲中文色 | 日日鲁鲁鲁夜夜爽爽狠狠 | 亚洲人成影院在线观看 | aⅴ亚洲 日韩 色 图网站 播放 | 日本丰满熟妇videos | 久久亚洲中文字幕无码 | 人人超人人超碰超国产 | 亚洲 欧美 激情 小说 另类 | 亚洲国产成人av在线观看 | 欧美人与物videos另类 | 国产精品亚洲lv粉色 | 精品乱子伦一区二区三区 | 中文字幕无码人妻少妇免费 | 妺妺窝人体色www婷婷 | 98国产精品综合一区二区三区 | 麻豆国产丝袜白领秘书在线观看 | 玩弄人妻少妇500系列视频 | 色综合天天综合狠狠爱 | 成熟妇人a片免费看网站 | 日本在线高清不卡免费播放 | 日本熟妇大屁股人妻 | 久久综合香蕉国产蜜臀av | 乱码av麻豆丝袜熟女系列 | 成人三级无码视频在线观看 | 国产精品久久久久久亚洲毛片 | 日韩无套无码精品 | av在线亚洲欧洲日产一区二区 | 人妻少妇精品视频专区 | 大胆欧美熟妇xx | 久久久婷婷五月亚洲97号色 | 99久久99久久免费精品蜜桃 | 色偷偷人人澡人人爽人人模 | 老熟妇仑乱视频一区二区 | 夫妻免费无码v看片 | 国产亚洲精品久久久久久国模美 | 人妻夜夜爽天天爽三区 | 麻豆国产97在线 | 欧洲 | 久久人妻内射无码一区三区 | 午夜男女很黄的视频 | 久久午夜无码鲁丝片 | 大乳丰满人妻中文字幕日本 | 日日麻批免费40分钟无码 | 十八禁真人啪啪免费网站 | 性欧美疯狂xxxxbbbb | 精品厕所偷拍各类美女tp嘘嘘 | 少妇高潮喷潮久久久影院 | 国内老熟妇对白xxxxhd | 玩弄少妇高潮ⅹxxxyw | 国产成人无码专区 | 亚洲色www成人永久网址 | 狠狠躁日日躁夜夜躁2020 | 乱码午夜-极国产极内射 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 国产 精品 自在自线 | 亚洲午夜福利在线观看 | 一个人免费观看的www视频 | 麻豆国产97在线 | 欧洲 | 国产成人精品优优av | 久久zyz资源站无码中文动漫 | 国产精品99久久精品爆乳 | 在线精品国产一区二区三区 | 国产精品手机免费 | 色一情一乱一伦一视频免费看 | 国产肉丝袜在线观看 | 婷婷五月综合缴情在线视频 | 久久久国产一区二区三区 | 男人扒开女人内裤强吻桶进去 | 国产成人精品优优av | 麻豆成人精品国产免费 | 国产三级精品三级男人的天堂 | 曰本女人与公拘交酡免费视频 | 日日碰狠狠躁久久躁蜜桃 | 日本乱人伦片中文三区 | 黑人大群体交免费视频 | 国产一区二区三区日韩精品 | 性欧美疯狂xxxxbbbb | 三上悠亚人妻中文字幕在线 | 欧美激情内射喷水高潮 | 亚洲一区二区三区四区 | 色偷偷人人澡人人爽人人模 | 国产精品爱久久久久久久 | 久久久中文字幕日本无吗 | 两性色午夜免费视频 | 久精品国产欧美亚洲色aⅴ大片 | 在线观看国产一区二区三区 | 伊人久久大香线焦av综合影院 | 天天燥日日燥 | 老子影院午夜伦不卡 | 亚洲成av人在线观看网址 | 日本精品久久久久中文字幕 | 欧美丰满老熟妇xxxxx性 | 日本爽爽爽爽爽爽在线观看免 | 在线观看国产一区二区三区 | 麻豆国产97在线 | 欧洲 | 99在线 | 亚洲 | 亚洲中文字幕在线无码一区二区 | 爽爽影院免费观看 | 亚洲熟女一区二区三区 | 在线播放无码字幕亚洲 | 国产精品久久久久9999小说 | 成人av无码一区二区三区 | 亚洲综合精品香蕉久久网 | 国产熟女一区二区三区四区五区 | 婷婷丁香六月激情综合啪 | 亚洲区欧美区综合区自拍区 | 国语自产偷拍精品视频偷 | 荫蒂被男人添的好舒服爽免费视频 | 亚洲综合另类小说色区 | 久久精品人妻少妇一区二区三区 | 国产尤物精品视频 | 亚洲成熟女人毛毛耸耸多 | 国产日产欧产精品精品app | 18禁黄网站男男禁片免费观看 | 亚洲精品国产a久久久久久 | 久久精品成人欧美大片 | 牲欲强的熟妇农村老妇女视频 | 亚洲aⅴ无码成人网站国产app | 又粗又大又硬又长又爽 | 人妻中文无码久热丝袜 | 久久久久久久女国产乱让韩 | 欧美第一黄网免费网站 | 国产精品亚洲一区二区三区喷水 | 亚洲欧美国产精品专区久久 | 人人爽人人澡人人高潮 | 亚洲日本va午夜在线电影 | 国产69精品久久久久app下载 | 国产精品第一区揄拍无码 | 最近中文2019字幕第二页 | 日日摸夜夜摸狠狠摸婷婷 | 精品无码成人片一区二区98 | 亚洲综合无码一区二区三区 | 久久综合给久久狠狠97色 | 亚洲成a人片在线观看日本 | 99久久亚洲精品无码毛片 | 午夜精品久久久久久久 | 女人被男人爽到呻吟的视频 | 四虎国产精品免费久久 | 日韩少妇内射免费播放 | 在线观看国产一区二区三区 | 精品亚洲成av人在线观看 | 成人av无码一区二区三区 | 嫩b人妻精品一区二区三区 | 国产成人综合美国十次 | 少妇性l交大片欧洲热妇乱xxx | 久久精品中文字幕大胸 | 亚洲狠狠婷婷综合久久 | 成年女人永久免费看片 | 色一情一乱一伦一视频免费看 | 亚洲欧洲日本综合aⅴ在线 | 日韩精品无码免费一区二区三区 | 日本熟妇浓毛 | 麻豆国产人妻欲求不满 | 狠狠色色综合网站 | 欧美午夜特黄aaaaaa片 | 国产又爽又猛又粗的视频a片 | 永久免费观看国产裸体美女 | 婷婷色婷婷开心五月四房播播 | 亚洲一区二区三区在线观看网站 | 在线播放亚洲第一字幕 | 欧美性猛交xxxx富婆 | 国产免费久久久久久无码 | 欧美成人免费全部网站 | 国产另类ts人妖一区二区 | 国产香蕉97碰碰久久人人 | 好爽又高潮了毛片免费下载 | 色婷婷香蕉在线一区二区 | 国产特级毛片aaaaaa高潮流水 | 久久熟妇人妻午夜寂寞影院 | 国产真实伦对白全集 | 亚洲欧洲日本综合aⅴ在线 | 久久久亚洲欧洲日产国码αv | 欧美性生交xxxxx久久久 | 日本饥渴人妻欲求不满 | 久久精品国产一区二区三区 | 在线亚洲高清揄拍自拍一品区 | a国产一区二区免费入口 | 久久久久人妻一区精品色欧美 | 久久五月精品中文字幕 | 国产午夜福利100集发布 | 内射老妇bbwx0c0ck | 亚洲小说春色综合另类 | 成人欧美一区二区三区 | 欧美猛少妇色xxxxx | 国产成人精品久久亚洲高清不卡 | 大乳丰满人妻中文字幕日本 | 宝宝好涨水快流出来免费视频 | 国产精品高潮呻吟av久久 | 亚洲精品午夜无码电影网 | 狂野欧美性猛交免费视频 | 国产又爽又黄又刺激的视频 | 亚洲成色在线综合网站 | 欧美人与物videos另类 | 亚洲中文字幕在线无码一区二区 | 在线 国产 欧美 亚洲 天堂 | 人人妻人人藻人人爽欧美一区 | 欧美精品国产综合久久 | 欧美精品无码一区二区三区 | 亚洲啪av永久无码精品放毛片 | 国产无套内射久久久国产 | 亚洲日本在线电影 | 国产成人综合美国十次 | 国产成人无码一二三区视频 | 国产热a欧美热a在线视频 | 九九久久精品国产免费看小说 | 男女下面进入的视频免费午夜 | 精品无码国产自产拍在线观看蜜 | 乌克兰少妇性做爰 | 欧美三级a做爰在线观看 | 日本护士毛茸茸高潮 | 午夜无码区在线观看 | 一二三四在线观看免费视频 | 粉嫩少妇内射浓精videos | 亚洲精品一区二区三区在线 | 久久人人爽人人人人片 | 国产精品毛多多水多 | 亚洲国产精品成人久久蜜臀 | 爆乳一区二区三区无码 | 伊人久久大香线焦av综合影院 | 国产后入清纯学生妹 | 亚洲小说图区综合在线 | 成人无码影片精品久久久 | 久久综合九色综合欧美狠狠 | 国产猛烈高潮尖叫视频免费 | 中文字幕无码免费久久99 | 成在人线av无码免观看麻豆 | 激情五月综合色婷婷一区二区 | 色五月丁香五月综合五月 | 人妻无码久久精品人妻 | 亚洲另类伦春色综合小说 | 六月丁香婷婷色狠狠久久 | 久久综合给久久狠狠97色 | 人妻天天爽夜夜爽一区二区 | 国产精品-区区久久久狼 | 亚洲熟妇色xxxxx亚洲 | 亚洲娇小与黑人巨大交 | 国产婷婷色一区二区三区在线 | 久久精品国产一区二区三区肥胖 | 日产国产精品亚洲系列 | av无码电影一区二区三区 | 好男人社区资源 | 亚洲欧美色中文字幕在线 | 国产色xx群视频射精 | 少妇无码一区二区二三区 | 无码国内精品人妻少妇 | 少妇性l交大片 | 强伦人妻一区二区三区视频18 | 久久精品成人欧美大片 | 日日噜噜噜噜夜夜爽亚洲精品 | 国产性生交xxxxx无码 | 少妇无码一区二区二三区 | 亚洲区欧美区综合区自拍区 | 精品久久久久香蕉网 | 久久久久人妻一区精品色欧美 | 久久天天躁狠狠躁夜夜免费观看 | 亚洲の无码国产の无码影院 | 久激情内射婷内射蜜桃人妖 | 久久精品国产大片免费观看 | 国产成人人人97超碰超爽8 | 国内精品人妻无码久久久影院 | 综合人妻久久一区二区精品 | 日韩精品a片一区二区三区妖精 | 无码一区二区三区在线 | 亚洲精品欧美二区三区中文字幕 | 又大又硬又黄的免费视频 | 亚洲七七久久桃花影院 | 无码一区二区三区在线 | 欧美 丝袜 自拍 制服 另类 | 国产xxx69麻豆国语对白 | 伊人久久大香线焦av综合影院 | 蜜桃视频插满18在线观看 | 日本一卡2卡3卡四卡精品网站 | 欧美午夜特黄aaaaaa片 | 中文字幕无码av激情不卡 | 国产成人无码av片在线观看不卡 | 露脸叫床粗话东北少妇 | 国产精品多人p群无码 | 九九综合va免费看 | 高清无码午夜福利视频 | 国产无遮挡又黄又爽免费视频 | 亚洲精品久久久久中文第一幕 | 久久99精品国产.久久久久 | 55夜色66夜色国产精品视频 | 欧美人与牲动交xxxx | 中文字幕人妻无码一区二区三区 | 亚洲精品成a人在线观看 | 久久国产精品萌白酱免费 | 国产精品人人爽人人做我的可爱 | 国产激情无码一区二区app | 少妇无码av无码专区在线观看 | 97久久精品无码一区二区 | 国产卡一卡二卡三 | 蜜桃视频插满18在线观看 | 久久国产精品偷任你爽任你 | 久久午夜无码鲁丝片 | 蜜桃视频韩日免费播放 | 99国产欧美久久久精品 | 国产三级久久久精品麻豆三级 | 国模大胆一区二区三区 | 成人免费视频视频在线观看 免费 | 久久久成人毛片无码 | 久久久久成人片免费观看蜜芽 | 国内综合精品午夜久久资源 | 久久久精品欧美一区二区免费 | 久久精品一区二区三区四区 | 成 人 网 站国产免费观看 | 成人女人看片免费视频放人 | 久久久久久久人妻无码中文字幕爆 | 国产精品内射视频免费 | 国产亚洲美女精品久久久2020 | 中文字幕 亚洲精品 第1页 | 国产av一区二区精品久久凹凸 | 国产精品无码一区二区三区不卡 | 亚洲国产欧美日韩精品一区二区三区 | 少妇愉情理伦片bd | 无遮挡国产高潮视频免费观看 | 国产人妻精品一区二区三区不卡 | 色综合久久网 | 永久免费观看美女裸体的网站 | 久久国语露脸国产精品电影 | 无码av最新清无码专区吞精 | 高清国产亚洲精品自在久久 | 一二三四在线观看免费视频 | 国产在线一区二区三区四区五区 | 少妇无码av无码专区在线观看 | 国产9 9在线 | 中文 | 蜜桃av抽搐高潮一区二区 | 国产亚洲视频中文字幕97精品 | 久久精品国产一区二区三区肥胖 | 久久精品一区二区三区四区 | 国产又粗又硬又大爽黄老大爷视 | 99久久精品国产一区二区蜜芽 | 人妻少妇精品久久 | 日产精品99久久久久久 | 成人一在线视频日韩国产 | 中文字幕无码日韩欧毛 | 亚洲无人区一区二区三区 | 国产激情无码一区二区 | 噜噜噜亚洲色成人网站 | 亚洲日韩av一区二区三区中文 | 全黄性性激高免费视频 | 爆乳一区二区三区无码 | 欧美高清在线精品一区 | 秋霞特色aa大片 | 国产成人精品优优av | 日本护士xxxxhd少妇 | 色欲av亚洲一区无码少妇 | 中文字幕无码日韩欧毛 | 人人妻在人人 | 2019nv天堂香蕉在线观看 | 欧美精品国产综合久久 | 99re在线播放 |