亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

VC中BASE64編碼和解碼使用詳解

2020-05-23 14:13:17
字體:
來源:轉載
供稿:網友

Base64是一種很常用的編碼方式,利用它可以將任何二進制的字符編碼到可打印的64個字符之中, 這樣,不管是圖片,中文文本等都可以編碼成只有ASCII的純文本。

BASE64可以用來將binary的字節序列數據編碼成ASCII字符序列構成的文本。完整的BASE64定義可見 RFC1421和 RFC2045。編碼后的數據比原始數據略長,為原來的4/3。在電子郵件中,根據RFC822規定,每76個字符,還需要加上一個回車換行。

轉換的時候,將三個byte的數據,先后放入一個24bit的緩沖區中,先來的byte占高位。數據不足3byte的話,于緩沖區中剩下的Bit用0補足。然后,每次取出6個bit,按照其值選擇ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/中的字符作為編碼后的輸出。不斷進行,直到全部輸入數據轉換完成。如果最后剩下兩個輸入數據,在編碼結果后加1個“=”;如果最后剩下一個輸入數據,編碼結果后加2個“=”;如果沒有剩下任何數據,就什么都不要加,這樣才可以保證資料還原的正確性。

BASE64_API.h 文件內容

 

 
  1. /* ---------------------------------------------------------- 
  2. 文件名稱:BASE64_API.h 
  3.  
  4. 作者:秦建輝 
  5.  
  6. MSN:splashcn@msn.com 
  7.  
  8. 當前版本:V1.1 
  9.  
  10. 歷史版本: 
  11. V1.1 2010年05月11日 
  12. 修正BASE64解碼的Bug。 
  13.  
  14. V1.0 2010年05月07日 
  15. 完成正式版本。 
  16.  
  17. 功能描述: 
  18. BASE64編碼和解碼 
  19.  
  20. 接口函數: 
  21. Base64_Encode 
  22. Base64_Decode 
  23.  
  24. 說明: 
  25. 1. 參考openssl-1.0.0。 
  26. 2. 改進接口,以使其適應TCHAR字符串。 
  27. 3. 修正EVP_DecodeBlock函數解碼時未去掉填充字節的缺陷。 
  28. ------------------------------------------------------------ */ 
  29. #pragma once 
  30. #include "stdafx.h" 
  31.  
  32. #include <windows.h> 
  33.  
  34. #ifdef __cplusplus 
  35. extern "C" { 
  36. #endif 
  37.  
  38. /* 
  39. 功能:將二進制數據轉換成BASE64編碼字符串 
  40. 參數說明: 
  41. inputBuffer:要編碼的二進制數據 
  42. inputCount:數據長度 
  43. outputBuffer:存儲轉換后的BASE64編碼字符串 
  44. 返回值: 
  45. -1:參數錯誤 
  46. >=0:有效編碼長度(字符數),不包括字符串結束符。 
  47. 備注: 
  48. 等效于openssl中EVP_EncodeBlock函數 
  49. */ 
  50. INT BASE64_Encode( const BYTE* inputBuffer, INT inputCount, TCHAR* outputBuffer ); 
  51.  
  52. /* 
  53. 功能:將BASE64編碼字符串轉換為二進制數據 
  54. 參數說明: 
  55. inputBuffer:BASE64編碼字符串 
  56. inputCount:編碼長度(字符數),應該為4的倍數。 
  57. outputBuffer:存儲轉換后的二進制數據 
  58. 返回值: 
  59. -1:參數錯誤 
  60. -2:數據錯誤 
  61. >=0:轉換后的字節數 
  62. 備注: 
  63. 等效于openssl中EVP_DecodeBlock函數 
  64. */ 
  65. INT BASE64_Decode( const TCHAR* inputBuffer, INT inputCount, BYTE* outputBuffer ); 
  66.  
  67. #ifdef __cplusplus 
  68. #endif 

BASE64_API.cpp 文件內容

 

 
  1. #pragma once 
  2.  
  3. #include "stdafx.h" 
  4.  
  5. #include "BASE64_API.h" 
  6.  
  7. static const CHAR* DATA_BIN2ASCII = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"
  8.  
  9. INT BASE64_Encode( const BYTE* inputBuffer, INT inputCount, TCHAR* outputBuffer ) 
  10. INT i; 
  11. BYTE b0, b1, b2; 
  12.  
  13. if( (inputBuffer == NULL) || (inputCount < 0) ) 
  14. return -1; // 參數錯誤 
  15.  
  16. if( outputBuffer != NULL ) 
  17. for( i = inputCount; i > 0; i -= 3 ) 
  18. if( i >= 3 ) 
  19. // 將3字節數據轉換成4個ASCII字符 
  20. b0 = *inputBuffer++; 
  21. b1 = *inputBuffer++; 
  22. b2 = *inputBuffer++; 
  23.  
  24. *outputBuffer++ = DATA_BIN2ASCII[b0 >> 2]; 
  25. *outputBuffer++ = DATA_BIN2ASCII[((b0 << 4) | (b1 >> 4)) & 0x3F]; 
  26. *outputBuffer++ = DATA_BIN2ASCII[((b1 << 2) | (b2 >> 6)) & 0x3F]; 
  27. *outputBuffer++ = DATA_BIN2ASCII[b2 & 0x3F]; 
  28. else 
  29. b0 = *inputBuffer++; 
  30. if( i == 2 )b1 = *inputBuffer++; else b1 = 0; 
  31.  
  32. *outputBuffer++ = DATA_BIN2ASCII[b0 >> 2]; 
  33. *outputBuffer++ = DATA_BIN2ASCII[((b0 << 4) | (b1 >> 4)) & 0x3F]; 
  34. *outputBuffer++ = (i == 1) ? TEXT('=') : DATA_BIN2ASCII[(b1 << 2) & 0x3F]; 
  35. *outputBuffer++ = TEXT('='); 
  36. // End for i 
  37.  
  38. *outputBuffer++ = TEXT('/0'); // 添加字符串結束標記 
  39.  
  40. return ((inputCount + 2) / 3) * 4; // 返回有效字符個數 
  41.  
  42. #define B64_EOLN 0xF0 // 換行/n 
  43. #define B64_CR 0xF1 // 回車/r 
  44. #define B64_EOF 0xF2 // 連字符- 
  45. #define B64_WS 0xE0 // 跳格或者空格(/t、space) 
  46. #define B64_ERROR 0xFF // 錯誤字符 
  47. #define B64_NOT_BASE64(a) (((a)|0x13) == 0xF3) 
  48.  
  49. static const BYTE DATA_ASCII2BIN[128] = { 
  50. 0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xE0,0xF0,0xFF,0xFF,0xF1,0xFF,0xFF, 
  51. 0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF, 
  52. 0xE0,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0x3E,0xFF,0xF2,0xFF,0x3F, 
  53. 0x34,0x35,0x36,0x37,0x38,0x39,0x3A,0x3B,0x3C,0x3D,0xFF,0xFF,0xFF,0x00,0xFF,0xFF, 
  54. 0xFF,0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09,0x0A,0x0B,0x0C,0x0D,0x0E, 
  55. 0x0F,0x10,0x11,0x12,0x13,0x14,0x15,0x16,0x17,0x18,0x19,0xFF,0xFF,0xFF,0xFF,0xFF, 
  56. 0xFF,0x1A,0x1B,0x1C,0x1D,0x1E,0x1F,0x20,0x21,0x22,0x23,0x24,0x25,0x26,0x27,0x28, 
  57. 0x29,0x2A,0x2B,0x2C,0x2D,0x2E,0x2F,0x30,0x31,0x32,0x33,0xFF,0xFF,0xFF,0xFF,0xFF 
  58. }; 
  59.  
  60. INT BASE64_Decode( const TCHAR* inputBuffer, INT inputCount, BYTE* outputBuffer ) 
  61. INT i, j; 
  62. BYTE b[4]; 
  63. TCHAR ch; 
  64.  
  65. if( (inputBuffer == NULL) || (inputCount < 0) ) 
  66. return -1; // 參數錯誤 
  67.  
  68. // 去除頭部空白字符 
  69. while( inputCount > 0 ) 
  70. ch = *inputBuffer; 
  71. if( (ch < 0) || (ch >= 0x80) ) 
  72. return -2; // 數據錯誤,不在ASCII字符編碼范圍內 
  73. else 
  74. if( DATA_ASCII2BIN[ch] == B64_WS ) 
  75. inputBuffer++; 
  76. inputCount--; 
  77. else 
  78. break
  79.  
  80. // 去除尾部的空白字符、回車換行字符、連字符 
  81. while( inputCount >= 4 ) 
  82. ch = inputBuffer[inputCount - 1]; 
  83. if( (ch < 0) || (ch >= 0x80) ) 
  84. return -2; // 數據錯誤,不在ASCII字符編碼范圍內 
  85. else 
  86. if( B64_NOT_BASE64(DATA_ASCII2BIN[ch]) ) 
  87. inputCount--; 
  88. else 
  89. break
  90.  
  91. // 字符串長度必須為4的倍數 
  92. if( (inputCount % 4) != 0 ) 
  93. return -2; // 數據錯誤 
  94.  
  95. if( outputBuffer != NULL ) 
  96. for( i = 0; i < inputCount; i += 4 ) 
  97. for( j = 0; j < 4; j++ ) 
  98. ch = *inputBuffer++; 
  99. if( (ch < 0) || (ch >= 0x80) ) 
  100. return -2; // 數據錯誤,不在ASCII字符編碼范圍內 
  101. else 
  102. if( ch == '=' ) // 發現BASE64編碼中的填充字符 
  103. break
  104. else 
  105. b[j] = DATA_ASCII2BIN[ch]; 
  106. if( b[j] & 0x80 ) 
  107. return -2; // 數據錯誤,無效的Base64編碼字符 
  108. }  
  109. // End for j 
  110.  
  111. if( j == 4 ) 
  112. *outputBuffer++ = (b[0] << 2) | (b[1] >> 4); 
  113. *outputBuffer++ = (b[1] << 4) | (b[2] >> 2 ); 
  114. *outputBuffer++ = (b[2] << 6) | b[3]; 
  115. else if( j == 3 ) 
  116. // 有1個填充字節 
  117. *outputBuffer++ = (b[0] << 2) | (b[1] >> 4); 
  118. *outputBuffer++ = (b[1] << 4) | (b[2] >> 2 ); 
  119.  
  120. return (i >> 2) * 3 + 2; 
  121. else if( j == 2 ) 
  122. // 有2個填充字節 
  123. *outputBuffer++ = (b[0] << 2) | (b[1] >> 4); 
  124.  
  125. return (i >> 2) * 3 + 1; 
  126. else 
  127. return -2; // 數據錯誤,無效的Base64編碼字符 
  128. }  
  129. // End for i 
  130.  
  131. return (inputCount >> 2) * 3; 

采用以上方法就可以將二進制數據轉換成可見字符進行傳遞就可以了.

那么如何使用呢?舉以下兩個例子

第一個:將一個圖片轉換成 txt 文本 并保存起來

 

 
  1. //選擇一個圖像文件,將它轉為 文本保存至 _T("D://2.txt" 
  2. void CTextPicDlg::OnBnClickedButton2() 
  3. // TODO: 在此添加控件通知處理程序代碼 
  4. CFileDialog file(TRUE,".jpg",""); 
  5. if (file.DoModal() == IDOK) 
  6. CFile data(file.GetPathName(), CFile::modeReadWrite); 
  7. int len = data.GetLength(); 
  8. BYTE *dv; 
  9. dv = (BYTE *)malloc(len*sizeof(BYTE)); 
  10. data.Read(dv, len); 
  11. data.Close(); 
  12. int slen = (len / 3) * 4; 
  13. slen += 10; 
  14. TCHAR * tc; 
  15. tc = (TCHAR *)malloc(slen); 
  16. slen = BASE64_Encode(dv, len, tc); 
  17. CFile save(_T("D://2.txt"), CFile::modeCreate | CFile::modeWrite); 
  18. save.Write(tc, slen); 
  19. save.Close(); 
  20. free(tc); 
  21. free(dv); 

第二個例子,將一個文本文件還原為一個圖像

 

 
  1. void CTextPicDlg::OnBnClickedButton3() 
  2. // TODO: 在此添加控件通知處理程序代碼 
  3. CFileDialog file(TRUE, ".txt"""); 
  4. if (file.DoModal() == IDOK) 
  5. CFile data(file.GetPathName(), CFile::modeReadWrite); 
  6. int len = data.GetLength(); 
  7. TCHAR *dv; 
  8. dv = (TCHAR *)malloc(len*sizeof(TCHAR)); 
  9. data.Read(dv, len); 
  10. data.Close(); 
  11. int slen = (len / 4) * 3; 
  12. slen += 10; 
  13. BYTE * tc; 
  14. tc = (BYTE *)malloc(slen); 
  15. BASE64_Decode(dv, len, tc); 
  16. //直接在內存里面構建CIMAGE,需要使用IStream接口,如何使用 
  17. //構建內存環境  
  18. HGLOBAL hGlobal = GlobalAlloc(GMEM_MOVEABLE, slen); 
  19. void * pData = GlobalLock(hGlobal); 
  20. memcpy(pData, tc, slen); // 拷貝位圖數據進去 
  21. GlobalUnlock(hGlobal); 
  22. // 創建IStream 
  23. IStream * pStream = NULL; 
  24. if (CreateStreamOnHGlobal(hGlobal, TRUE, &pStream) != S_OK) 
  25. return ; 
  26. // 使用CImage加載位圖內存 
  27. CImage img; 
  28. if (SUCCEEDED(img.Load(pStream)) ) 
  29. CClientDC dc(this); 
  30. //使用內在中構造的圖像 直接在對話框上繪圖 
  31. img.Draw(dc.m_hDC, 0, 0, 500, 300); 
  32. //釋放內存 
  33. pStream->Release(); 
  34. GlobalFree(hGlobal); 
  35. //如果要保存圖像文件的話,那就使用下面的代碼 
  36. //CFileDialog savefile(FALSE, ".jpg", ""); 
  37. //if (savefile.DoModal()==IDOK) 
  38. //{ 
  39. // CFile save(savefile.GetPathName(), CFile::modeCreate | CFile::modeWrite); 
  40. // save.Write(tc, slen); 
  41. // save.Close(); 
  42. //} 
  43. free(tc); 
  44. free(dv); 

至此,利用Base64轉碼的方式,來顯示保存顯示圖片的方法,就算是成功了!

我們再來看一個base64編碼解碼的例子

首先是編碼

 

 
  1. const BYTE Base64ValTab[65] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"
  2.  
  3. #define AVal(x) Base64ValTab[x] 
  4. int CSeeBase64Dlg::EncodeBase64(char * pInput, char * pOutput) 
  5. int i = 0; 
  6. int loop = 0; 
  7. int remain = 0; 
  8. int iDstLen = 0; 
  9. int iSrcLen = (int)strlen(pInput); 
  10.  
  11. loop = iSrcLen/3; 
  12. remain = iSrcLen%3; 
  13.  
  14. // also can encode native char one by one as decode method 
  15. // but because all of char in native string is to be encoded so encode 3-chars one time is easier. 
  16.  
  17. for (i=0; i < loop; i++) 
  18. BYTE a1 = (pInput[i*3] >> 2); 
  19. BYTE a2 = ( ((pInput[i*3] & 0x03) << 4) | (pInput[i*3+1] >> 4) ); 
  20. BYTE a3 = ( ((pInput[i*3+1] & 0x0F) << 2) | ((pInput[i*3+2] & 0xC0) >> 6) ); 
  21. BYTE a4 = (pInput[i*3+2] & 0x3F); 
  22.  
  23. pOutput[i*4] = AVal(a1); 
  24. pOutput[i*4+1] = AVal(a2); 
  25. pOutput[i*4+2] = AVal(a3); 
  26. pOutput[i*4+3] = AVal(a4); 
  27.  
  28. iDstLen = i*4; 
  29.  
  30. if (remain == 1) 
  31. // should pad two equal sign 
  32. i = iSrcLen-1; 
  33. BYTE a1 = (pInput[i] >> 2); 
  34. BYTE a2 = ((pInput[i] & 0x03) << 4); 
  35.  
  36. pOutput[iDstLen++] = AVal(a1); 
  37. pOutput[iDstLen++] = AVal(a2); 
  38. pOutput[iDstLen++] = '='
  39. pOutput[iDstLen++] = '='
  40. pOutput[iDstLen] = 0x00; 
  41. else if (remain == 2) 
  42. // should pad one equal sign 
  43. i = iSrcLen-2; 
  44. BYTE a1 = (pInput[i] >> 2); 
  45. BYTE a2 = ( ((pInput[i] & 0x03) << 4) | (pInput[i+1] >> 4)); 
  46. BYTE a3 = ( (pInput[i+1] & 0x0F) << 2); 
  47.  
  48. pOutput[iDstLen++] = AVal(a1); 
  49. pOutput[iDstLen++] = AVal(a2); 
  50. pOutput[iDstLen++] = AVal(a3); 
  51. pOutput[iDstLen++] = '='
  52. pOutput[iDstLen] = 0x00; 
  53. else 
  54. // just division by 3 
  55. pOutput[iDstLen] = 0x00; 
  56.  
  57. return iDstLen; 

下面是解碼

 

 
  1. const BYTE Base64IdxTab[128] = 
  2. 255,255,255,255, 255,255,255,255, 255,255,255,255, 255,255,255,255, 
  3. 255,255,255,255, 255,255,255,255, 255,255,255,255, 255,255,255,255, 
  4. 255,255,255,255, 255,255,255,255, 255,255,255,62, 255,255,255,63, 
  5. 52,53,54,55, 56,57,58,59, 60,61,255,255, 255,255,255,255, 
  6. 255,0,1,2, 3,4,5,6, 7,8,9,10, 11,12,13,14, 
  7. 15,16,17,18, 19,20,21,22, 23,24,25,255, 255,255,255,255, 
  8. 255,26,27,28, 29,30,31,32, 33,34,35,36, 37,38,39,40, 
  9. 41,42,43,44, 45,46,47,48, 49,50,51,255, 255,255,255,255 
  10. }; 
  11.  
  12. #define BVal(x) Base64IdxTab[x] 
  13.  
  14. int CSeeBase64Dlg::DecodeBase64(char * pInput, char * pOutput) 
  15. int i = 0; 
  16. int iCnt = 0; 
  17. int iSrcLen = (int)strlen(pInput); 
  18.  
  19. char * p = pOutput; 
  20.  
  21. for (i=0; i < iSrcLen; i++) 
  22. if (pInput[i] > 127) continue
  23. if (pInput[i] == '='return p-pOutput+1; 
  24.  
  25. BYTE a = BVal(pInput[i]); 
  26. if (a == 255) continue
  27.  
  28. switch (iCnt) 
  29. case 0: 
  30. *p = a << 2; 
  31. iCnt++; 
  32. break
  33.  
  34. case 1: 
  35. *p++ |= a >> 4; 
  36. *p = a << 4; 
  37. iCnt++; 
  38. break
  39.  
  40. case 2: 
  41. *p++ |= a >> 2; 
  42. *p = a << 6; 
  43. iCnt++; 
  44. break
  45. case 3: 
  46. *p++ |= a; 
  47. iCnt = 0; 
  48. break
  49. }  
  50.  
  51. *p = 0x00; 
  52. return p-pOutput; 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩精品中文字幕| 日韩精品亚洲元码| 亚洲精品www久久久| 国产亚洲成av人片在线观看桃| 久久久久久久亚洲精品| 亚洲人成在线观| 成人女保姆的销魂服务| 日韩精品极品毛片系列视频| 九九热精品在线| 亚洲美腿欧美激情另类| 欧美一级成年大片在线观看| 国产精品主播视频| www.日韩系列| 国产色婷婷国产综合在线理论片a| 亚洲天堂第二页| 欧美制服第一页| 久久久精品中文字幕| 91牛牛免费视频| 国产精品欧美日韩| 日韩欧美在线观看| 亚洲福利在线看| 久久午夜a级毛片| 午夜精品久久久久久久99热| 亚洲精品在线观看www| 久久天天躁狠狠躁老女人| 国产日本欧美一区二区三区| 欧美极度另类性三渗透| 久久久久久久97| 国产精品丝袜视频| 高清亚洲成在人网站天堂| 色www亚洲国产张柏芝| 欧美一级黄色网| 亚洲人成电影在线| 国产精品美女主播在线观看纯欲| 亚洲第五色综合网| 国产一区二区三区直播精品电影| 亚洲大尺度美女在线| 狠狠躁夜夜躁人人爽超碰91| 精品亚洲男同gayvideo网站| 欧美成人免费视频| 久久久久久久久久久久av| 欧美成人一区二区三区电影| 日韩成人在线视频观看| 色哟哟亚洲精品一区二区| 色婷婷av一区二区三区在线观看| 最近中文字幕日韩精品| 日日摸夜夜添一区| 国产一区二区三区四区福利| 国产成人亚洲综合91精品| 国产中文字幕91| 亚洲欧美日韩国产成人| 91av在线播放视频| 欧美黄色片免费观看| 欧美另类交人妖| 动漫精品一区二区| 97av在线播放| 久久精品国产亚洲一区二区| 久久99国产精品自在自在app| 亚洲精品99久久久久中文字幕| 欧美高清不卡在线| 色黄久久久久久| 亚洲一区制服诱惑| 亚洲国产私拍精品国模在线观看| 国产亚洲精品激情久久| 亚洲天堂色网站| 欧美激情精品久久久久久变态| 国产精品成人观看视频国产奇米| 97精品国产91久久久久久| 欧美在线视频一二三| 国产午夜精品视频免费不卡69堂| 91国在线精品国内播放| 81精品国产乱码久久久久久| 欧美日产国产成人免费图片| 亚洲欧美日韩国产成人| 亚洲视频国产视频| 久久福利视频网| 亚洲精品电影网| 欧美一级片在线播放| 欧美日韩国产精品一区二区三区四区| 在线观看91久久久久久| 一区二区三区视频免费在线观看| 88国产精品欧美一区二区三区| 国产精品免费小视频| 国产v综合ⅴ日韩v欧美大片| 久久久久久国产三级电影| 一区二区三区美女xx视频| 91精品久久久久久久久久久| 中文字幕九色91在线| 另类少妇人与禽zozz0性伦| 国产午夜精品美女视频明星a级| 综合欧美国产视频二区| 91亚洲精品一区二区| www.国产精品一二区| 国产精品99蜜臀久久不卡二区| 亚洲免费视频观看| 国产精品日韩精品| 91国产中文字幕| 成人免费网站在线观看| 亚洲va久久久噜噜噜| 国产91精品在线播放| 日本精品视频在线播放| 日韩av免费网站| 九九视频直播综合网| 久久久视频精品| 亚洲最大成人在线| 国产欧美 在线欧美| 欧美精品福利视频| 亚洲精品免费在线视频| 国产成人精品久久亚洲高清不卡| 欧美激情亚洲综合一区| 亚洲国产精品久久久久秋霞蜜臀| 久久精视频免费在线久久完整在线看| 91精品久久久久久久久久久| 黑人巨大精品欧美一区二区一视频| 91亚洲va在线va天堂va国| 日韩在线视频观看| 久久久久久久色| 欧美成人激情视频免费观看| 欧美日韩国产精品| 久操成人在线视频| 日韩www在线| 欧美日韩国产中文精品字幕自在自线| 91在线观看免费| 欧美日韩在线观看视频小说| 91地址最新发布| 久久精品久久久久久国产 免费| 国产精品第一页在线| 亚洲国语精品自产拍在线观看| 亚洲aa在线观看| 亚洲丝袜一区在线| 日韩视频在线一区| 91久久精品国产91久久性色| 91在线观看免费高清完整版在线观看| 日韩av中文在线| 精品国产一区二区三区久久狼黑人| 日韩小视频网址| 亚洲欧美国产精品久久久久久久| 亚洲午夜精品久久久久久久久久久久| 国色天香2019中文字幕在线观看| 欧美成人午夜免费视在线看片| 亚洲午夜精品久久久久久久久久久久| 久久久久久久久久久成人| 国产欧美一区二区三区在线看| 中文字幕日韩精品有码视频| 国产a级全部精品| 亚洲日本欧美中文幕| 日韩欧美成人区| 国产一区私人高清影院| 92看片淫黄大片欧美看国产片| 久久av在线看| 亚洲影院色无极综合| 日韩中文在线中文网在线观看| 欧洲精品毛片网站| 九九精品视频在线观看| 亚洲美女av在线播放| 亚洲三级 欧美三级| 亚洲欧美日韩国产中文| 国产精品美女在线观看| 欧亚精品中文字幕| 欧美黄色片在线观看| 久久久女人电视剧免费播放下载| 欧美性感美女h网站在线观看免费| 欧美精品999| 在线观看久久久久久|