精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

項目中數(shù)據(jù)庫密碼沒有加密導(dǎo)致了數(shù)據(jù)泄露!!

運(yùn)維 數(shù)據(jù)庫運(yùn)維
作者個人研發(fā)的在高并發(fā)場景下,提供的簡單、穩(wěn)定、可擴(kuò)展的延遲消息隊列框架,具有精準(zhǔn)的定時任務(wù)和延遲隊列處理功能。自開源半年多以來,已成功為十幾家中小型企業(yè)提供了精準(zhǔn)定時調(diào)度方案,經(jīng)受住了生產(chǎn)環(huán)境的考驗。

[[383999]]

作者個人研發(fā)的在高并發(fā)場景下,提供的簡單、穩(wěn)定、可擴(kuò)展的延遲消息隊列框架,具有精準(zhǔn)的定時任務(wù)和延遲隊列處理功能。自開源半年多以來,已成功為十幾家中小型企業(yè)提供了精準(zhǔn)定時調(diào)度方案,經(jīng)受住了生產(chǎn)環(huán)境的考驗。為使更多童鞋受益,現(xiàn)給出開源框架地址:https://github.com/sunshinelyz/mykit-delay

寫在前面

最近,有位讀者私信我說,他們公司的項目中配置的數(shù)據(jù)庫密碼沒有加密,編譯打包后的項目被人反編譯了,從項目中成功獲取到數(shù)據(jù)庫的賬號和密碼,進(jìn)一步登錄數(shù)據(jù)庫獲取了相關(guān)的數(shù)據(jù),并對數(shù)據(jù)庫進(jìn)行了破壞。雖然這次事故影響的范圍不大,但是這足以說明很多公司對于項目的安全性問題重視程度不夠。

文章已收錄到:

https://github.com/sunshinelyz/technology-binghe

https://gitee.com/binghe001/technology-binghe

數(shù)據(jù)泄露緣由

由于Java項目的特殊性,打包后的項目如果沒有做代碼混淆,配置文件中的重要配置信息沒有做加密處理的話,一旦打包的程序被反編譯后,很容易獲得這些敏感信息,進(jìn)一步對項目或者系統(tǒng)造成一定的損害。所以,無論是公司層面還是開發(fā)者個人,都需要對項目的安全性有所重視。

今天,我們就一起來聊聊如何在項目中加密數(shù)據(jù)庫密碼,盡量保證數(shù)據(jù)庫密碼的安全性。本文中,我使用的數(shù)據(jù)庫連接池是阿里開源的Druid。

數(shù)據(jù)庫密碼加密

配置數(shù)據(jù)庫連接池

這里,我就簡單的使用xml配置進(jìn)行演示,當(dāng)然小伙伴們也可以使用Spring注解方式,或者使用SpringBoot進(jìn)行配置。

  1. <!--數(shù)據(jù)源加密操作--> 
  2. <bean id="dbPasswordCallback" class="com.binghe.dbsource.DBPasswordCallback" lazy-init="true"/> 
  3.   
  4. <bean id="statFilter" class="com.alibaba.druid.filter.stat.StatFilter" lazy-init="true"
  5.         <property name="logSlowSql" value="true"/> 
  6.         <property name="mergeSql" value="true"/> 
  7.     </bean> 
  8. <!-- 數(shù)據(jù)庫連接 --> 
  9. <bean id="readDataSource" class="com.alibaba.druid.pool.DruidDataSource" 
  10.           destroy-method="close" init-method="init" lazy-init="true"
  11.         <property name="driverClassName" value="${driver}"/> 
  12.         <property name="url" value="${url1}"/> 
  13.         <property name="username" value="${username}"/> 
  14.         <property name="password" value="${password}"/> 
  15.         <!-- 初始化連接大小 --> 
  16.         <property name="initialSize" value="${initialSize}"/> 
  17.         <!-- 連接池最大數(shù)量 --> 
  18.         <property name="maxActive" value="${maxActive}"/> 
  19.         <!-- 連接池最小空閑 --> 
  20.         <property name="minIdle" value="${minIdle}"/> 
  21.         <!-- 獲取連接最大等待時間 --> 
  22.         <property name="maxWait" value="${maxWait}"/> 
  23.         <!-- --> 
  24.         <property name="defaultReadOnly" value="true"/> 
  25.         <property name="proxyFilters"
  26.             <list> 
  27.                 <ref bean="statFilter"/> 
  28.             </list> 
  29.         </property> 
  30.         <property name="filters" value="${druid.filters}"/> 
  31.         <property name="connectionProperties" value="password=${password}"/> 
  32.         <property name="passwordCallback" ref="dbPasswordCallback"/> 
  33.         <property name="testWhileIdle" value="true"/> 
  34.         <property name="testOnBorrow" value="false"/> 
  35.         <property name="testOnReturn" value="false"/> 
  36.         <property name="validationQuery" value="SELECT 'x'"/> 
  37.         <property name="timeBetweenLogStatsMillis" value="60000"/> 
  38.         <!-- 配置一個連接在池中最小生存的時間,單位是毫秒 --> 
  39.         <property name="minEvictableIdleTimeMillis" value="${minEvictableIdleTimeMillis}"/> 
  40.         <!-- 配置間隔多久才進(jìn)行一次檢測,檢測需要關(guān)閉的空閑連接,單位是毫秒 --> 
  41.         <property name="timeBetweenEvictionRunsMillis" value="${timeBetweenEvictionRunsMillis}"/> 
  42. </bean> 

其中要注意的是:我在配置文件中進(jìn)行了如下配置。

  1. <bean id="dbPasswordCallback" class="com.binghe.dbsource.DBPasswordCallback" lazy-init="true"/> 
  2.   
  3. <property name="connectionProperties" value="password=${password}"/>   
  4. <property name="passwordCallback" ref="dbPasswordCallback"/> 

生成RSA密鑰

使用RSA公鑰和私鑰,生成一對公鑰和私鑰的工具類如下所示。

  1. package com.binghe.crypto.rsa; 
  2. import java.security.Key
  3. import java.security.KeyPair; 
  4. import java.security.KeyPairGenerator; 
  5. import java.security.interfaces.RSAPrivateKey; 
  6. import java.security.interfaces.RSAPublicKey; 
  7. import java.util.HashMap; 
  8. import java.util.Map; 
  9. import sun.misc.BASE64Decoder; 
  10. import sun.misc.BASE64Encoder; 
  11. /** 
  12.  * 算法工具類 
  13.  * @author binghe 
  14.  */ 
  15. public class RSAKeysUtil { 
  16.   
  17.     public static final String KEY_ALGORITHM = "RSA"
  18.     public static final String SIGNATURE_ALGORITHM = "MD5withRSA"
  19.     private static final String PUBLIC_KEY = "RSAPublicKey"
  20.     private static final String PRIVATE_KEY = "RSAPrivateKey"
  21.   
  22.     public static void main(String[] args) { 
  23.         Map<String, Object> keyMap; 
  24.         try { 
  25.             keyMap = initKey(); 
  26.             String publicKey = getPublicKey(keyMap); 
  27.             System.out.println(publicKey); 
  28.             String privateKey = getPrivateKey(keyMap); 
  29.             System.out.println(privateKey); 
  30.         } catch (Exception e) { 
  31.             e.printStackTrace(); 
  32.         } 
  33.     } 
  34.   
  35.     public static String getPublicKey(Map<String, Object> keyMap) throws Exception { 
  36.         Key key = (Key) keyMap.get(PUBLIC_KEY); 
  37.         byte[] publicKey = key.getEncoded(); 
  38.         return encryptBASE64(key.getEncoded()); 
  39.     } 
  40.   
  41.     public static String getPrivateKey(Map<String, Object> keyMap) throws Exception { 
  42.         Key key = (Key) keyMap.get(PRIVATE_KEY); 
  43.         byte[] privateKey = key.getEncoded(); 
  44.         return encryptBASE64(key.getEncoded()); 
  45.     } 
  46.   
  47.     public static byte[] decryptBASE64(String key) throws Exception { 
  48.         return (new BASE64Decoder()).decodeBuffer(key); 
  49.     } 
  50.   
  51.     public static String encryptBASE64(byte[] key) throws Exception { 
  52.         return (new BASE64Encoder()).encodeBuffer(key); 
  53.     } 
  54.   
  55.     public static Map<String, Object> initKey() throws Exception { 
  56.         KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance(KEY_ALGORITHM); 
  57.         keyPairGen.initialize(1024); 
  58.         KeyPair keyPair = keyPairGen.generateKeyPair(); 
  59.         RSAPublicKey publicKey = (RSAPublicKey) keyPair.getPublic(); 
  60.         RSAPrivateKey privateKey = (RSAPrivateKey) keyPair.getPrivate(); 
  61.         Map<String, Object> keyMap = new HashMap<String, Object>(2); 
  62.         keyMap.put(PUBLIC_KEY, publicKey); 
  63.         keyMap.put(PRIVATE_KEY, privateKey); 
  64.         return keyMap; 
  65.     } 

運(yùn)行這個類,輸出的結(jié)果如下:

在輸出的結(jié)果信息中,上邊是公鑰下邊是私鑰。

對密碼進(jìn)行加密

使用私鑰對明文密碼進(jìn)行加密,示例代碼如下所示。

  1. package com.binghe.dbsource.demo; 
  2. import com.alibaba.druid.filter.config.ConfigTools; 
  3. /** 
  4.  * 使用密鑰加密數(shù)據(jù)庫密碼的代碼示例 
  5.  * @author binghe 
  6.  */ 
  7. public class ConfigToolsDemo { 
  8.  /** 
  9.   * 私鑰對數(shù)據(jù)進(jìn)行加密 
  10.   */ 
  11.  private static final String PRIVATE_KEY_STRING = "MIICdgIBADANBgkqhkiG9w0BAQEFAASCAmAwggJcAgEAAoGBAKtq3IJP5idDXZjML6I8HTAl0htWZSOO43LhZ/+stsIG50WsuW0UJ2vdrEtjvTEfJxP6N1VNrbsF9Lrsp6A4AyUwx00ZUueTlbUaX60134Di0IdQ3C4RTt5mPIbF3hUKers8csltgYR4fByvR3Eq4lt+jAolVHKmyzufukH3d3vJAgMBAAECgYBXiyW+r4t9NdxRMsaI9mZ5tncNWxwgAtOKUi/I1a4ofVoTrVitqoNPhVB+2BtBQQW2IC2uNROq1incZQxeuPxxZJgz1lnnZyHvDE3wuMZAGTcalID+5xBZ2j6fBtDnxbfIL/tIfGJrX+0mUXP2LIo242yQIlzr7RV60iuE2Ms54QJBAOqE0ycvztfxubqBWO7l8PsS3qDUv9lLBBO/Q8I+qVl4tzh+SD/13BqLuaj9eWPGPyml+faWtbmuQgBqauT23l0CQQC7HmMC0CgZS6taQxmPkXzw0XhxZ7tBZeLWl87hqc2S79P0BPX9kPukiC4LpA5xyz0CZ5azJXd2EwRsxF32GERdAkASEi4bJOnxZeUD5BewQPOyxR92kS4/VjJ4OxLDkwSFqnGj3sc+dnmBaibiSLXj5FDVqr56K97Q8gaP9aNLBWLZAkEAjwGnPBQoQUTinaZgl6fibA47VbiolU+v8L+u3iqvMVhXjcxo0DUJDXMCdeUZIQDqDLdsplfBGB1qqVHeWeGsBQJAXGNe2I510WLjMdn+olhi5ZjMr4F4oiF8TAE1Uu74FWn0sc418E7ScgXPCgpGVK0QaXo2wtDeMIoxJwm9Zh8oyg=="
  12.     public static void main(String[] args) throws Exception { 
  13.       //密碼明文,也就是數(shù)據(jù)庫的密碼 
  14.         String plainText = "root"
  15.         System.out.printf(ConfigTools.encrypt(PRIVATE_KEY_STRING, plainText)); 
  16.  } 

運(yùn)行上述代碼示例,結(jié)果如下所示。

然后將數(shù)據(jù)庫配置的鏈接密碼改為這個輸出結(jié)果如下:

  1. jdbc.username=root 
  2. jdbc.password=EA9kJ8NMV8zcb5AeLKzAsL/8F1ructRjrqs69zM70BwDyeMtxuEDEVe9CBeRgZ+qEUAshhWGEDk9ay3TLLKrf2AOE3VBn+w8+EfUIEXFy8u3jYViHeV8yc8Z7rghdFShhd/IJbjqbsro1YtB9pHrl4EpbCqp7RM2rZR/wJ0WN48= 

編寫解析數(shù)據(jù)庫密碼的類

  1. package com.binghe.dbsource; 
  2. import java.util.Properties; 
  3. import com.alibaba.druid.filter.config.ConfigTools; 
  4. import com.alibaba.druid.util.DruidPasswordCallback; 
  5. /** 
  6.  * 數(shù)據(jù)庫密碼回調(diào) 
  7.  * @author binghe 
  8.  */ 
  9. public class DBPasswordCallback extends DruidPasswordCallback { 
  10.  private static final long serialVersionUID = -4601105662788634420L; 
  11.  /** 
  12.   * password的屬性 
  13.   */ 
  14.  private static final String DB_PWD = "password"
  15.  /** 
  16.   * 數(shù)據(jù)對應(yīng)的公鑰 
  17.   */ 
  18.  public static final String PUBLIC_KEY_STRING = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCratyCT+YnQ12YzC+iPB0wJdIbVmUjjuNy4Wf/rLbCBudFrLltFCdr3axLY70xHycT+jdVTa27BfS67KegOAMlMMdNGVLnk5W1Gl+tNd+A4tCHUNwuEU7eZjyGxd4VCnq7PHLJbYGEeHwcr0dxKuJbfowKJVRypss7n7pB93d7yQIDAQAB"
  19.   
  20.  @Override 
  21.  public void setProperties(Properties properties) { 
  22.         super.setProperties(properties); 
  23.         String pwd = properties.getProperty(DB_PWD); 
  24.         if (pwd != null && !"".equals(pwd.trim())) { 
  25.             try { 
  26.                 //這里的password是將jdbc.properties配置得到的密碼進(jìn)行解密之后的值 
  27.                 //所以這里的代碼是將密碼進(jìn)行解密 
  28.                 //TODO 將pwd進(jìn)行解密; 
  29.                 String password = ConfigTools.decrypt(PUBLIC_KEY_STRING, pwd);  
  30.                 setPassword(password.toCharArray()); 
  31.             } catch (Exception e) { 
  32.                 setPassword(pwd.toCharArray()); 
  33.             } 
  34.         } 
  35.     } 

這里DBPasswordCallback類,就是在配置文件中配置的DBPasswordCallback類,如下所示。

  1. <bean id="dbPasswordCallback" class="com.binghe.dbsource.DBPasswordCallback" lazy-init="true"/> 

其中PasswordCallback是javax.security.auth.callback包下面的,底層安全服務(wù)實例化一個 PasswordCallback 并將其傳遞給 CallbackHandler 的 handle 方法,以獲取密碼信息。

當(dāng)然,除了使用上述的方式,自己也可以對應(yīng)一套加解密方法,只需要將 DBPasswordCallback的 String password = ConfigTools.decrypt(PUBLIC_KEY_STRING, pwd); 替換即可。

另外,在編寫解析數(shù)據(jù)庫密碼的類時,除了可以繼承阿里巴巴開源的Druid框架中的DruidPasswordCallback類外,還可以直接繼承自Spring提供的PropertyPlaceholderConfigurer類,如下所示。

  1. public class DecryptPropertyPlaceholderConfigurer extends PropertyPlaceholderConfigurer{ 
  2.     /** 
  3.      * 重寫父類方法,解密指定屬性名對應(yīng)的屬性值 
  4.      */ 
  5.     @Override 
  6.     protected String convertProperty(String propertyName,String propertyValue){ 
  7.         if(isEncryptPropertyVal(propertyName)){ 
  8.             return DesUtils.getDecryptString(propertyValue);//調(diào)用解密方法 
  9.         }else
  10.             return propertyValue; 
  11.         } 
  12.     } 
  13.     /** 
  14.      * 判斷屬性值是否需要解密,這里我約定需要解密的屬性名用encrypt開頭 
  15.      */ 
  16.     private boolean isEncryptPropertyVal(String propertyName){ 
  17.         if(propertyName.startsWith("encrypt")){ 
  18.             return true
  19.         }else
  20.             return false
  21.         } 
  22.     } 

此時,就需要將xml文件中的如下配置

  1. <bean id="dbPasswordCallback" class="com.binghe.dbsource.DBPasswordCallback" lazy-init="true"/> 

修改為下面的配置。

  1. <bean id="dbPasswordCallback" class="com.binghe.dbsource.DecryptPropertyPlaceholderConfigurer" lazy-init="true"/> 

到此,在項目中對數(shù)據(jù)庫密碼進(jìn)行加密和解析的整個過程就完成了。

本文轉(zhuǎn)載自微信公眾號「冰河技術(shù)」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系冰河技術(shù)公眾號。

 

責(zé)任編輯:武曉燕 來源: 冰河技術(shù)
相關(guān)推薦

2010-05-19 13:37:39

MySQL數(shù)據(jù)庫密碼

2011-05-24 14:48:46

壓縮數(shù)據(jù)庫

2021-01-06 10:52:02

MySQL數(shù)據(jù)庫安全

2022-04-11 06:56:14

數(shù)據(jù)庫安全數(shù)據(jù)泄露

2015-03-23 11:21:08

2011-03-02 16:43:25

2011-08-30 09:14:49

SQL ServerJOIN條件笛卡爾乘積

2017-12-20 09:59:06

2021-10-09 12:56:45

數(shù)據(jù)庫泄露網(wǎng)絡(luò)攻擊網(wǎng)絡(luò)安全

2024-01-22 09:43:50

數(shù)據(jù)庫方案

2022-01-06 11:34:09

數(shù)據(jù)庫物聯(lián)網(wǎng)應(yīng)用

2021-12-29 06:13:44

數(shù)據(jù)庫密碼數(shù)據(jù)泄露

2023-09-01 07:30:59

2022-07-21 12:49:21

數(shù)據(jù)泄露黑客

2021-01-27 21:21:46

數(shù)據(jù)泄露網(wǎng)絡(luò)安全信息安全

2011-03-10 08:42:15

SQL Server備份還原

2025-08-26 01:15:00

Spring項目數(shù)據(jù)源

2012-12-20 10:22:49

2020-08-18 08:09:55

Docker容器工具

2019-08-07 06:34:32

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

狠狠操精品视频| 麻豆av一区二区| 日本少妇高清视频| 粉嫩一区二区三区四区公司1| 亚洲综合一区在线| 欧美日韩综合久久| 国产精品女同一区二区| 激情视频一区| 中文国产成人精品| 丰满少妇xbxb毛片日本| 日韩欧美另类一区二区| 亚洲三级在线观看| 国产综合18久久久久久| 中文字幕一区2区3区| 亚洲激情女人| x99av成人免费| 久久午夜夜伦鲁鲁片| 国产精品国产三级在线观看| 精品国产乱码久久久久久婷婷 | 国产又粗又猛又爽又黄的| 亚洲精品一二三区区别| 亚洲毛片在线观看.| 性一交一黄一片| 国产精品久久久久77777丨| 一二三四社区欧美黄| 色播五月综合| 午夜影院免费体验区| 韩国av一区二区三区| 136fldh精品导航福利| 免费中文字幕在线| 日韩国产一区二区| 亚洲精品理论电影| 制服下的诱惑暮生| 国产a亚洲精品| 欧美日韩国内自拍| 无颜之月在线看| 自拍视频在线网| 91视频在线观看免费| 丁香婷婷久久久综合精品国产| 亚洲天堂avav| 蜜臀国产一区二区三区在线播放| 性色av一区二区三区| 久草免费在线视频观看| 一个色综合网| 久久综合网hezyo| 欧美亚一区二区三区| 国产精品毛片av| 日韩女同互慰一区二区| 手机在线免费毛片| 日韩黄色三级在线观看| 欧美三级资源在线| 色免费在线视频| free欧美| 91福利国产精品| 成人3d动漫一区二区三区| 男人最爱成人网| 色综合网色综合| 国产亚洲综合视频| 伊伊综合在线| 色婷婷精品久久二区二区蜜臀av | 波多一区二区| 亚洲一区视频在线观看视频| 成人免费观看在线| 999精品网| 欧美日韩视频在线| 国产一级片黄色| 国产a亚洲精品| 欧美精品乱码久久久久久| 国产农村妇女精品久久| 中文字幕一区二区三区四区久久| 精品av综合导航| 成人影视免费观看| 区一区二视频| 欧美精品情趣视频| 日韩欧美亚洲一区二区三区| 欧美综合国产| 国产精品中文久久久久久久| 国产免费一区二区三区最新不卡 | 亚洲专区在线视频| 国模人体一区二区| 久久久久久黄色| www亚洲国产| 男女视频在线| 色婷婷久久久综合中文字幕| 中日韩av在线播放| 久久国产精品免费精品3p| 日韩乱码在线视频| www成人啪啪18软件| 欧美午夜不卡| 日本精品久久电影| 在线免费一级片| 国产成人av电影在线播放| 久久免费99精品久久久久久| 日本免费在线观看| 亚洲成人精品一区| 向日葵污视频在线观看| www.神马久久| 中文字幕日韩综合av| 久久久久无码国产精品| 手机精品视频在线观看| 97在线电影| 国产www.大片在线| 亚洲午夜免费电影| jizz欧美性11| 色老板在线视频一区二区| www.日韩.com| 五月天综合激情| 国产一区二区久久| 欧美日本国产精品| 男女视频在线| 91精品国产一区二区三区蜜臀| 性欧美丰满熟妇xxxx性仙踪林| 羞羞色午夜精品一区二区三区| 欧美亚洲国产日本| www.天堂在线| 中文字幕亚洲精品在线观看| 日韩中文字幕免费在线| 国产香蕉精品| 欧美美女18p| 一本色道久久综合熟妇| 久久日韩精品一区二区五区| 国产精品va在线观看无码| 伊人亚洲精品| 中文字幕在线视频日韩| 国产午夜精品久久久久| 国产成人av影院| 女同性恋一区二区| 国产亚洲欧美日韩精品一区二区三区 | 日本在线视频1区| 一二三区精品视频| 国内av一区二区| 日韩免费在线| 欧洲日本亚洲国产区| 色噜噜在线播放| 亚洲国产日韩在线一区模特| 久久黄色一级视频| 亚洲情侣在线| 成人av电影天堂| 欧美中文在线| 欧美网站在线观看| 国产 中文 字幕 日韩 在线| 亚洲三级毛片| 国产一区二区久久久| 538视频在线| 亚洲国产精品电影在线观看| 久久精品久久精品久久| 国产成人精品三级| 99国产精品白浆在线观看免费| 日韩色性视频| 色婷婷av一区二区三区久久| 日韩黄色片网站| 中文字幕不卡一区| 狠狠干狠狠操视频| 欧美在线二区| 国产精华一区| 午夜激情电影在线播放| 亚洲欧美日韩直播| 日韩xxx视频| 国产精品视频观看| 亚洲天堂av一区二区三区| 你懂的成人av| 国产精品日韩二区| 超碰91在线观看| 亚洲视频在线看| 中文字幕欧美人妻精品一区蜜臀 | 国产视频欧美视频| 黄色片视频免费| 国产精品亲子伦对白| 伊人免费视频二| 激情欧美亚洲| 欧洲亚洲一区二区三区四区五区| 国产一区二区精品调教| 精品国产一区二区三区久久久狼| a级片免费视频| 午夜精品在线看| аⅴ天堂中文在线网| 国产一区在线观看视频| 免费超爽大片黄| 国产一区二区区别| 亚洲www视频| 免费高潮视频95在线观看网站| 亚洲天堂av高清| 国产特黄一级片| 午夜久久久久久久久| 女人又爽又黄免费女仆| 激情欧美日韩一区二区| 男女日批视频在线观看| 精品视频日韩| 国产精品区二区三区日本| 日韩一区二区三区免费| 欧美美女18p| 国产免费av在线| 精品国产一区二区三区不卡| 亚洲中文字幕无码爆乳av| 一区二区在线观看免费| 久久日免费视频| 成人高清av在线| 国产精品v日韩精品v在线观看| 欧美视频亚洲视频| 日韩中文字幕一区二区| 超碰97成人| 国产日韩欧美在线播放| 亚洲人成午夜免电影费观看| 不卡av电影院| 国产高清视频免费最新在线| 亚洲电影在线观看| 国产精品伦一区二区三区| 欧美日韩国产麻豆| 欧美亚洲日本在线| 国产清纯在线一区二区www| 亚洲少妇中文字幕| 欧美aa在线视频| 91专区在线观看| 欧美日韩亚洲一区| 亚洲乱码一区二区三区三上悠亚| 婷婷综合成人| 都市激情久久久久久久久久久| 精品三级在线| 日本一区二区在线播放| 成年女人在线看片| 久久久久久综合网天天| www久久日com| 色婷婷综合久久久久| 免费在线超碰| 亚洲精品美女久久久久| 亚洲伦理在线观看| 欧美一区二区在线看| 在线观看中文字幕网站| 91精品福利在线| 久久久久久久久黄色| 婷婷丁香久久五月婷婷| 国产成人无码精品久在线观看| 一区二区三区四区国产精品| 国产免费一区二区三区四区| 国产精品欧美一级免费| 天堂资源在线视频| 国产欧美日韩不卡| 亚洲色图第四色| 国产欧美日韩在线看| 免费看的黄色网| 国产免费久久精品| 91精品久久久久久久久久久久| 国产亚洲一区二区三区四区 | 免费av网站在线播放| 日韩精品最新网址| 精品人妻少妇嫩草av无码专区| 欧美一区二区三区在线观看视频 | 成人做爰视频www| 国产精品99久久久久久久久| 国产超碰精品| 国产精品一二区| 亚洲成人1区| 亚洲va男人天堂| 福利欧美精品在线| 精品国产一区二区三区免费 | www国产免费| 欧美精品一级| 成人性免费视频| 国产情侣一区| 日韩中文字幕免费在线| 麻豆成人久久精品二区三区小说| 色一情一区二区三区| 国产真实乱子伦精品视频| 免费人成视频在线播放| 高清免费成人av| 黄色国产在线观看| 国产视频一区二区三区在线观看| 免费视频91蜜桃| 专区另类欧美日韩| 国产在线一区视频| 色噜噜夜夜夜综合网| 一级特黄aa大片| 欧美sm美女调教| 欧美日韩影视| 日韩中文在线中文网三级| 亚洲精品白浆| 97超级碰在线看视频免费在线看| 亚洲电影有码| 99久久精品免费看国产四区| 伊人久久大香线蕉av不卡| 亚洲一区二区在线观| 国内在线观看一区二区三区| 99爱视频在线| 国产中文一区二区三区| 特大黑人巨人吊xxxx| 亚洲欧洲日韩一区二区三区| 国产一级一级片| 色噜噜狠狠成人网p站| 99精品在线看| 亚洲欧美中文字幕在线一区| a级影片在线| 日本精品一区二区三区在线播放视频 | 在线免费看黄| 久久久免费在线观看| 黄色欧美视频| 精品视频一区二区三区四区| 久久国产小视频| 欧洲黄色一级视频| 国产久卡久卡久卡久卡视频精品| a级大片在线观看| 一卡二卡欧美日韩| 国产美女www| 亚洲国产毛片完整版| 国产日产一区二区| 国产精品国产三级国产aⅴ浪潮| 91精品短视频| 先锋影音亚洲资源| 在线亚洲激情| 91人妻一区二区三区| 国产精品婷婷午夜在线观看| 日韩毛片在线播放| 日韩一级片在线观看| 自拍视频在线免费观看| 日本精品一区二区三区在线| 成人免费在线电影网| 欧美日韩一级在线| 男人操女人的视频在线观看欧美 | 中文字幕一区二区视频| 亚洲黄色免费观看| 亚洲精品一线二线三线| www久久日com| 亚洲精品欧美一区二区三区| 日韩国产欧美一区二区| 白嫩少妇丰满一区二区| 99久久国产综合精品色伊| 久久99久久98精品免观看软件| 欧美久久一二三四区| av播放在线观看| 国产精品日日做人人爱| 久久av影视| 欧美日韩国产高清一区二区| 国产又粗又猛又黄又爽| 亚洲一级黄色av| 亚洲伦理影院| 日本最新一区二区三区视频观看| 亚洲在线黄色| 人妻在线日韩免费视频| 午夜精品福利一区二区三区蜜桃| 亚洲欧美强伦一区二区| 欧美激情久久久久久| 视频二区欧美| 免费不卡av在线| 成人av网站免费观看| 日韩乱码一区二区| 日韩精品视频免费| 欧美性suv| 亚洲制服中文| 国产主播一区二区| 免费在线观看一级片| 欧美成人aa大片| 福利小视频在线| 久久福利电影| 日韩高清国产一区在线| 九九九视频在线观看| 欧美人牲a欧美精品| av激情在线| 国产精品区一区| 久久久久中文| 日韩av片在线免费观看| 欧美二区三区91| 黑人另类精品××××性爽| 精品久久久久久中文字幕动漫| 国产精品久久777777毛茸茸| 六月婷婷七月丁香| 欧美三区在线视频| 91一区二区三区在线| 国产精品一区二区三区不卡 | 欧美极品在线视频| 琪琪久久久久日韩精品| 国产免费视频传媒| 亚洲欧洲国产专区| 精品人妻一区二区三区浪潮在线| 欧美激情一区二区三区在线视频观看| 美女呻吟一区| 蜜臀av免费观看| 亚洲一区二区av电影| 久久久久久久影视| 91精品视频播放| 日韩午夜精品| 欧美一级特黄高清视频| 欧美成人精品福利| 性欧美18一19sex性欧美| 偷拍盗摄高潮叫床对白清晰| 丁香啪啪综合成人亚洲小说 | 欧美日韩免费不卡视频一区二区三区| 欧美三级电影一区二区三区| 国产精品一区二区三区不卡| 日韩成人一区二区三区在线观看| 色婷婷在线视频观看| 日韩精品视频在线观看网址| 欧美一级在线| 欧美日韩性生活片| 中文字幕日韩一区| 欧美女子与性| av免费观看久久| 日韩—二三区免费观看av| 久久久美女视频| 永久免费毛片在线播放不卡 | 国产在线不卡一卡二卡三卡四卡| 亚州国产精品视频|