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

記一次 .NET 某拍攝監(jiān)控軟件的卡死分析

安全 應(yīng)用安全
可能有些朋友有疑問,為什么 scvncctrl 后面的偏移值那么大,這是因?yàn)?scvncctrl 沒有提供公有和私有符號,所以無法對應(yīng)函數(shù)名,windbg 只能以 module 為參考點(diǎn)設(shè)置偏移,這對 dump 分析產(chǎn)生了很大的阻礙!

一、背景

1. 講故事

今天本來想寫一篇 非托管泄露 的生產(chǎn)事故分析,但想著昨天就上了一篇非托管文章,連著寫也沒什么意思,換個(gè)口味吧,剛好前些天有位朋友也找到我,說他們的拍攝監(jiān)控軟件卡死了,讓我?guī)兔Ψ治鱿聻槭裁磿ㄋ溃牭竭@種軟件,讓我不禁想起了前些天 在程序員桌子上安裝監(jiān)控 的新聞,參考如下:

圖片圖片

我在想我這不是尼瑪作惡嗎... ?????? 和朋友確認(rèn)了下還好不是干這個(gè)事的。

二、WinDbg 分析

1. 為什么會卡死

因?yàn)檫@種監(jiān)控軟件是窗體程序,所以它的卡死理應(yīng)看主線程的調(diào)用棧即可, 在windbg中有一個(gè) k 命令。

0:000:x86> kb 8
 # ChildEBP RetAddr      Args to Child              
00 00dbedc0 77835329     0fd54c08 00000000 0fd54c08 ntdll_777d0000!NtWaitForAlertByThreadId+0xc
01 00dbedc0 7783505c     00000000 00000000 0fd54c08 ntdll_777d0000!RtlpWaitOnAddressWithTimeout+0x64
02 00dbee60 77813fd8     0fd543f0 0fd54c04 0000000c ntdll_777d0000!RtlpWaitOnCriticalSection+0x1ac
03 00dbeea8 77813d99     00000000 00dbef04 09d72f87 ntdll_777d0000!RtlpEnterCriticalSectionContended+0x228
04 00dbeeb4 09d72f87     0fd54c04 09d38131 ee66de6e ntdll_777d0000!RtlEnterCriticalSection+0x49
WARNING: Stack unwind information not available. Following frames may be wrong.
05 00dbef04 09d38036     ee66de46 000001fd 00000111 scvncctrl!DllUnregisterServer+0x4ed7
06 00dbef2c 09d3304d     00000111 000001fd 00000111 scvncctrl+0x48036
07 00dbef50 09d341f3     00000111 000001fd 00000001 scvncctrl+0x4304d

從卦象來看,程序在 scvncctrl!DllUnregisterServer+0x4ed7 方法中等待 臨界區(qū)鎖,即 RtlEnterCriticalSection 處。

可能有些朋友有疑問,為什么 scvncctrl 后面的偏移值那么大,這是因?yàn)?scvncctrl 沒有提供公有和私有符號,所以無法對應(yīng)函數(shù)名,windbg 只能以 module 為參考點(diǎn)設(shè)置偏移,這對 dump 分析產(chǎn)生了很大的阻礙!

接下來繼續(xù)看,既然主線程在等待鎖,那必然有人在持有鎖,那到底是誰在持有呢?

2. 尋找持有線程

要想找到持有者,可以提取 RtlEnterCriticalSection 方法中的第一個(gè)參數(shù) 0fd54c04 ,我們使用 dt _RTL_CRITICAL_SECTION 命令即可。

0:000:x86> dt _RTL_CRITICAL_SECTION 0fd54c04
ntdll_777d0000!_RTL_CRITICAL_SECTION
   +0x000 DebugInfo        : 0x07ba4428 _RTL_CRITICAL_SECTION_DEBUG
   +0x004 LockCount        : 0n-6
   +0x008 RecursionCount   : 0n1
   +0x00c OwningThread     : 0x0000621c Void
   +0x010 LockSemaphore    : 0xffffffff Void
   +0x014 SpinCount        : 0x200064a

上面的 OwningThread 就是當(dāng)前的持有線程,找到了之后切過去看下它的線程棧,它到底在干嘛?

0:005:x86> ~~[0x0000621c]s
ntdll_777d0000!NtWaitForSingleObject+0xc:
7784619c c20c00          ret     0Ch
0:005:x86> kb
CvRegToMachine(x86) conversion failure for 0x14f
X86MachineInfo::SetVal: unknown register 0 requested
 # ChildEBP RetAddr      Args to Child              
00 0a8cf1ac 747ccfd5     00000924 00000001 00000000 ntdll_777d0000!NtWaitForSingleObject+0xc
01 0a8cf1ac 747ddb12     00000002 00000006 ae23e128 mswsock!SockWaitForSingleObject+0x125
02 0a8cf220 75c05fe5     000007e8 0a8cf258 00000001 mswsock!WSPRecv+0x232
03 0a8cf26c 09ddd32f     000007e8 011a5a30 00002000 ws2_32!recv+0x95
WARNING: Stack unwind information not available. Following frames may be wrong.
04 0a8cf3b4 09ddd0a6     011a5a30 00002000 00000003 scvncctrl!DllUnregisterServer+0x6f27f
05 0a8cf4d4 09ddd625     00000001 00000001 07ac4ae0 scvncctrl!DllUnregisterServer+0x6eff6
06 0a8cf5f0 09ddd72f     0fd1f350 07ac4ae0 00000000 scvncctrl!DllUnregisterServer+0x6f575
07 0a8cf708 09d70626     00000003 00000001 0fd543f0 scvncctrl!DllUnregisterServer+0x6f67f
08 0a8cf958 09d71b56     00000075 000001f7 0000070b scvncctrl!DllUnregisterServer+0x2576
09 0a8cf9a4 09d3140c     00000075 000001f7 0000070b scvncctrl!DllUnregisterServer+0x3aa6
0a 0a8cfa18 09d35b89     e431cbea 0fd5fbf0 0fd543f0 scvncctrl+0x4140c
0b 0a8cfa80 09d73189     00000000 09d73120 0a8cfacc scvncctrl+0x45b89
0c 0a8cfa90 09e09434     0fd543f0 e431cba6 09e093dd scvncctrl!DllUnregisterServer+0x50d9
0d 0a8cfacc 75c77ba9     0fd5fbf0 75c77b90 0a8cfb34 scvncctrl!DllUnregisterServer+0x9b384
0e 0a8cfadc 7783b79b     0fd5fbf0 c738a5e9 00000000 kernel32!BaseThreadInitThunk+0x19
0f 0a8cfb34 7783b71f     ffffffff 778689f7 00000000 ntdll_777d0000!__RtlUserThreadStart+0x2b

卦中的 ws2_32!recv 是一個(gè)win32體系內(nèi)的方法,用于 接收客戶端發(fā)送數(shù)據(jù),可能有些朋友對 recv 方法不是很清楚,方法簽名大概如下:

int recv(
  SOCKET s,
  char *buf,
  int len,
  int flags
);

因?yàn)槭侵骺囟耍以诰W(wǎng)上找了一段 win32 實(shí)現(xiàn)的 server 版的 recv 完整代碼。

#define _WINSOCK_DEPRECATED_NO_WARNINGS

//1.頭文件
#include <stdio.h>
#include <Winsock2.h>
#pragma comment (lib,"ws2_32.lib")

int main()
{
 WSADATA wsaData;
 WSAStartup(MAKEWORD(2, 2), &wsaData); 

 if (LOBYTE(wsaData.wVersion) != 2 || HIBYTE(wsaData.wVersion) != 2)
 {
  printf("請求版本失敗!\n");
  return -1;
 }
 printf("請求版本成功!\n");
 SOCKET serverScoket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);

 if (INVALID_SOCKET == serverScoket)
 {
  printf("創(chuàng)建套接字失敗!\n");
  WSACleanup();            
  return -1;
 }
 printf("創(chuàng)建套接字成功!\n");

 SOCKADDR_IN serverAddr = { 0 };  
 serverAddr.sin_family = AF_INET;  

 serverAddr.sin_port = htons(8888);
 serverAddr.sin_addr.S_un.S_addr = inet_addr("192.168.0.107"); 

 if (SOCKET_ERROR == bind(serverScoket, (SOCKADDR*)&serverAddr, sizeof(serverAddr)))
 {
  printf("綁定失敗!\n");
  closesocket(serverScoket);
  WSACleanup();             
  return -1;
 }
 printf("綁定成功!\n");

 if (SOCKET_ERROR == listen(serverScoket, 10))
 {
  printf("監(jiān)聽失敗!\n");
  closesocket(serverScoket);
  WSACleanup();            
  return -1;
 }
 printf("監(jiān)聽成功!\n");

 SOCKADDR_IN clientAddr = { 0 }; 
 int len = sizeof(clientAddr);
 SOCKET clientSocket = accept(serverScoket, (sockaddr*)&clientAddr, &len);
 if (INVALID_SOCKET == clientSocket)
 {
  printf("接受鏈接失敗!\n");
  closesocket(serverScoket);
  WSACleanup();            
  return -1;
 }
 printf("接受客戶鏈接成功!\n");
 printf("客戶ip為:%s", inet_ntoa(clientAddr.sin_addr));

 //8.開始通訊
 char recvbuff[1024] = {}; 
 char sendbuff[1024] = {}; 

 //參數(shù)一:代表客戶端的socket,表示從客戶端進(jìn)行收取數(shù)據(jù)
 //參數(shù)二:接受的數(shù)據(jù)存放地址
 //參數(shù)三:接受數(shù)據(jù)的長度
 //參數(shù)四:表示收發(fā)方式,0表示默認(rèn),一次收完
 while (true)
 {
  //保存數(shù)據(jù)清空
  memset(recvbuff, 0, sizeof(recvbuff));
  //從客戶端接受數(shù)據(jù)
  if (recv(clientSocket, recvbuff, sizeof(recvbuff) - 1, 0) > 0)
  {
   printf("客戶說:%s\n", recvbuff);
  }
  else
  {
   break;
  }
  memset(sendbuff, 0, sizeof(sendbuff));
  printf("我說:");
  scanf_s("%s", sendbuff, sizeof(sendbuff) - 1);
  //發(fā)送數(shù)據(jù)給客戶端
  send(clientSocket, sendbuff, strlen(sendbuff), 0);
 }

 //9.關(guān)閉鏈接
 closesocket(clientSocket);//關(guān)閉客戶端socket
 closesocket(serverScoket);//關(guān)閉服務(wù)端socket
 WSACleanup();             //關(guān)閉套接字請求

 return 0;
}

結(jié)合上面的完整代碼,業(yè)務(wù)邏輯應(yīng)該是 while (true) 里的 send 和 recv 區(qū)間內(nèi)的某句代碼持有了鎖,但因?yàn)槟撤N異常導(dǎo)致持有的 臨界區(qū)鎖 沒有釋放,出現(xiàn)了一種 鎖污染 的情況。

朋友提供的信息也進(jìn)一步佐證了這種說法。

  • 大截圖
  • 受控端偶發(fā)斷網(wǎng)

這些情況組合在一起導(dǎo)致了 send 和 recv 之間的某處代碼異常污染了 臨界區(qū)鎖。

本來想提取下 recv 中的 socket 信息,結(jié)果發(fā)現(xiàn)是一個(gè)網(wǎng)絡(luò)句柄號,真正的socket信息在內(nèi)核層,沒法提出來只能作罷,截圖如下:

圖片圖片

也即線程棧上的 000007e8 字段。

0a8cf26c 09ddd32f     000007e8 011a5a30 00002000 ws2_32!recv+0x95

那這個(gè)問題怎么解決呢?通篇分析下來應(yīng)該就是 scvncctrl 的 bug,能做的就是升級到最新版本,畢竟程序里還是 2020 年的。

0:005:x86> lmvm scvncctrl
Browse full module list
start    end        module name
09cf0000 09f06000   scvncctrl   (export symbols)       scvncctrl.dll
    Loaded symbol image file: scvncctrl.dll
    Image name: scvncctrl.dll
    Browse all global symbols  functions  data
    Timestamp:        Sat Oct 10 15:14:33 2020 (5F815F59)
    CheckSum:         001CA728
    ImageSize:        00216000
    File version:     3.9.2.0
    Product version:  3.9.2.0
    File flags:       0 (Mask 3F)
    File OS:          4 Unknown Win32
    File type:        2.0 Dll
    File date:        00000000.00000000
    Translations:     0409.04b0
    Information from resource tables:
        CompanyName:      SmartCode Pte. Ltd.
        ProductName:      SmartCode VNC Viewer ActiveX
        OriginalFilename: scvncctrl.dll
        ProductVersion:   3.9.2.0
        FileVersion:      3.9.2.0
        FileDescription:  SmartCode VNC Viewer ActiveX
        LegalCopyright:   Copyright (c) 2003-2020 SmartCode Pte. Ltd. All rights reserved.
        Comments:         https://www.s-code.com

三、總結(jié)

這次卡死事故還是挺有教育意義的,告訴我們第三方插件盡量應(yīng)升盡升,同時(shí)也考察了對 臨界區(qū)鎖 和 socket 的基礎(chǔ)知識。

責(zé)任編輯:武曉燕 來源: 一線碼農(nóng)聊技術(shù)
相關(guān)推薦

2024-05-28 10:18:30

WPF程序數(shù)據(jù)

2023-05-15 11:15:50

.NET門診語句

2025-09-02 01:35:00

.NET光學(xué)定位軟件

2024-05-20 09:39:02

.NETurl線程池

2022-10-13 18:40:05

.NETOA后端

2022-01-17 21:28:36

管理系統(tǒng).NET

2024-07-01 13:00:24

.NET網(wǎng)絡(luò)邊緣計(jì)算

2024-11-29 10:06:59

2024-09-14 10:28:56

.NET卡死程序

2023-04-06 10:52:18

2024-12-27 13:31:18

.NETdump調(diào)試

2024-06-06 10:51:15

自動(dòng)化系統(tǒng)推測

2024-05-31 12:56:06

.NET代碼方法

2023-10-07 13:28:53

.NET軟件賬本

2024-06-13 17:09:55

2022-10-09 10:47:37

NET視覺軟件

2023-06-26 00:12:46

2024-03-28 12:56:36

2023-07-06 10:11:38

.NET模式dump

2024-07-12 11:20:34

.NET崩潰視覺程序
點(diǎn)贊
收藏

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

欧美性大战久久| 久久激情综合| 日韩免费高清视频| 被灌满精子的波多野结衣| 蜜桃视频久久一区免费观看入口| 欧美久久一区二区三区| 亚洲人成精品久久久久| 成人在线免费网站| 无码人妻丰满熟妇精品区| 97精品国产一区二区三区| 欧美成人一区二区三区| 漂亮人妻被中出中文字幕| 日本天堂在线观看| 成人深夜在线观看| 国产精品老牛影院在线观看| 久久久久成人精品无码| 国产精品免费99久久久| 日韩欧美视频一区| 妺妺窝人体色www在线观看| 亚洲国产精品精华素| 久久久综合激的五月天| 91网站在线免费观看| 69国产精品视频免费观看| 欧美jjzz| 在线精品国产成人综合| 呦呦视频在线观看| 国产中文欧美日韩在线| 日本久久精品电影| 奇米精品一区二区三区| 操你啦在线视频| 国产欧美日本一区二区三区| 国产精品区一区二区三含羞草| 美女福利视频在线观看| 国产99久久久国产精品成人免费| 精品人伦一区二区三区蜜桃网站| 国产精品一区二区三区精品| 中文字幕在线观看欧美| 亚洲男人影院| 久久久久亚洲精品| 激情五月深爱五月| 国产一区二区欧美| 国产视频精品在线| 亚洲av成人片无码| 97一区二区国产好的精华液| 在线电影院国产精品| 手机看片福利日韩| 亚洲免费福利| 一本久久综合亚洲鲁鲁五月天| 亚洲国产日韩欧美| 精华区一区二区三区| 91最新地址在线播放| 国产欧美一区二区在线播放| 99久久精品国产一区色| 激情欧美一区二区三区在线观看| 久久久精品999| 黑人と日本人の交わりビデオ| 欧美亚洲黄色| 欧美视频一区二区在线观看| 亚欧在线免费观看| 欧美黄色三级| 在线观看av一区二区| 成人在线免费播放视频| 无遮挡爽大片在线观看视频 | 天堂av手机版| 懂色av噜噜一区二区三区av| 亚洲影影院av| www.狠狠干| 丁香婷婷深情五月亚洲| 国产精品久久久久免费| 亚洲三区在线观看无套内射| 久久综合久久综合久久综合| 日韩欧美一区二区三区四区| 国产系列在线观看| 国产精品美女久久久久aⅴ| 亚洲免费视频一区| av毛片在线免费| 一区二区成人在线视频| 男人添女荫道口图片| 美女av在线免费看| 91福利在线观看| 亚洲欧洲日本精品| 精品一区二区三区四区五区| 欧美v日韩v国产v| 疯狂揉花蒂控制高潮h| 色综合中文网| 精品国产一区av| 久久一级黄色片| 国产精品毛片| 国产综合香蕉五月婷在线| 国产国语亲子伦亲子| 成人av网站在线观看免费| 欧美日韩精品一区| 国产黄色小视频在线| 亚洲成av人片在线| 天天干在线影院| 97久久精品一区二区三区的观看方式 | 成人性色av| 三区在线观看| 亚洲色图在线视频| 久久久久久久久久久视频| 朝桐光一区二区| 精品嫩草影院久久| 男人舔女人下部高潮全视频| 欧美在线网站| 国产成人a亚洲精品| 99久久精品国产一区二区成人| 老司机精品视频在线| 97se亚洲综合| 狠狠狠综合7777久夜色撩人| 亚洲综合在线视频| 一级在线免费视频| 极品国产人妖chinesets亚洲人妖| 欧美成人综合网站| 1024手机在线观看你懂的| 欧美视频网站| 国产精品久久久久久久9999| 丰满大乳国产精品| 国产精品久久久一本精品| 九色在线视频观看| 日韩精品一区二区三区中文字幕| 91精品久久久久久久久99蜜臂| 日本美女视频一区| 日韩高清一级| 欧美激情a在线| 在线视频 中文字幕| 北条麻妃一区二区三区| 亚洲视频小说| 婷婷六月国产精品久久不卡| 精品电影一区二区| 国产色无码精品视频国产| 日本视频在线一区| 欧美13一14另类| 成人性生交大片免费看网站| 6080午夜不卡| 特黄一区二区三区| 老司机一区二区三区| 久久精品美女| av在线资源| 精品国产乱码久久久久久免费| 亚洲婷婷在线观看| 欧美激情一级片一区二区| 国产在线精品播放| 91大神在线网站| 欧洲av一区二区嗯嗯嗯啊| 90岁老太婆乱淫| 亚洲日本国产| 超碰97在线资源| 中文字幕在线三区| 欧美一级欧美三级在线观看| 日韩av手机在线免费观看| 久久精品国产亚洲aⅴ| 日韩中文一区二区三区| 朝桐光一区二区| 国产亚洲xxx| 自拍偷拍18p| 欧美国产日产图区| 九色porny自拍| 99re66热这里只有精品8| 国产精品欧美日韩一区二区| yiren22亚洲综合伊人22| 欧美在线你懂的| 色婷婷粉嫩av| 国产一区久久久| 成人午夜免费在线视频| 韩国女主播一区二区三区| 91精品国产色综合久久不卡98口| 中文字幕在线一| 国产精品灌醉下药二区| 亚洲成人天堂网| 亚洲精品国产偷自在线观看| 99re在线观看| 日韩精品美女| 国产亚洲欧美视频| 国产美女免费看| 亚洲午夜激情网站| 国产乱了高清露脸对白| 日韩成人精品在线| 国产奶头好大揉着好爽视频| jizz18欧美18| 日本电影亚洲天堂| 黄色动漫在线| 亚洲精品国产精品自产a区红杏吧 亚洲精品国产精品乱码不99按摩 亚洲精品国产精品久久清纯直播 亚洲精品国产精品国自产在线 | 久久久精品视频免费观看| 成人性色生活片免费看爆迷你毛片| 视频一区视频二区视频三区视频四区国产| 国产区在线观看| 精品久久久久一区| 欧美性猛交bbbbb精品| 国产精品人人做人人爽人人添| 国产v片免费观看| 少妇精品久久久一区二区三区| 久久免费精品日本久久中文字幕| 亚洲一级视频在线观看| 一区二区三区在线视频播放| 亚洲久久久久久| 久久国产视频网| 日韩精品 欧美| 日韩av片子| 国产一区二区高清视频| 国产精品久久久久久妇女| 久久人人爽人人爽人人片av高请 | 成人免费视频视频| 苍井空浴缸大战猛男120分钟| 日韩欧美在线精品| 国产欧美日韩视频| 999福利在线视频| 日韩中文字幕亚洲| 四虎在线免费看| 日韩欧美自拍偷拍| 中文字幕 亚洲视频| 亚洲午夜久久久久久久久久久 | 97久久超碰| 国产精品综合久久久| 涩涩在线视频| 精品中文字幕视频| 在线中文资源天堂| 亚洲精品一区av在线播放| 国产女无套免费视频| 色就色 综合激情| 欧美福利视频一区二区| 亚洲欧美日韩精品久久久久| 亚洲一区二区自偷自拍 | 亚洲av毛片在线观看| 天使萌一区二区三区免费观看| 国产三区二区一区久久| 精品福利在线| 日韩美女视频中文字幕| h片在线观看视频免费| 欧美成人h版在线观看| 在线激情网站| 亚洲欧美国产高清va在线播| 国产91免费在线观看| 91麻豆精品国产综合久久久久久| 免费在线观看一级片| 国产精品电影院| 卡一卡二卡三在线观看| 久久久亚洲高清| 青青草视频播放| 99在线热播精品免费| 少妇熟女视频一区二区三区| 国产精品一区二区男女羞羞无遮挡| 白白操在线视频| 久久久久久久久久久久久久久久久久| 91九色露脸| 激情综合婷婷| 亚洲最大福利视频网站| 91精品网站在线观看| 国产精品美女久久久久av超清| 黄色网页在线免费看| 日韩一级裸体免费视频| 欧美日韩视频在线播放| 日韩在线免费av| av在线电影免费观看| 最近更新的2019中文字幕| 在线免费观看黄色网址| 最近中文字幕日韩精品| 91se在线| 久久最新资源网| 日韩av激情| 97高清免费视频| 欧美激情喷水| 国产精品九九九| 精品国产鲁一鲁****| 亚洲xxxx做受欧美| 成人av婷婷| 久久久综合亚洲91久久98| 九九热爱视频精品视频| 亚洲国产婷婷香蕉久久久久久99| 国产欧美一区二区三区米奇| 国产在线精品一区| 久久综合亚洲| 一区二区国产日产| 欧美精品观看| 国产第一页视频| 久久精品国产成人一区二区三区 | 免费视频一区| 日本888xxxx| 国产美女主播视频一区| 亚洲激情 欧美| 国产日韩在线不卡| 亚洲天堂一级片| 午夜视频在线观看一区| 国内精品福利视频| 欧美私人免费视频| a级片在线视频| 精品无人区太爽高潮在线播放| 亚洲av综合色区无码一区爱av| 欧美日韩免费观看一区二区三区| 中文字幕国产在线观看| 欧美老人xxxx18| 刘亦菲毛片一区二区三区| 亚洲色图50p| 1stkiss在线漫画| 欧美中在线观看| 日韩大陆av| 久久久久久久久久久久久久一区| 日韩激情网站| 男人的天堂成人| 欧美亚洲一区| 丰满少妇中文字幕| 国产亚洲短视频| 久久久国产精品人人片| 91久久精品国产91性色tv| 99久久精品无免国产免费| 亚洲欧洲免费视频| 国产www视频在线观看| 国产精品久久久亚洲| 国内精品麻豆美女在线播放视频 | 国产精品扒开腿做爽爽爽视频| 天堂√8在线中文| 成人国产精品久久久久久亚洲| 日日狠狠久久| 欧美日韩一区二区三区免费| 中文无码久久精品| 蜜桃免费在线视频| 97超碰欧美中文字幕| 欧美日韩在线视频免费| 在线免费观看日本一区| 日本人妻丰满熟妇久久久久久| 亚洲国内精品视频| 1区2区3区在线视频| 国产一区欧美二区三区| 国产精品一区二区三区av麻| 国精产品一区一区三区视频| 国产成人小视频| 亚洲不卡在线播放| 欧美狂野另类xxxxoooo| 成年人在线观看| 日韩av片电影专区| 欧洲亚洲视频| 日韩人妻无码精品久久久不卡| 国产一区二区三区的电影 | 久久99久久98精品免观看软件| 一区二区三区中文字幕| 7777久久亚洲中文字幕| 国产亚洲精品一区二区| 厕沟全景美女厕沟精品| 韩国成人动漫在线观看| 亚洲视频日本| 男人网站在线观看| 亚洲成人一区在线| 亚洲国产精品视频在线| 欧美成人小视频| 久久久精品区| 强开小嫩苞一区二区三区网站 | 91精品国产高清久久久久久91 | 日本美女视频网站| 亚洲猫色日本管| 精品人妻无码一区二区| 久久在线免费观看视频| 国产精品视频首页| 久久av高潮av| av在线播放成人| 日本韩国欧美中文字幕| 亚洲日本成人网| 欧美与亚洲与日本直播| 亚洲欧洲免费无码| 国产一区二区三区在线观看精品 | 亚洲成人精品一区二区| 日本成人动漫在线观看| 97国产在线观看| 亚洲精品aaaaa| 我要看一级黄色大片| 亚洲欧美一区二区视频| www.国产麻豆| 97久久伊人激情网| 精品精品久久| 欧美国产日韩另类 | 日韩欧美视频一区二区三区四区| 在线看片不卡| 伊人久久一区二区三区| 色综合视频在线观看| 欧美激情免费| 国产精品综合久久久久久| 国产日韩亚洲| 长河落日免费高清观看| 欧美一区二区三区在线电影| 波多野结依一区| 欧美日韩在线一区二区三区| 久久精品999| 欧美一级高潮片| 永久免费看mv网站入口亚洲| 精品中文字幕一区二区三区四区 | 久久久久久久极品| 亚洲性猛交xxxxwww| 厕沟全景美女厕沟精品| 国产系列第一页| 高清在线观看日韩| 天天综合久久综合| 久久中国妇女中文字幕| 图片婷婷一区| 亚洲精品20p| 色综合天天综合网天天狠天天| 亚洲第一天堂在线观看| 国产suv精品一区二区| 91偷拍一区二区三区精品| 捆绑裸体绳奴bdsm亚洲| 欧美视频一区二区三区在线观看 | 日韩在线一区二区三区免费视频| av电影免费在线看|