成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > OpenCV結合selenium實現(xiàn)滑塊驗證碼

OpenCV結合selenium實現(xiàn)滑塊驗證碼

熱門標簽:電梯新時達系統(tǒng)外呼顯示e 西青語音電銷機器人哪家好 地圖標注與注銷 南昌地圖標注 成都呼叫中心外呼系統(tǒng)哪家強 百應電話機器人總部 旅游廁所地圖標注怎么弄 無錫智能外呼系統(tǒng)好用嗎 宿州電話機器人哪家好

本次案例使用OpenCV和selenium來解決一下滑塊驗證碼

先說一下思路:

  • 彈出滑塊驗證碼后使用selenium元素截圖將驗證碼整個背景圖截取出來
  • 將需要滑動的小圖單獨截取出來,最好將小圖與背景圖頂部的像素距離獲取到,這樣可以將背景圖上下多余的邊框截取掉
  • 使用OpenCV將背景圖和小圖進行灰度處理,并對小圖再次進行二值化全局閾值,這樣就可以利用OpenCV在背景圖中找到小圖所在的位置
  • 用OpenCV獲取到相差的距離后利用selenium的鼠標拖動方法進行拖拉至終點。

詳細步驟:

先獲取驗證碼背景圖,selenium瀏覽器對象中使用screenshot方法可以將指定的元素圖片截取出來

import os
from selenium import webdriver


browser = webdriver.Chrome()
browser.get("https://www.toutiao.com/c/user/token/MS4wLjABAAAA4EKNlqVeNTTuEdWn0VytNS8cdODKTsNNwLTxOnigzZtclro2Kylvway5mTyTUKvz/")

save_path = os.path.join(os.path.expanduser('~'), "Desktop", "background.png")
browser.find_element_by_id("element_id_name").screenshot(save_path)

截取后的驗證碼背景圖和需要滑動的小圖   如:

再將小圖與背景圖頂部的像素距離獲取到,指的是下面圖中紅邊的高度:

如果HTML元素中小圖是單獨存在時,那么它的高度在會定義在頁面元素中,使用selenium頁面元素對象的value_of_css_property方法可以獲取到像素距離。

獲取這個是因為要把背景圖的上下兩邊多余部分進行切除,從而保留關鍵的圖像部位,能夠大幅度提高識別率。

element_object = browser.find_element_by_xpath("xpath_element")
px = element_object.value_of_css_property("top")

接下來就要對圖像進行灰度處理:

import numpy
import cv2


def make_threshold(img):
    """全局閾值
    將圖片二值化,去除噪點,讓其黑白分明"""
    x = numpy.ones(img.shape, numpy.uint8) * 255
    y = img - x
    result, thresh = cv2.threshold(y, 127, 255, cv2.THRESH_BINARY_INV)
    # 將二值化后的結果返回
    return thresh


class ComputeDistance:
    """獲取需要滑動的距離
    將驗證碼背景大圖和需要滑動的小圖進行處理,先在大圖中找到相似的小圖位置,再獲取對應的像素偏移量"""
    def __init__(self, Background_path: str, image_to_move: str, offset_top_px: int):
        """
        :param Background_path: 驗證碼背景大圖
        :param image_to_move: 需要滑動的小圖
        :param offset_top_px: 小圖距離在大圖上的頂部邊距(像素偏移量)
        """
        self.Background_img = cv2.imread(Background_path)
        self.offset_px = offset_top_px
        self.show_img = show_img
        small_img_data = cv2.imread(image_to_move, cv2.IMREAD_UNCHANGED)
        # 得到一個改變維度為50的乘以值
        scaleX = 50 / small_img_data.shape[1]
        # 使用最近鄰插值法縮放,讓xy乘以scaleX,得到縮放后shape為50x50的圖片
        self.tpl_img = cv2.resize(small_img_data, (0, 0), fx=scaleX, fy=scaleX)
        self.Background_cutting = None

    def tpl_op(self):
        # 將小圖轉換為灰色
        tpl_gray = cv2.cvtColor(self.tpl_img, cv2.COLOR_BGR2GRAY)
        h, w = tpl_gray.shape
        # 將背景圖轉換為灰色
        # Background_gray = cv2.cvtColor(self.Background_img, cv2.COLOR_BGR2GRAY)
        Background_gray = cv2.cvtColor(self.Background_cutting, cv2.COLOR_BGR2GRAY)
        # 得到二值化后的小圖
        threshold_img = make_threshold(tpl_gray)
        # 將小圖與大圖進行模板匹配,找到所對應的位置
        result = cv2.matchTemplate(Background_gray, threshold_img, cv2.TM_CCOEFF_NORMED)
        min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(result)
        # 左上角位置
        top_left = (max_loc[0] - 5, max_loc[1] + self.offset_px)
        # 右下角位置
        bottom_right = (top_left[0] + w, top_left[1] + h)
        # 在源顏色大圖中畫出小圖需要移動到的終點位置
        """rectangle(圖片源數(shù)據(jù), 左上角, 右下角, 顏色, 畫筆厚度)"""
        cv2.rectangle(self.Background_img, top_left, bottom_right, (0, 0, 255), 2)

    def cutting_background(self):
        """切割圖片的上下邊框"""
        height = self.tpl_img.shape[0]
        # 將大圖中上下多余部分去除,如: Background_img[40:110, :]
        self.Background_cutting = self.Background_img[self.offset_px - 10: self.offset_px + height + 10, :]

    def run(self):
        # 如果小圖的長度與大圖的長度一致則不用將大圖進行切割,可以將self.cutting_background()注釋掉
        self.cutting_background()
        return self.tpl_op()


if __name__ == '__main__':
    image_path1 = "背景圖路徑"
    image_path2 = "小圖路徑"
    distance_px = "像素距離"
    main = ComputeDistance(image_path1, image_path2, distance_px)
    main.run()

上面代碼可以返回小圖到凹點的距離,現(xiàn)在我們可以看一下灰度處理中的圖片樣子:

得到距離后還要對這個距離數(shù)字進行處理一下,要讓它拆分成若干個小數(shù),這么做的目的是在拖動的時候不能一下拖動到終點,

要模仿人類的手速緩緩向前行駛,不然很明顯是機器在操控。

比如到終點的距離為100,那么要把它轉為 [8, 6, 11, 10, 3, 6, 3, -2, 4, 0, 15, 1, 9, 6, -2, 4, 1, -2, 15, 6, -2] 類似的,列表中的數(shù)加起來正好為100.

最簡單的轉換:

def handle_distance(distance):
    """將直線距離轉為緩慢的軌跡"""
    import random
    slow_distance = []
    while sum(slow_distance) = distance:
        slow_distance.append(random.randint(-2, 15))

    if sum(slow_distance) != distance:
        slow_distance.append(distance - sum(slow_distance))
    return slow_distance

有了到終點的距離,接下來就開始拖動吧:

import time
from random import randint
from selenium.webdriver.common.action_chains import ActionChains


def move_slider(website, slider, track, **kwargs):
    """將滑塊移動到終點位置
    :param website: selenium頁面對象
    :param slider: selenium頁面中滑塊元素對象
    :param track: 到終點所需的距離
    """
    name = kwargs.get('name', '滑塊')

    try:
        if track[0] > 200:
            return track[0]
        # 點擊滑塊元素并拖拽
        ActionChains(website).click_and_hold(slider).perform()
        time.sleep(0.15)
        for i in track:
            # 隨機上下浮動鼠標
            ActionChains(website).move_by_offset(xoffset=i, yoffset=randint(-2, 2)).perform()
        # 釋放元素
        time.sleep(1)
        ActionChains(website).release(slider).perform()
        time.sleep(1)
        # 隨機拿開鼠標
        ActionChains(website).move_by_offset(xoffset=randint(200, 300), yoffset=randint(200, 300)).perform()
        print(f'[網(wǎng)頁] 拖拽 {name}')
        return True
    except Exception as e:
        print(f'[網(wǎng)頁] 拖拽 {name} 失敗 {e}')

教程結束,讓我們結合上面代碼做一個案例吧。

訪問今日頭條某博主的主頁,直接打開主頁的鏈接會出現(xiàn)驗證碼。

下面代碼 使用pip安裝好相關依賴庫后可直接運行:

調用ComputeDistance類時,參數(shù) show_img=True 可以在拖動驗證碼前進行展示背景圖識別終點后的區(qū)域在哪里, 如:

distance_obj = ComputeDistance(background_path, small_path, px, show_img=True)

OK,下面為案例代碼: 

import os
import time
import requests
import cv2
import numpy
from random import randint

from selenium import webdriver
from selenium.webdriver.common.action_chains import ActionChains


def show_image(img_array, name='img', resize_flag=False):
    """展示圖片"""
    maxHeight = 540
    maxWidth = 960
    scaleX = maxWidth / img_array.shape[1]
    scaleY = maxHeight / img_array.shape[0]
    scale = min(scaleX, scaleY)
    if resize_flag and scale  1:
        img_array = cv2.resize(img_array, (0, 0), fx=scale, fy=scale)
    cv2.imshow(name, img_array)
    cv2.waitKey(0)
    cv2.destroyWindow(name)


def make_threshold(img):
    """全局閾值
    將圖片二值化,去除噪點,讓其黑白分明"""
    x = numpy.ones(img.shape, numpy.uint8) * 255
    y = img - x
    result, thresh = cv2.threshold(y, 127, 255, cv2.THRESH_BINARY_INV)
    # 將二值化后的結果返回
    return thresh


def move_slider(website, slider, track, **kwargs):
    """將滑塊移動到終點位置
    :param website: selenium頁面對象
    :param slider: selenium頁面中滑塊元素對象
    :param track: 到終點所需的距離
    """
    name = kwargs.get('name', '滑塊')

    try:
        if track[0] > 200:
            return track[0]
        # 點擊滑塊元素并拖拽
        ActionChains(website).click_and_hold(slider).perform()
        time.sleep(0.15)
        for i in track:
            # 隨機上下浮動鼠標
            ActionChains(website).move_by_offset(xoffset=i, yoffset=randint(-2, 2)).perform()
        # 釋放元素
        time.sleep(1)
        ActionChains(website).release(slider).perform()
        time.sleep(1)
        # 隨機拿開鼠標
        ActionChains(website).move_by_offset(xoffset=randint(200, 300), yoffset=randint(200, 300)).perform()
        print(f'[網(wǎng)頁] 拖拽 {name}')
        return True
    except Exception as e:
        print(f'[網(wǎng)頁] 拖拽 {name} 失敗 {e}')


class ComputeDistance:
    """獲取需要滑動的距離
    將驗證碼背景大圖和需要滑動的小圖進行處理,先在大圖中找到相似的小圖位置,再獲取對應的像素偏移量"""
    def __init__(self, Background_path: str, image_to_move: str, offset_top_px: int, show_img=False):
        """
        :param Background_path: 驗證碼背景大圖
        :param image_to_move: 需要滑動的小圖
        :param offset_top_px: 小圖距離在大圖上的頂部邊距(像素偏移量)
        :param show_img: 是否展示圖片
        """
        self.Background_img = cv2.imread(Background_path)
        self.offset_px = offset_top_px
        self.show_img = show_img
        small_img_data = cv2.imread(image_to_move, cv2.IMREAD_UNCHANGED)
        # 得到一個改變維度為50的乘以值
        scaleX = 50 / small_img_data.shape[1]
        # 使用最近鄰插值法縮放,讓xy乘以scaleX,得到縮放后shape為50x50的圖片
        self.tpl_img = cv2.resize(small_img_data, (0, 0), fx=scaleX, fy=scaleX)
        self.Background_cutting = None

    def show(self, img):
        if self.show_img:
            show_image(img)

    def tpl_op(self):
        # 將小圖轉換為灰色
        tpl_gray = cv2.cvtColor(self.tpl_img, cv2.COLOR_BGR2GRAY)
        h, w = tpl_gray.shape
        # 將背景圖轉換為灰色
        # Background_gray = cv2.cvtColor(self.Background_img, cv2.COLOR_BGR2GRAY)
        Background_gray = cv2.cvtColor(self.Background_cutting, cv2.COLOR_BGR2GRAY)
        # 得到二值化后的小圖
        threshold_img = make_threshold(tpl_gray)
        # 將小圖與大圖進行模板匹配,找到所對應的位置
        result = cv2.matchTemplate(Background_gray, threshold_img, cv2.TM_CCOEFF_NORMED)
        min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(result)
        # 左上角位置
        top_left = (max_loc[0] - 5, max_loc[1] + self.offset_px)
        # 右下角位置
        bottom_right = (top_left[0] + w, top_left[1] + h)
        # 在源顏色大圖中畫出小圖需要移動到的終點位置
        """rectangle(圖片源數(shù)據(jù), 左上角, 右下角, 顏色, 畫筆厚度)"""
        cv2.rectangle(self.Background_img, top_left, bottom_right, (0, 0, 255), 2)
        if self.show_img:
            show_image(self.Background_img)
        return top_left

    def cutting_background(self):
        """切割圖片的上下邊框"""
        height = self.tpl_img.shape[0]
        # 將大圖中上下多余部分去除,如: Background_img[40:110, :]
        self.Background_cutting = self.Background_img[self.offset_px - 10: self.offset_px + height + 10, :]

    def run(self):
        # 如果小圖的長度與大圖的長度一致則不用將大圖進行切割,可以將self.cutting_background()注釋掉
        self.cutting_background()
        return self.tpl_op()


class TodayNews(object):
    def __init__(self):
        self.url = "https://www.toutiao.com/c/user/token/" \

                   "MS4wLjABAAAA4EKNlqVeNTTuEdWn0VytNS8cdODKTsNNwLTxOnigzZtclro2Kylvway5mTyTUKvz/"
        self.process_folder = os.path.join(os.path.expanduser('~'), "Desktop", "today_news")
        self.background_path = os.path.join(self.process_folder, "background.png")
        self.small_path = os.path.join(self.process_folder, "small.png")
        self.small_px = None
        self.xpath = {}
        self.browser = None

    def check_file_exist(self):
        """檢查流程目錄是否存在"""
        if not os.path.isdir(self.process_folder):
            os.mkdir(self.process_folder)

    def start_browser(self):
        """啟動瀏覽器"""
        self.browser = webdriver.Chrome()
        self.browser.maximize_window()

    def close_browser(self):
        self.browser.quit()

    def wait_element_loaded(self, xpath: str, timeout=10, close_browser=True):
        """等待頁面元素加載完成
        :param xpath: xpath表達式
        :param timeout: 最長等待超時時間
        :param close_browser: 元素等待超時后是否關閉瀏覽器
        :return: Boolean
        """
        now_time = int(time.time())
        while int(time.time()) - now_time  timeout:
            # noinspection PyBroadException
            try:
                element = self.browser.find_element_by_xpath(xpath)
                if element:
                    return True
                time.sleep(1)
            except Exception:
                pass
        else:
            if close_browser:
                self.close_browser()
            # print("查找頁面元素失敗,如果不存在網(wǎng)絡問題請嘗試修改xpath表達式")
            return False

    def add_page_element(self):
        self.xpath['background_img'] = '//div[@role="dialog"]/div[2]/img[1]'
        self.xpath['small_img'] = '//div[@role="dialog"]/div[2]/img[2]'
        self.xpath['slider_button'] = '//div[@id="secsdk-captcha-drag-wrapper"]/div[2]'

    def process_main(self):
        """處理頁面內容"""
        self.browser.get(self.url)

        for _ in range(10):
            if self.wait_element_loaded(self.xpath['background_img'], timeout=5, close_browser=False):
                time.sleep(1)
                # 截圖
                self.browser.find_element_by_xpath(self.xpath['background_img']).screenshot(self.background_path)
                small_img = self.browser.find_element_by_xpath(self.xpath['small_img'])
                # 獲取小圖片的URL鏈接
                small_url = small_img.get_attribute("src")
                # 獲取小圖片距離背景圖頂部的像素距離
                self.small_px = small_img.value_of_css_property("top").replace("px", "").split(".")[0]

                response = requests.get(small_url)
                if response.ok:
                    with open(self.small_path, "wb") as file:
                        file.write(response.content)

                time.sleep(1)
                # 如果沒滑動成功則刷新頁面重試
                if not self.process_slider():
                    self.browser.refresh()
                    continue
            else:
                break

    @staticmethod
    def handle_distance(distance):
        """將直線距離轉為緩慢的軌跡"""
        import random
        slow_distance = []
        while sum(slow_distance) = distance:
            slow_distance.append(random.randint(-2, 15))

        if sum(slow_distance) != distance:
            slow_distance.append(distance - sum(slow_distance))
        return slow_distance

    def process_slider(self):
        """處理滑塊驗證碼"""

        distance_obj = ComputeDistance(self.background_path, self.small_path, int(self.small_px), show_img=False)
        # 獲取移動所需的距離
        distance = distance_obj.run()

        track = self.handle_distance(distance[0])
        track.append(-2)
        slider_element = self.browser.find_element_by_xpath(self.xpath['slider_button'])

        move_slider(self.browser, slider_element, track)
        time.sleep(2)

        # 如果滑動完成則返回True
        if not self.wait_element_loaded(self.xpath['slider_button'], timeout=2, close_browser=False):
            return True
        else:
            return False

    def run(self):
        self.check_file_exist()
        self.start_browser()
        self.add_page_element()
        self.process_main()
        # self.close_browser()


if __name__ == '__main__':
    main = TodayNews()
    main.run()

到此這篇關于OpenCV結合selenium實現(xiàn)滑塊驗證碼的文章就介紹到這了,更多相關OpenCV selenium滑塊驗證碼內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python Selenium破解滑塊驗證碼最新版(GEETEST95%以上通過率)

標簽:辛集 西安 濰坊 贛州 渭南 七臺河 雅安 許昌

巨人網(wǎng)絡通訊聲明:本文標題《OpenCV結合selenium實現(xiàn)滑塊驗證碼》,本文關鍵詞  OpenCV,結合,selenium,實現(xiàn),;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《OpenCV結合selenium實現(xiàn)滑塊驗證碼》相關的同類信息!
  • 本頁收集關于OpenCV結合selenium實現(xiàn)滑塊驗證碼的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    四虎影视成人| 99热这里只有精品99| 亚洲第一视频在线观看| 欧美午夜精品一区| 青娱乐国产91| 国产精品999999| 亚洲国产综合视频| 亚洲午夜久久久影院| 中文字幕在线观看免费| 一二三区不卡| 尤物免费看在线视频| 小说区亚洲自拍另类图片专区| 女人被爽到呻吟gif动态图下载| 成人做爰69片免费看网站| 日产欧产美韩系列久久99| 色欲色香天天天综合网www| 欧美肥婆姓交大片| 三区四区电影在线观看| 免费的国产精品| 欧美少妇激情| 日韩电影免费在线看| 中文字幕网在线| 伊人网在线视频观看| 领导边摸边吃奶边做爽在线观看| 国产精品福利在线观看网址| 在线观看免费黄视频| 在线播放黄色av| 国产精品美女久久久久人| 国产网站在线免费观看| 黄色性生活一级片| 麻豆精品一区二区三区视频| 99久久99久久精品国产| 日产日韩在线亚洲欧美| 国产女主播福利| 天天操夜夜操国产精品| 日本午夜激情视频| 男人天堂网av| 中文字幕电影在线| 日韩精品极品毛片系列视频| 欧美日韩精品在线| 一级片在线观看视频| 综合国产在线视频| 国产精品综合一区二区| 欧美日韩中文字幕一区二区| 日韩精品一卡二卡| 亚洲欧洲制服丝袜| 久久综合九色综合97婷婷| 国产人妻精品一区二区三区| 免费大片黄在线观看视频网站| 波多野结衣av在线| 色狠狠久久av综合| 一区二区国产欧美| 免费看日本一区二区| 国产黄片一区二区三区| 青青久久av| 国产精品50p| 成人久久在线| 欧美日韩精品一本二本三本| 欧美一级免费播放| 中文娱乐网av| 日韩中文字幕a| 亚洲尤物在线视频观看| 3p视频在线观看| 国产不卡网站| 青青青国产精品一区二区| 一二三四中文字幕| 思热99re视热频这里只精品| 欧美福利网址| 国产一区二区三区精品欧美日韩一区二区三区| 色婷婷综合在线| 在线日韩av永久免费观看| 网曝门事件国产精品二区| 男女视频一区二区三区| 国产精品偷伦视频免费观看了| 少妇大叫太大太粗太爽了a片小说| 杨幂一区二区国产精品| 91九色国产视频| 国产精品一区二区免费视频| freee性欧美| 亚洲视频中文字幕在线观看| 日韩大片在线观看视频| 六月天色婷婷| 中文在线手机av| 久久久噜噜噜久噜久久综合| 欧美成人免费全部| 在线视频免费观看一区| 国产一二三四在线视频| 亚洲一区二区三区精品中文字幕| 国产黄色免费观看| 精品成人免费一区二区在线播放| 国产网站免费观看| 欧美色图在线视频| 久久久久久91香蕉国产| 在线免费观看的av| 色小子综合网| 色视频在线观看| 一区二区三区的久久的视频| av资源在线播放| 亚洲精品乱码久久久久久不卡| 久久影院午夜精品| 91网站最新网址| 国产成人在线免费视频| 91插插插插插插| 91在线中字| 日产福利视频在线观看| 传媒av在线| 韩国精品久久久| av黄色在线| 经典三级一区二区| 国产91综合网| 日韩欧美一区二区不卡| 九九综合久久| 日韩电影免费观看中文字幕| 亚洲三区在线观看无套内射| 国产精品福利电影一区二区三区四区| 大胆人体色综合| 亚洲另类自拍| 亚洲国产美女久久久久| 性农村xxxxx小树林| 欧美在线首页| 蜜桃精品wwwmitaows| 亚洲成人第一网站| 亚洲精品乱码久久久久久| 一区二区国产在线| 欧美电影免费看| 欧美大成色www永久网站婷| 国产aⅴ综合色| www.av成人| 91精品专区| 成年免费视频黄网站在线观看| 女人被爽到呻吟gif动态图下载| 免费在线毛片网站| 91超碰中文字幕久久精品| 无套内谢大学处破女www小说| 国产超碰精品在线观看| 好吊色在线视频| 精品久久中出| 欧美日韩在线不卡视频| av资源吧首页| 男人的天堂av网| 中文字幕人妻一区二区三区在线视频| 成人国产精品免费| 久久综合久久久久88| 91精品国产综合久久久久久豆腐| 成人动漫视频在线观看| 视频一区日韩| 国产中文一区二区| 日本成人a网站| 桃乃木香奈和黑人aⅴ在线播放| 成人av电影在线网| 超碰av在线免费观看| 国产成年人在线观看| 欧美三级在线播放| 欧美高潮视频| 亚洲福利国产| 国产精品久久久久999| 免费在线a视频| 爽好久久久欧美精品| 7777精品伊人久久久大香线蕉经典版下载| 在线看国产一区| 成人日日夜夜| 日韩欧美国产中文字幕| 91性高湖久久久久久久久_久久99| 亚洲青青久久| 国产精品少妇在线视频| 亚洲第一色av| 日本系列欧美系列| 中文字幕在线视频精品| 免费日本视频一区| 免费h在线看| 日韩国产欧美一区二区| 每日在线更新av| 成人免费av片| 成人午夜免费在线观看| 成人动漫精品一区二区| 久久91精品视频| 亚洲深夜福利网站| 久久精品国产亚洲一区二区三区| 欧洲毛片在线视频免费观看| 色综合天天爱| 色呦呦在线视频| 男女激情视频一区| 免费人成在线观看网站| japanese在线观看| 激情一区二区| 日本一区二区不卡高清更新| 一本久道久久综合无码中文| 天堂在线亚洲| 91精品视频大全| brazzers精品成人一区| 日韩丰满少妇无码内射| 26uuu亚洲国产精品| 综合激情视频| 色8久久影院午夜场| av文字幕在线观看| 久久国产精品久久精品国产| 中文字幕在线观看视频www| 日产欧产va高清| 大桥未久av一区二区三区| 谁有免费的黄色网址| 中文字幕精品三级久久久| 老司机久久99久久精品播放免费| 亚洲精品mp4| 麻豆一区产品精品蜜桃的特点| 久久久久亚洲av无码专区| 国产精品福利电影一区二区三区四区| 日本精品人妻无码77777| 天堂av一区二区三区| 小黄文在线观看| 欧美一级淫片videoshd| 国产精品免费精品一区| 秋霞影视一区二区三区| 久久99国产成人小视频| 免费看污视频的网站| 宅男噜噜噜66国产日韩在线观看| 另类天堂视频在线观看| 永久av免费在线观看| 欧美成人aaa片一区国产精品| 欧美日韩视频在线一区二区观看视频| 久久婷婷国产综合尤物精品| av片中文字幕| 国产极品一区二区三区| 99re91这里只有精品| 91小视频xxxx网站在线| 久久综合第一页| 亚洲高清国产精品| 全部孕妇毛片丰满孕妇孕交| 性欧美videos高清hd4k| 国产精品久久久久久久久免费相片| 伊人国产精品视频| 性高潮免费视频| 久久精品一区二区三区不卡免费视频| 欧美午夜激情小视频| 91免费视频网站在线观看| www.成人精品免费网站青椒| 2018av在线| 国产精品日本欧美一区二区三区| 国产精品探花视频| av在线一区二区三区| 亚洲成av人**亚洲成av**| 国产精品国产成人国产三级| 色婷婷综合久久久久中文字幕1| 国内精品不卡一区二区三区| 国产树林野战在线播放| 亚洲第一综合色| 神马久久一区二区三区| h片在线观看视频免费免费| 亚洲另类中文字| gogo大胆日本视频一区| 92看片淫黄大片一级| av官网在线观看| 51精品免费网站| 成人拍拍拍在线观看| 99久久精品免费看国产| 午夜精品久久久久久久99黑人| 天天做天天躁天天躁| 欧美福利视频网站| 欧美日韩综合在线| 51xtv成人影院| 日韩av在线资源| 嘿嘿视频在线观看| 91久久精品午夜一区二区| 国产手机av在线| av影音资源网| 99精品免费| 国产专区一区二区三区| 国产精品久久久久毛片软件| 欧美日韩国产综合一区二区三区| 日本一区二区三区免费视频| 99久久精品久久久久久ai换脸| 日韩伦理在线免费观看| 成人在线小说| 亚洲精品视频一二三区| 娇小发育未年成性色xxx8| 欧洲亚洲一区二区| 97在线免费视频观看| 国内自拍视频一区| 中国一区二区视频| 美脚丝袜脚交一区二区| 97影院秋霞午夜在线观看| 国产精品视频免费在线观看| 国产精品白丝喷水在线观看| www.大网伊人| 亚洲高清久久| 综合图区亚洲白拍在线| 97公开免费视频| 精品免费囯产一区二区三区| 亚洲视频香蕉人妖| 好看的黄色网址| 亚洲一区二区三区sesese| 一区二区视频欧美| 91欧美激情一区二区三区成人| 欧美日韩国产综合视频| www.香蕉视频在线观看| 欧美一级大片免费看| 国产一区二区按摩在线观看| av小片在线| 欧美性猛交xx乱大交| 亚洲一区欧美激情| 欧美午夜不卡影院在线观看完整版免费| 欧美电影完整版在线观看| 欧美久久久网站| 自拍偷拍国产精品| 九九久久久久久| 97精品国产综合久久久动漫日韩| 日本在线免费观看| av中文字幕一区二区三区| 色婷婷精品国产一区二区三区| 日韩亚洲欧美综合| 狠狠躁18三区二区一区| 欧美日韩精品免费观看视一区二区| 日韩av在线电影观看| 色视频精品视频在线观看| 疯狂试爱三2浴室激情视频| 精品网站www| 中文字幕第4页| 午夜男人视频在线观看| 久久成人在线观看| 天天射狠狠干| 精品亚洲va在线va天堂资源站| 亚洲精品一区中文字幕乱码| 欧美日韩国产片| 91久久中文字幕| 国产精品第一第二| 国产三级理论片| free性中国hd国语露脸| 欧美精品久久一区二区三区| 婷婷六月综合|