亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? ecrypt-test.c

?? phelix加密算法源代碼,是一個(gè)開源的加密算法
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
/* ecrypt-test.c */

/* 
 * API conformance test and test vector generation (DRAFT)
 *
 * Based on the NESSIE test suite (http://www.cryptonessie.org/)
 */

/* ------------------------------------------------------------------------- */

#define QUOTE(str) QUOTE_HELPER(str)
#define QUOTE_HELPER(str) # str

#include "ecrypt-portable.h"
#include QUOTE(ECRYPT_API)

#if defined(ECRYPT_SSYN) || defined(ECRYPT_SSYN_AE)
#error self-synchronising stream ciphers are not supported yet
#endif

#if defined(ECRYPT_SYNC_AE) || defined(ECRYPT_SSYN_AE)
#define ECRYPT_AE
#endif

#include <stdio.h>
#include <string.h>

#define MAXKEYSIZEB ((ECRYPT_MAXKEYSIZE + 7) / 8)
#define MAXIVSIZEB ((ECRYPT_MAXIVSIZE + 7) / 8)
#define MAXMACSIZEB ((ECRYPT_MAXMACSIZE + 7) / 8)

/* ------------------------------------------------------------------------- */

int compare_blocks(const u8 *m1, const u8 *m2, int len_bits)
{
  int i;
  const int lenb = (len_bits + 7) >> 3;
  const int mask0 = (1 << (((len_bits - 1) & 7) + 1)) - 1;

  if ((m1[0] & mask0) != (m2[0] & mask0))
    return 1;

  for (i = 1; i < lenb; i++)
    if (m1[i] != m2[i])
      return 1;
  
  return 0;
}

void print_data(FILE *fd, const char *str, const u8 *val, int len)
{
  int i;

  static const char hex[] = "0123456789ABCDEF";

  fprintf(fd, "%28s = ", str);

  for (i = 0; i < len; i++)
    {
      if (i > 0 && (i & 0xF) == 0 && (len > 24))
        fprintf(fd, "\n%28s   ", "");

      putc(hex[(val[i] >> 4) & 0xF], fd);
      putc(hex[(val[i]     ) & 0xF], fd);
    }

  fprintf(fd, "\n");
}

void print_chunk(FILE *fd, const char *str, const u8 *val, int start, int len)
{
  char indexed[80];

  sprintf(indexed, "%s[%d..%d]", str, start, start + len - 1);
  print_data(fd, indexed, val + start, len);
}

void xor_digest(const u8 *stream, int size, u8 *out, int outsize)
{
  int i;
  memset(out, 0, outsize);
  for (i = 0; i < size; i++)
    out[i % outsize] ^= stream[i];
}

/* ------------------------------------------------------------------------- */

#define TEST_STREAM_SIZEB 0x200
#define TEST_STREAM_SIZEB_SET4 0x20000
#define TEST_CHUNK 64

#ifdef ECRYPT_AE

#define CTX ECRYPT_AE_ctx
#define IVSETUP ECRYPT_AE_ivsetup
#define ENCRYPT_BYTES ECRYPT_AE_encrypt_bytes
#define DECRYPT_BYTES ECRYPT_AE_decrypt_bytes
#define AUTHENTICATE_BYTES ECRYPT_AE_authenticate_bytes
#define ENCRYPT_BLOCKS ECRYPT_AE_encrypt_blocks
#define DECRYPT_BLOCKS ECRYPT_AE_decrypt_blocks
#define KEYSETUP ECRYPT_AE_keysetup
#define ENCRYPT_PACKET ECRYPT_AE_encrypt_packet
#define DECRYPT_PACKET ECRYPT_AE_decrypt_packet
#define FINALIZE ECRYPT_AE_finalize

#else

#define CTX ECRYPT_ctx
#define IVSETUP ECRYPT_ivsetup
#define ENCRYPT_BYTES ECRYPT_encrypt_bytes
#define DECRYPT_BYTES ECRYPT_decrypt_bytes
#define ENCRYPT_BLOCKS ECRYPT_encrypt_blocks
#define DECRYPT_BLOCKS ECRYPT_decrypt_blocks

#define KEYSETUP(ctx, key, keysize, ivsize, macsize)                         \
  ECRYPT_keysetup(ctx, key, keysize, ivsize)

#define ENCRYPT_PACKET(                                                      \
    ctx, iv, aad, aadlen, plaintext, ciphertext, msglen, mac)                \
  ECRYPT_encrypt_packet(ctx, iv, plaintext, ciphertext, msglen)

#define DECRYPT_PACKET(                                                      \
    ctx, iv, aad, aadlen, ciphertext, plaintext, msglen, mac)                \
  ECRYPT_decrypt_packet(ctx, iv, ciphertext, plaintext, msglen)

#define FINALIZE(ctx, checkmac)

#endif

typedef struct
{
  int keysize;
  int ivsize;
  int msglen;

  CTX ctx;

  u8 key[MAXKEYSIZEB];
  u8 iv[MAXIVSIZEB];

  u8 plaintext[TEST_STREAM_SIZEB_SET4];
  u8 ciphertext[TEST_STREAM_SIZEB_SET4];
  u8 checktext[TEST_STREAM_SIZEB_SET4];

#ifdef ECRYPT_AE
  int macsize;
  int aadlen;

  u8 aad[TEST_CHUNK];
  u8 mac[MAXMACSIZEB];
  u8 checkmac[MAXMACSIZEB];
#endif

  u8 xored[TEST_CHUNK];

  FILE *fd;

} test_struct;

int errors = 0;

void encrypt_and_check(test_struct* t, void (*print)(test_struct*, int))
{
  const int blocks = t->msglen / ECRYPT_BLOCKLENGTH;
  const int tail = blocks * ECRYPT_BLOCKLENGTH;
  const int bytes = t->msglen % ECRYPT_BLOCKLENGTH;

  memset(t->ciphertext, 0, sizeof(t->ciphertext));
#ifdef ECRYPT_AE
  memset(t->mac, 0, sizeof(t->mac));
#endif

  KEYSETUP(&t->ctx, t->key, t->keysize, t->ivsize, t->macsize);
  ENCRYPT_PACKET(&t->ctx, t->iv, 
    t->aad, t->aadlen, t->plaintext, t->ciphertext, t->msglen, t->mac);

  print(t, 0);

#ifdef ECRYPT_AE
  memset(t->checkmac, 0, sizeof(t->checkmac));
#endif
  memset(t->checktext, 0, sizeof(t->checktext));

  KEYSETUP(&t->ctx, t->key, t->keysize, t->ivsize, t->macsize);
  DECRYPT_PACKET(&t->ctx, t->iv, 
    t->aad, t->aadlen, t->ciphertext, t->checktext, t->msglen, t->checkmac);

  if (compare_blocks(t->plaintext, t->checktext, t->msglen * 8) != 0)
    {
      ++errors;
      fprintf(t->fd, 
	      "*** ERROR: encrypt_packet <-> decrypt_packet:\n"
	      "*** decrypted text differs from plaintext:\n");
      print(t, 1);
    }
#ifdef ECRYPT_AE
  else if (compare_blocks(t->mac, t->checkmac, t->macsize) != 0)
    {
      ++errors;
      fprintf(t->fd, 
	      "*** ERROR: encrypt_packet <-> decrypt_packet:\n"
	      "*** decryption MAC differs from encryption MAC:\n");
      print_data(t->fd, "MAC", t->checkmac, (t->macsize + 7) / 8);
    }

  memset(t->checkmac, 0, sizeof(t->checkmac));
#endif
  memset(t->checktext, 0, sizeof(t->checktext));

  IVSETUP(&t->ctx, t->iv);

#ifdef ECRYPT_SUPPORTS_AAD
  AUTHENTICATE_BYTES(&t->ctx, t->aad, t->aadlen);
#endif

  ENCRYPT_BYTES(&t->ctx, t->plaintext, t->checktext, t->msglen);
  FINALIZE(&t->ctx, t->checkmac);

  if (compare_blocks(t->ciphertext, t->checktext, t->msglen * 8) != 0)
    {
      ++errors;
      fprintf(t->fd, 
	      "*** ERROR: encrypt_packet <-> encrypt_bytes:\n"
	      "*** encrypt_bytes generates different ciphertext:\n");
      print(t, 2);
    }
#ifdef ECRYPT_AE
  else if (compare_blocks(t->mac, t->checkmac, t->macsize) != 0)
    {
      ++errors;
      fprintf(t->fd, 
	      "*** ERROR: encrypt_packet <-> encrypt_bytes:\n"
	      "*** encrypt_bytes generates different MAC:\n");
      print_data(t->fd, "MAC", t->checkmac, (t->macsize + 7) / 8);
    }

  memset(t->checkmac, 0, sizeof(t->checkmac));
#endif
  memset(t->checktext, 0, sizeof(t->checktext));

  IVSETUP(&t->ctx, t->iv);

#ifdef ECRYPT_SUPPORTS_AAD
  AUTHENTICATE_BYTES(&t->ctx, t->aad, t->aadlen);
#endif

  DECRYPT_BYTES(&t->ctx, t->ciphertext, t->checktext, t->msglen);
  FINALIZE(&t->ctx, t->checkmac);

  if (compare_blocks(t->plaintext, t->checktext, t->msglen * 8) != 0)
    {
      ++errors;
      fprintf(t->fd, 
	      "*** ERROR: encrypt_packet <-> decrypt_bytes:\n"
	      "*** decrypt_bytes generates different plaintext:\n");
      print(t, 2);
    }
#ifdef ECRYPT_AE
  else if (compare_blocks(t->mac, t->checkmac, t->macsize) != 0)
    {
      ++errors;
      fprintf(t->fd, 
	      "*** ERROR: encrypt_packet <-> decrypt_bytes:\n"
	      "*** decrypt_bytes generates different MAC:\n");
      print_data(t->fd, "MAC", t->checkmac, (t->macsize + 7) / 8);
    }

  memset(t->checkmac, 0, sizeof(t->checkmac));
#endif
  memset(t->checktext, 0, sizeof(t->checktext));

  IVSETUP(&t->ctx, t->iv);

#ifdef ECRYPT_SUPPORTS_AAD
  AUTHENTICATE_BYTES(&t->ctx, t->aad, t->aadlen);
#endif

  ENCRYPT_BLOCKS(&t->ctx, t->plaintext, t->checktext, blocks);
  ENCRYPT_BYTES(&t->ctx, t->plaintext + tail, t->checktext + tail, bytes);
  FINALIZE(&t->ctx, t->checkmac);

  if (compare_blocks(t->ciphertext, t->checktext, t->msglen * 8) != 0)
    {
      ++errors;
      fprintf(t->fd, 
	      "*** ERROR: encrypt_packet <-> encrypt_blocks/bytes:\n"
	      "*** encrypt_blocks/bytes generates different ciphertext:\n");
      print(t, 2);
    }
#ifdef ECRYPT_AE
  else if (compare_blocks(t->mac, t->checkmac, t->macsize) != 0)
    {
      ++errors;
      fprintf(t->fd, 
	      "*** ERROR: encrypt_packet <-> encrypt_blocks/bytes:\n"
	      "*** encrypt_blocks/bytes generates different MAC:\n");
      print_data(t->fd, "MAC", t->checkmac, (t->macsize + 7) / 8);
    }

  memset(t->checkmac, 0, sizeof(t->checkmac));
#endif
  memset(t->checktext, 0, sizeof(t->checktext));

  IVSETUP(&t->ctx, t->iv);

#ifdef ECRYPT_SUPPORTS_AAD
  AUTHENTICATE_BYTES(&t->ctx, t->aad, t->aadlen);
#endif

  DECRYPT_BLOCKS(&t->ctx, t->ciphertext, t->checktext, blocks);
  DECRYPT_BYTES(&t->ctx, t->ciphertext + tail, t->checktext + tail, bytes);
  FINALIZE(&t->ctx, t->checkmac);

  if (compare_blocks(t->plaintext, t->checktext, t->msglen * 8) != 0)
    {
      ++errors;
      fprintf(t->fd, 
	      "*** ERROR: encrypt_packet <-> decrypt_blocks/bytes:\n"
	      "*** decrypt_blocks/bytes generates different plaintext:\n");
      print(t, 2);
    }
#ifdef ECRYPT_AE
  else if (compare_blocks(t->mac, t->checkmac, t->macsize) != 0)
    {
      ++errors;
      fprintf(t->fd, 
	      "*** ERROR: encrypt_packet <-> decrypt_blocks/bytes:\n"
	      "*** decrypt_blocks/bytes generates different MAC:\n");
      print_data(t->fd, "MAC", t->checkmac, (t->macsize + 7) / 8);
    }
#endif

  fprintf(t->fd, "\n");
}

void print_stream(test_struct* t, int type)
{
  const int chunk = TEST_CHUNK;

  switch (type)
    {
    case 0:
      print_data(t->fd, "key", t->key, (t->keysize + 7) / 8); 
      print_data(t->fd, "IV", t->iv, (t->ivsize + 7) / 8);    
      
      print_chunk(t->fd, "stream", t->ciphertext, 0, chunk);
      print_chunk(t->fd, "stream", t->ciphertext, t->msglen/2-chunk, chunk);
      print_chunk(t->fd, "stream", t->ciphertext, t->msglen/2, chunk);         
      print_chunk(t->fd, "stream", t->ciphertext, t->msglen-chunk, chunk);
      
      xor_digest(t->ciphertext, t->msglen, t->xored, chunk);
      print_data(t->fd, "xor-digest", t->xored, chunk);  
      
#ifdef ECRYPT_AE
      print_data(t->fd, "MAC", t->mac, (t->macsize + 7) / 8); 
#endif
      break;
    case 1:
      print_chunk(t->fd, "decryption", t->checktext, 0, chunk);
      print_chunk(t->fd, "decryption", t->checktext, t->msglen/2-chunk, chunk);
      print_chunk(t->fd, "decryption", t->checktext, t->msglen/2, chunk);
      print_chunk(t->fd, "decryption", t->checktext, t->msglen-chunk, chunk);
      
      xor_digest(t->checktext, t->msglen, t->xored, chunk);                    
      print_data(t->fd, "xor-digest", t->xored, chunk);  

#ifdef ECRYPT_AE
      print_data(t->fd, "MAC", t->checkmac, (t->macsize + 7) / 8); 
#endif
      break;
    case 2:
      print_chunk(t->fd, "stream", t->checktext, 0, chunk);
      print_chunk(t->fd, "stream", t->checktext, t->msglen/2-chunk, chunk);
      print_chunk(t->fd, "stream", t->checktext, t->msglen/2, chunk);         
      print_chunk(t->fd, "stream", t->checktext, t->msglen-chunk, chunk);
      
      xor_digest(t->checktext, t->msglen, t->xored, chunk);                    
      print_data(t->fd, "xor-digest", t->xored, chunk); 
 
#ifdef ECRYPT_AE   
      print_data(t->fd, "MAC", t->checkmac, (t->macsize + 7) / 8); 
#endif
      break;
    }
}

void print_pair(test_struct* t, int type)
{
  switch (type)
    {
    case 0:
      print_data(t->fd, "key", t->key, (t->keysize + 7) / 8); 
      print_data(t->fd, "IV", t->iv, (t->ivsize + 7) / 8);

#ifdef ECRYPT_SUPPORTS_AAD
      if (t->aadlen)
	print_data(t->fd, "AAD", t->aad, t->aadlen);
#endif
      print_data(t->fd, "plaintext", t->plaintext, t->msglen);
      print_data(t->fd, "ciphertext", t->ciphertext, t->msglen); 
#ifdef ECRYPT_AE
      print_data(t->fd, "MAC", t->mac, (t->macsize + 7) / 8);      
#endif
      break;
    case 1:
      print_data(t->fd, "decryption", t->checktext, t->msglen); 
#ifdef ECRYPT_AE
      print_data(t->fd, "MAC", t->checkmac, (t->macsize + 7) / 8); 
#endif
      break;
    case 2:
      print_data(t->fd, "ciphertext", t->checktext, t->msglen);
#ifdef ECRYPT_AE 
      print_data(t->fd, "MAC", t->checkmac, (t->macsize + 7) / 8); 
#endif
      break;
    }
}

void test_vectors(FILE *fd, int keysize, int ivsize, int macsize)
{

#define STREAM_VECTOR(set, vector)                                           \
  do {                                                                       \
    fprintf(fd, "Set %d, vector#%3d:\n", set, vector);                       \
    encrypt_and_check(&t, print_stream);                                     \
  } while (0)

#define MAC_VECTOR(set, vector)                                              \
  do {                                                                       \
    fprintf(fd, "Set %d, vector#%3d:\n", set, vector);                       \
    encrypt_and_check(&t, print_pair);                                       \
  } while (0)

#define AAD_VECTOR(set, vector)                                              \
  do {                                                                       \
    fprintf(fd, "Set %d, vector#%3d:\n", set, vector);                       \
    encrypt_and_check(&t, print_pair);                                       \
  } while (0)

  test_struct t;
  int i, v;

  fprintf(fd, 
	  "****************************************"
	  "****************************************\n");
  fprintf(fd, 
	  "*                          ECRYPT Stream"
	  " Cipher Project                        *\n");
  fprintf(fd, 
	  "****************************************"
	  "****************************************\n");
  fprintf(fd, "\n");
  fprintf(fd, "Primitive Name: %s\n", ECRYPT_NAME);
  fprintf(fd, "================%.*s\n", (int)strlen(ECRYPT_NAME),
	  "==========================================");
  fprintf(fd, "Key size: %d bits\n", keysize);
  fprintf(fd, "IV size: %d bits\n", ivsize);
#ifdef ECRYPT_AE
  fprintf(fd, "MAC size: %d bits\n", macsize);
#endif
  fprintf(fd, "\n");
  fprintf(fd, "Preferred block length: %d bytes\n", ECRYPT_BLOCKLENGTH);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国内精品免费在线观看| 在线免费观看日本一区| 一区二区三区四区国产精品| 精品国产一区久久| 欧美探花视频资源| www.欧美.com| 国产一区二区三区电影在线观看 | 91精品啪在线观看国产60岁| youjizz久久| 国内精品在线播放| 亚洲成人精品影院| 亚洲三级电影全部在线观看高清| 精品国产乱码91久久久久久网站| 欧美日韩一区不卡| 99re这里都是精品| 成人妖精视频yjsp地址| 国产在线观看免费一区| 免费人成精品欧美精品| 亚洲综合区在线| 亚洲视频一区二区免费在线观看 | 玉米视频成人免费看| 国产欧美视频一区二区| 欧美电影免费观看完整版| 欧美午夜片在线观看| 日本高清无吗v一区| 91在线播放网址| 99久久综合色| 不卡的av电影在线观看| 成人黄色国产精品网站大全在线免费观看 | 日韩精品中文字幕一区| 91精品一区二区三区久久久久久 | 亚洲成人精品影院| 亚洲国产日产av| 亚洲一二三区在线观看| 一区二区三区四区国产精品| 亚洲另类在线一区| 亚洲综合久久av| 亚洲国产精品久久艾草纯爱| 亚洲夂夂婷婷色拍ww47| 亚洲不卡av一区二区三区| 亚洲第一精品在线| 日韩电影在线免费观看| 麻豆精品视频在线观看免费| 九色综合狠狠综合久久| 国产自产v一区二区三区c| 国产精品小仙女| av成人免费在线| 色94色欧美sute亚洲13| 欧美日韩国产一级二级| 91精品国产综合久久福利软件| 欧美一区二区三区男人的天堂| 精品久久久网站| 国产欧美一区二区精品秋霞影院| 国产精品久久久久久户外露出| 亚洲美女偷拍久久| 亚洲国产精品久久人人爱| 日本午夜精品一区二区三区电影| 蜜臀a∨国产成人精品| 国产在线精品一区二区| 粉嫩欧美一区二区三区高清影视| 91在线视频免费观看| 欧美图片一区二区三区| 日韩欧美中文一区二区| 久久精品在线观看| 亚洲黄色录像片| 蜜臀av亚洲一区中文字幕| 国产成人免费视| 色先锋资源久久综合| 欧美一区三区四区| 日本一区二区三区在线观看| 又紧又大又爽精品一区二区| 免费视频最近日韩| 99久久er热在这里只有精品66| 欧美日韩中文字幕精品| 久久久久久99精品| 伊人婷婷欧美激情| 国产一区二区三区美女| 91精品福利视频| 精品国产一区二区三区不卡 | 99re成人精品视频| 91精品国产品国语在线不卡| 日本一区二区成人| 日韩精品免费专区| 菠萝蜜视频在线观看一区| 91精品国产91久久久久久一区二区| 国产日韩v精品一区二区| 亚洲成人资源网| 丰满少妇久久久久久久| 日韩小视频在线观看专区| 亚洲人妖av一区二区| 狠狠色丁香九九婷婷综合五月| 在线欧美日韩国产| 国产欧美精品日韩区二区麻豆天美| 爽爽淫人综合网网站| 97se亚洲国产综合自在线不卡| 精品国产伦理网| 亚洲成人免费看| 99r国产精品| 日本一区二区三级电影在线观看| 天天色 色综合| 色婷婷久久久久swag精品| 久久影视一区二区| 日韩电影免费在线观看网站| 色综合久久久网| 国产精品女上位| 国产精品一区在线观看乱码 | 欧美日韩在线观看一区二区| 国产精品久久久久久福利一牛影视| 精品一区二区三区日韩| 欧美手机在线视频| 亚洲欧美日韩久久| 99精品久久免费看蜜臀剧情介绍| 国产亚洲美州欧州综合国| 日本中文一区二区三区| 欧美性极品少妇| 亚洲另类色综合网站| 91毛片在线观看| 国产精品久久久久久妇女6080 | 亚洲成a人片在线不卡一二三区| 99久久精品一区| 中文子幕无线码一区tr | 欧美区一区二区三区| 亚洲曰韩产成在线| 欧美在线综合视频| 亚洲制服丝袜av| 欧美性高清videossexo| 亚洲国产精品综合小说图片区| 欧美在线小视频| 亚洲精品中文在线影院| 色老综合老女人久久久| 亚洲欧美国产高清| 91黄色激情网站| 一区二区三区不卡视频| 91福利小视频| 亚洲成人动漫精品| 欧美一区二区三区爱爱| 九九久久精品视频| 国产丝袜欧美中文另类| caoporen国产精品视频| 亚洲女同ⅹxx女同tv| 欧美亚洲综合色| 亚洲成人激情综合网| 欧美一卡二卡三卡| 国内精品视频一区二区三区八戒| 久久久一区二区| 成人精品鲁一区一区二区| 亚洲免费在线看| 欧美三日本三级三级在线播放| 日韩电影在线免费| xf在线a精品一区二区视频网站| 国内精品伊人久久久久影院对白| 日本一区二区三区四区在线视频| 91丨九色丨尤物| 一区二区成人在线观看| 777午夜精品视频在线播放| 蜜桃精品在线观看| 中文字幕精品在线不卡| 一本色道亚洲精品aⅴ| 日韩国产精品久久久| 久久精品一区四区| 在线观看网站黄不卡| 毛片av中文字幕一区二区| 国产精品网站导航| 欧美图区在线视频| 国内精品免费在线观看| 亚洲品质自拍视频| 日韩免费电影一区| 99精品国产一区二区三区不卡| 天天色综合成人网| 国产日韩欧美电影| 欧美日韩的一区二区| 国产精品资源在线看| 亚洲免费观看高清在线观看| 日韩欧美色综合网站| av在线综合网| 久久国产精品第一页| ●精品国产综合乱码久久久久| 欧美一区二区三区性视频| www.一区二区| 久久99热这里只有精品| 亚洲欧美视频在线观看| 精品国产乱码久久久久久闺蜜| 色哟哟精品一区| 国产一区二区三区免费在线观看| 亚洲一区在线播放| 中文久久乱码一区二区| 这里只有精品视频在线观看| 99国产精品视频免费观看| 精品一区二区三区影院在线午夜 | 久久久精品综合| 欧美久久久久中文字幕| 99久久久免费精品国产一区二区| 久久99国产精品麻豆| 亚洲成av人片在线观看无码| 国产精品久久久久久户外露出| 欧美成人三级电影在线| 欧美日本在线一区| 99久久777色| 成人综合日日夜夜| 国产曰批免费观看久久久|