青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

<2009年12月>
293012345
6789101112
13141516171819
20212223242526
272829303112
3456789

統(tǒng)計

  • 隨筆 - 21
  • 文章 - 0
  • 評論 - 2
  • 引用 - 0

常用鏈接

留言簿

隨筆分類

隨筆檔案

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

轉(zhuǎn) 部分飛鴿協(xié)議

最近看到一些朋友在編寫網(wǎng)絡(luò)程序是遇到一些問題,故把以前做IPMSG時翻譯的文檔貼過來,希望對網(wǎng)絡(luò)編程新手有所幫助,在尋找編程項目的同學(xué)們也可參照此文檔寫出自己的IPMSG。

本文只包含其中幾個比較重要的命令以及運行機制的中文翻譯,更詳細的內(nèi)容請參照文后的IPMSG 協(xié)議英文文檔

聲明:下述協(xié)議內(nèi)容略去了一些在編寫程序過程中沒有用到協(xié)議內(nèi)容,最初的Ipmsg協(xié)議是用日文寫的,下面協(xié)議內(nèi)容由本人(cugb_cat)翻譯自Mr.Kanazawa的英文文檔。本翻譯文檔可任意傳播和使用。

        IP信使傳輸協(xié)議(第9版草案)         1996/02/21
                2003/01/14 修訂

                H.Shirouzu
            shirouzu@h.email.ne.jp


關(guān)于IP信使:
  IP信使使用TCP/UDP協(xié)議提供收發(fā)消息及文件(目錄)。
特性:
IP信使能夠安裝在任何一個安裝了TCP/IP協(xié)議棧的操作系統(tǒng)上,使用在線用戶的動態(tài)識別機制,可以和在線所有用戶進行信息交換。
運行機制介紹:
使用TCP/UDP端口(默認端口為2425),消息的收發(fā)使用UDP協(xié)議,文件(文件夾)的收發(fā)使用TCP協(xié)議。
1、   命令字:
1)   基本命令字(32位命令字的低8位)
    IPMSG_NOOPERATION     不進行任何操作
    IPMSG_BR_ENTRY     用戶上線
    IPMSG_BR_EXIT         用戶退出
    IPMSG_ANSENTRY     通報在線
    IPMSG_SENDMSG         發(fā)送消息
    IPMSG_RECVMSG         通報收到消息
    IPMSG_GETFILEDATA     請求通過TCP傳輸文件
    IPMSG_RELEASEFILES   停止接收文件
    IPMSG_GETDIRFILES     請求傳輸文件夾
2)   選項位(32位命令字的高24位)
IPMSG_SENDCHECKOPT   傳送檢查(需要對方返回確認信息)
IPMSG_FILEATTACHOPT   傳送文件選項
3)   附件類型命令(文件類型命令字的低8位)
IPMSG_FILE_REGULAR   普通文件
IPMSG_FILE_DIR     目錄文件
IPMSG_FILE_RETPARENT   返回上一級目錄
2、   數(shù)據(jù)包格式(使用字符串):
1)   數(shù)據(jù)包格式(版本1的格式)
版本號(1):包編號:發(fā)送者姓名:發(fā)送者主機名:命令字:附加信息
2)   舉例如下
“1:100:shirouzu:Jupiter:32:Hello”
3、   數(shù)據(jù)包處理總述:
1)   用戶識別
當(dāng)IPMSG 啟動時,命令I(lǐng)PMSG_BR_ENTRY被廣播到網(wǎng)絡(luò)中,向所有在線的用戶提示一個新用戶的到達(即表示“我來了”);所有在線用戶將把該新上線用戶添 加到自己的用戶列表中,并向該新上線用戶發(fā)送IPMSG_ANSENTRY命令(即表示“我在線”);該新上線用戶接收到IPMSG_ANSENTRY命 令后即將在線用戶添加到自己的用戶列表中。
2)   收發(fā)消息
使用IPMSG_SENDMSG命令發(fā)送消息,消息內(nèi)容添加在附加信息中;在接收消息時,如果對方要求回信確認(IPMSG_SENDCHECKOPT位打開),則需發(fā)送IPMSG_RECVMSG命令并將對方發(fā)送的數(shù)據(jù)包的編號放在附加信息中一同發(fā)送至發(fā)送消息方
3)   附加文件的擴充(添加于第9版)
帶有IPMSG_FILEATTACHOPT位的IPMSG_SENDMSG命令可用來傳輸文件,文件屬性及內(nèi)容添加在附加信息中,文件內(nèi)容添加在消息內(nèi) 容后并以’\0’與之分隔開。傳輸文件時以下信息將被添加到消息內(nèi)容之后(包括格式):文件序號:文件名:大小(單位:字節(jié)):最后修改時間:文件屬性 [: 附加屬性=val1[,val2…][:附加信息=…]]:\a:文件序號…
(文件大小、最后修改時間和文件屬性為十六進制數(shù),如果文件名中包含’:’則使用“::”代替)。
接收端開始接收文件時,請求傳輸文件命令I(lǐng)PMSG_GETFILEDATA將發(fā)送到發(fā)送端的TCP端口(和UDP的發(fā)送端口相同),并將發(fā)送端發(fā)送的包 編號:文件序號:偏移量(全為十六進制格式)寫到附加信息區(qū)一同發(fā)送,文件發(fā)送端接收到該請求信息并進行校驗正確后即開始發(fā)送文件(不使用任何格式,亦不 進行加密)。
當(dāng)接收端接收到目錄文件時,將發(fā)送附加信息區(qū)為發(fā)送端發(fā)送的包編號:文件序號:偏移量(全為十六進制格式)的 IPMSG_GETDIRFILES命令,以用來請求傳輸目錄文件;發(fā)送端則將頭信息長度:文件名:文件大小:文件屬性:文件內(nèi)容添加到附加信息區(qū)(除了 文件名和文件內(nèi)容外,其余皆為十六進制),頭信息長度是從頭信息長度開始到文件內(nèi)容前的‘:’分割符為止的字符個數(shù)。
當(dāng)文件屬性為IPMSG_FILE_DIR時,IPMsg能夠自動識別其為目錄,下一個文件的數(shù)據(jù)在該目錄之后。
當(dāng)文件屬性為IPMSG_FILE_RETPARENT時,IPMsg識別其動作為返回上一級目錄,在這種情況下,文件名為‘.’其屬性為當(dāng)前目錄的值。

附IPMSG協(xié)議英文版:



Original ipmsg protocol specification is written in Japanese.
This document was translated by Mr.Kanazawa.
This document is not verified yet.

----------------------------------------------------------------------
    IP Messenger communication protocol (Draft-9) 1996/02/21
                                Modified 2003/01/14

                                    H.Shirouzu
                              shirouzu@h.email.ne.jp
----------------------------------------------------------------------

About IP Messenger
    This is a Send/Receive message service using the TCP/UDP Port.

Characteristics
    IP Messenger can be installed in any OS if TCP/IP is used on your machine.
    Dynamic member recognition can be done within your network or specified network.
    You can exchange messages between all IPMsg members.

Function description
    Use TCP/UDP port(default:2425). See the following descriptions
    (Message Send/Receive: UDP, File Send/Receive: TCP)

1. Command

  1) Command functions (Low 8 bits from command number 32 bits)

    IPMSG_NOOPERATION No Operation
    IPMSG_BR_ENTRY Entry to service (Start-up with a Broadcast command)
    IPMSG_BR_EXIT Exit from service (End with a Broadcast command)
    IPMSG_ANSENTRY Notify a new entry
    IPMSG_BR_ABSENCE Change absence mode

    IPMSG_BR_ISGETLIST Search valid sending host members
    IPMSG_OKGETLIST Host list sending notice
    IPMSG_GETLIST Host list sending request
    IPMSG_ANSLIST Host list sending

    IPMSG_SENDMSG Message transmission
    IPMSG_RECVMSG Message receiving check

    IPMSG_READMSG Message open notice
    IPMSG_DELMSG Message discarded notice
    IPMSG_ANSREADMSG Message open confirmation notice(added from version-8 )

    IPMSG_GETFILEDATA File Transfer request by TCP
    IPMSG_RELEASEFILES Discard attachment file
    IPMSG_GETDIRFILES Attachment hierarchical file request

    IPMSG_GETINFO Get IPMSG version info.
    IPMSG_SENDINFO Send IPMSG version info.

    IPMSG_GETABSENCEINFO Get absence sentence
    IPMSG_SENDABSENCEINFO Send absence sentence

    IPMSG_GETPUBKEY RSA Public Key Acquisition
    IPMSG_ANSPUBKEY RSA Public Key Response

  2) Option flag (High 24 bits from command number 32 bits)

    IPMSG_ABSENCEOPT Absence mode(Member recognition command)
    IPMSG_SERVEROPT Server(Reserved)
    IPMSG_DIALUPOPT Send individual member recognition command

    IPMSG_SENDCHECKOPT Transmission check
    IPMSG_SECRETOPT Sealed message
    IPMSG_READCHECKOPT Sealed message check(added from ver8 )
    IPMSG_PASSWORDOPT Lock
    IPMSG_BROADCASTOPT Broadcast message
    IPMSG_MULTICASTOPT Multi-cast(Multiple casts selection)
    IPMSG_NEWMUTIOPT New version multi-cast(reserved)
    IPMSG_AUTORETOPT Automatic response(Ping-pong protection)
    IPMSG_NOLOGOPT No log files
    IPMSG_NOADDLISTOPT Notice to the members outside of BR_ENTRY

    IPMSG_FILEATTACHOPT File attachment
    IPMSG_ENCRYPTOPT Code

    IPMSG_NOPOPUPOPT (No longer valid)
    IPMSG_RETRYOPT Re-send flag(Use when acquiring HOSTLIST)

  3) Extended code flag (hex format combination)

    IPMSG_RSA_512
    IPMSG_RSA_1024
    IPMSG_RSA_2048
    IPMSG_RC2_40
    IPMSG_RC2_128
    IPMSG_RC2_256
    IPMSG_BLOWFISH_128
    IPMSG_BLOWFISH_256
    IPMSG_SIGN_MD5

  4) Extended files for attachment (fileattr low 8 bits)

    IPMSG_FILE_REGULAR
    IPMSG_FILE_DIR
    IPMSG_FILE_RETPARENT
    IPMSG_FILE_SYMLINK
    IPMSG_FILE_CDEV
    IPMSG_FILE_BDEV
    IPMSG_FILE_FIFO
    IPMSG_FILE_RESFORK

  5) Attachment file extended attribute(fileattr high 24 bits)

    IPMSG_FILE_RONLYOPT
    IPMSG_FILE_HIDDENOPT
    IPMSG_FILE_EXHIDDENOPT
    IPMSG_FILE_ARCHIVEOPT
    IPMSG_FILE_SYSTEMOPT

  6) Extended file attribute for attachment file

    IPMSG_FILE_UID
    IPMSG_FILE_USERNAME
    IPMSG_FILE_GID
    IPMSG_FILE_GROUPNAME
    IPMSG_FILE_PERM
    IPMSG_FILE_MAJORNO
    IPMSG_FILE_MINORNO
    IPMSG_FILE_CTIME
    IPMSG_FILE_MTIME
    IPMSG_FILE_ATIME
    IPMSG_FILE_CREATETIME

    IPMSG_FILE_CREATOR
    IPMSG_FILE_FILETYPE
    IPMSG_FILE_FINDERINFO

    IPMSG_FILE_ACL
    IPMSG_FILE_ALIASFNAME
    IPMSG_FILE_UNICODEFNAME


2.Command format(Use all character strings)

  1) Command(Format version-1)

    Ver(1) : PacketNo : SenderName : SenderHost : CommandNo : AdditionalSection

  2) An example for Message Send/Receive by using the current command format

    "1:100:shirouzu:jupiter:32:Hello"


3.Command process overview

  1) Member recognition

    An IPMSG_BR_ENTRY command notifies a new entry to the current
    members at start-up.

    All members add the new member to their list after getting a notification message.
    An IPMSG_ANSENTRY command sends a message back to the new member.

    The new member gets the current member data by a
    IPMSG_ANSENTRY command. All members can communicate as long as an
    IP packet exists.

    An IPMSG_BR_ABSENCE command broadcasts absence mode cancel or
    nickname change to all members. However, an IPMSG_ANSENTRY command
    does not send a message back, which is different from an IPMSG_BR_ENTRY
    command.

    IPMSG_BR_ENTRY, IPMSG_ANSENTRY, and IPMSG_BR_ABSENCE commands
    use an IPMSG_ABSENCEOPT flag for absence mode. Input a nickname to
    additional command.
    Add an IPMSG_DIALUPOPT flag for dial-up users who can't be reached by
    a broadcast command. A member recognition command needs to be
    sent individually to the members with this optional flag.

    (Extended group)IPMSG_BR_ENTRY and IPMSG_BR_ABSENCE commands
    sends a group name by adding the new group name after the current
    command format character strings (Input '
\0' between the current
    command and extended name).

  2) Send/Receive Message
    Send Message uses an IPMSG_SENDMSG command that can input a message
    in the extended area.
    Receive Message sends back an IPMSG_RECVMSG command only
    if an IPMSG_SENDCHECKOPT flag is ON. Input the original packet number
    to the extended area.

    Broadcast Message Send uses an IPMSG_BOADCASTOPT command
    and an IPMSG_SENDMSG flag should be ON.
    Auto-Send packet(absence notice) needs to be added to IPMSG_AUTORETOPT
    for ping-pong protection. If either one or another packet is ON, then
    confirmation/auto-send packet is not sent back.

    Send Message Sealing needs to be an IPMSG_SECRETOPT packet ON.
    In this case, Receive Message sends an IPMSG_READMSG command.
    Input the original packet number to the extended area.

    (Additional IPMSG_NOADDLISTOPT)
    When receiving an IPMSG_SENDMSG packet from a host that is
    not on your Send/Receive list, IPMsg will either confirm a host by
    sending an IPMSG_BR_ENTRY command or add a host name to
    the Send/Receive list.
    However, single-shot Message Send/Receive action needs to be avoided.
    Add an IPMSG_NOADDLISTOPT flag to an IPMSG_SENDMSG command.

    (Additional IPMSG_READCHECKOPT from version-8 )
    When an IPMSG_READMSG command contains an IPMSG_READCHECKOPT flag,
    IPMsg process is the same as IPMSG_SENDMSG with an
    IPMSG_SENDCHECKOPT flag.
    However, Send Message uses an IPMSG_ANSREADMSG command,
    not IPMSG_RECVMSG.

  3) Message Send/Receive 亅encrypted extension (Added in the version-9 )

    Use the combination of Public-key(RSA) and common key(RC2/Blowfish).
    (Encrypted extension area is used in hex format.)

    (Public key acquisition)Send an IPMSG_GETPUBKEY command to Receive
    Message. Receive Message gets an IPMSG_ANSPUBKEY that
    means receiving RSA public key from Send Message.

    IPMSG_GETPUBKEY/IPMSG_ANSPUBKEY both require the value which is
    encryption capability (Exp. IPMSG_RSA_1024) flag uses "OR" at first
    part of extension

    In addition, In IPMSG_ANSPUBKEY, public key written as EE-NNNNNN
    E=Exponent丄N=method)devide by '
:'. and Input the Fdelimiter '-'
    between E and N.

    This sequence can be skipped after the 2nd Send/Receive process by
    memorizing public key and encrypted data.
   
    (Encrypted message)After a sender creates a common key that is
    supported both sender and receiver, a common key can encrypt a message.
    In addition, a receiver'
s public key encrypts the common key.


    (Encrypted message transmission) IPMSG_ENCRYPTOPT is used in
    IPMSG_SENDMSG. At the first part of extension, input the value which
    is 'or' resoult from Convination of public key and common key type .
    Then use common key which encrypt with public key devide by ':'.
    Then input message which is eccrypted by public key devide by ':'.
    If both supports IPMSG_SIGN_XXX, then add ':' and signeture.

    Also, In the method of encode padding, PKCS#1ECB key is used for RSA,
    PKCS#5 CBC common key is used for RC2/blowfish.

    Also, The Packet related to Entry manifestation the capability of
    ecryption support using IPMSG_ENCRYPTOPT

  4) Extension with file attachment(Available from version-9 )

    An IPMSG_SENDMSG command with an IPMSG_FILEATTACHOPT flag for
    File transfer (download permission)notification sends a message
    with attachment.
    Input '\0' after the message and attachment file data.
   

    fileID:filename:size:mtime:fileattr[:extend-attr=val1
    [,val2...][:extend-attr2=...]]:\a:fileID...
    (size, mtime, and fileattr describe hex format.
      If a filename contains ':', please replace with "::".)

    When Receive Message downloads an attachment file, an IPMSG_GETFILEDATA
    command requests a data transmission packet to the TCP port that is the same number
    as the UDP sending port number. Input packetID:fileID: offset to the extended area.
    (Use all hex format.)
    File Transfer side receives the request. After recognizing that it's a correct request,
    then send the specified data (no format)

    When the data receiving side downloads a hierarchical attachment file,
    use an IPMSG_GETDIRFILES command and input a packetID:fileID
    to the extended area and send a data transmission request packet.
    (all hex format)

    Data sending side sends the following hierarchical data format.
    header-size:filename:file-size:fileattr[:extend-attr=val1
    [,val2...][:extend-attr2=...]]:contents-data
    Next headersize: Next filename...
    (All hex format except for filename and contetns-data)

    header-size is from the beginning of header-size to the delimiter '
:'
    that is before contents-data. extend-attr can be omitted and used multiple
    extended attributes. Use '
=' for data input.

    When fileattr is IPMSG_FILE_DIR, IPMsg recognizes that it is automatically
    in the directory, the next file data is after the directory.

    When fileattr is IPMSG_FILE_RETPARENT, IMPsg recognizes that it returns
    to the parent directory. In this case, File name is always "." and the attribute
    value is the current directory data.

    Sending process starts from the attachment directly and returns the
    IPMSG_FILE_RETPARENT command to the attachment directory.

    Add an IPMSG_FILEATTACHOPT flag for an Entry packet to support the
    attachment file.

  5) Other commands

    When acquiring different versions, send an IPMSG_GETINFO command.
    Receiving side sends the version information character string to
    extended area.

    Send an IPMSG_GETABSENCEINFO command for acquiring an absence message.
    Receiving side sends an IPMSG_SENDABSENCEINFO back if the status is absence mode.
    If the status is not absence mode, a character string "Not absence mode" will be sent back.

  6) Confirmation/Retry

    If a confirmation packet for IPMSG_SENDMSG or IPMSG_RECVMSG is not delivered
    within a specified time, then it will be sent again.
    A number of retry actions or interval period is depended on the current condition.


4. Other

  1) Linefeed

    Linefeed characters in Send Message is standardized with UNIX type ('
0x0a').
    Please change if needed.

  2) Delimiter '
:'

    '
:' is used as a delimiter. You can't use this delimiter for user name
    and host name.
    If the use/host names contain a ':', please replace with another sign,
    for an example ';'.
    Although using this delimiter isn

posted on 2010-01-07 11:15 ChinaPanda 閱讀(596) 評論(0)  編輯 收藏 引用

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲欧美国产制服动漫| 国产精品永久免费观看| 亚洲午夜三级在线| 夜夜嗨av一区二区三区网页| 欧美激情综合色| 亚洲大胆美女视频| 欧美www在线| 亚洲国产三级网| 一个色综合导航| 午夜视频一区二区| 久久这里有精品视频| 国产一区二区三区无遮挡| 国内精品一区二区三区| 1000部精品久久久久久久久| 亚洲精品国产精品国自产观看| 亚洲伦理在线观看| 中文久久精品| 欧美在线观看网站| 欧美高清视频免费观看| 99人久久精品视频最新地址| 亚洲欧美日本视频在线观看| 久久全国免费视频| 欧美午夜精品| 亚洲国产精品国自产拍av秋霞| 日韩午夜中文字幕| 久久国产一区二区| 亚洲美女视频| 久久成人18免费观看| 欧美国产日韩一区二区三区| 国产日韩欧美一区二区三区四区| 亚洲国产精品久久| 性做久久久久久久免费看| 欧美日韩八区| 欧美一区二区在线免费播放| 久久综合九色综合欧美狠狠| 欧美色播在线播放| 亚洲福利一区| 久久精品99无色码中文字幕| 亚洲国产成人精品久久| 亚洲综合二区| 欧美三级电影大全| 亚洲国产精品v| 久久精品国产99国产精品澳门| 亚洲人成人一区二区三区| 久久亚洲不卡| 韩日午夜在线资源一区二区| 亚洲午夜影视影院在线观看| 欧美成人四级电影| 欧美一级播放| 国产精品日韩欧美大师| 一区二区国产精品| 欧美黄色精品| 久久综合影音| 加勒比av一区二区| 久久深夜福利免费观看| 午夜精品免费在线| 国产伦精品一区二区三区高清| 一区二区日本视频| 亚洲国产高清一区| 欧美va亚洲va日韩∨a综合色| 狠狠爱综合网| 久久午夜色播影院免费高清| 欧美亚洲在线播放| 国产一区二区三区直播精品电影| 亚洲视频一二| 野花国产精品入口| 国产精品高清在线| 午夜亚洲福利| 欧美在线视频网站| 影音先锋久久久| 美腿丝袜亚洲色图| 免费不卡在线观看av| 99在线热播精品免费| 99ri日韩精品视频| 国产精品一区久久久| 久久蜜桃香蕉精品一区二区三区| 欧美亚洲一级| 亚洲精品在线二区| 99精品99| 国产视频亚洲精品| 欧美黄免费看| 欧美日韩中文字幕精品| 欧美一级播放| 久久国产精品久久精品国产| 亚洲国产第一| 一区二区精品国产| 国产亚洲网站| 亚洲高清毛片| 国产精品福利网站| 久久久九九九九| 欧美激情综合色| 亚洲欧美日韩国产综合在线 | 亚洲综合色丁香婷婷六月图片| 欧美午夜一区二区福利视频| 久久爱另类一区二区小说| 久久都是精品| 日韩亚洲欧美精品| 亚洲自拍高清| 亚洲乱码精品一二三四区日韩在线 | 国产日本亚洲高清| 欧美激情一区二区三区高清视频| 亚洲人精品午夜在线观看| 宅男精品视频| 1024成人网色www| 亚洲色诱最新| 亚洲国产精品久久久久| 亚洲网站视频| 亚洲三级影院| 久久久久久久综合| 午夜精品久久久久久久久久久| 久久只精品国产| 久久精品视频免费| 国产精品成人在线观看| 亚洲国产高清一区二区三区| 国内精品伊人久久久久av影院| 99国产精品| 日韩一级黄色大片| 美国成人直播| 猛男gaygay欧美视频| 国产欧美一区二区三区另类精品| 亚洲国产精品成人| 黄页网站一区| 亚洲综合999| 亚洲欧美精品一区| 欧美日在线观看| 亚洲日本成人在线观看| 亚洲国产高清在线| 欧美亚洲午夜视频在线观看| 亚洲一区二区在线| 欧美女同视频| 亚洲欧洲一区二区三区久久| 亚洲成人自拍视频| 美女黄毛**国产精品啪啪| 美脚丝袜一区二区三区在线观看| 国产午夜精品全部视频播放| 亚洲视频一区二区| 亚洲影视在线播放| 国产精品99一区二区| 一本久久青青| 亚洲私人黄色宅男| 欧美午夜不卡影院在线观看完整版免费 | 免费久久精品视频| 国内精品免费午夜毛片| 性做久久久久久免费观看欧美| 亚洲影院在线观看| 国产女同一区二区| 欧美一区二区三区四区在线观看地址| 午夜精品免费| 亚洲欧美精品suv| 国产精品亚洲视频| 一区二区三区波多野结衣在线观看| 日韩视频一区二区三区在线播放| 免费成人在线视频网站| 欧美激情视频在线播放| 99精品视频一区二区三区| 欧美日本在线播放| 99re66热这里只有精品3直播 | 欧美在线视频免费观看| 久久久久久综合| 尤物99国产成人精品视频| 久久先锋影音av| 欧美一区在线直播| 欧美成人精品福利| 亚洲视频精品在线| 国产欧美日韩在线视频| 美女网站久久| 妖精成人www高清在线观看| 欧美中文字幕不卡| 亚洲国产欧美在线| 国产精品国产三级国产专区53| 欧美一区二区三区免费观看视频| 毛片一区二区三区| 亚洲一区二区成人| 国产一区视频观看| 免费成人网www| 亚洲你懂的在线视频| 欧美二区在线| 亚洲愉拍自拍另类高清精品| 精品88久久久久88久久久| 欧美精品18+| 午夜在线a亚洲v天堂网2018| 欧美激情中文不卡| 久久精品视频亚洲| 亚洲一区免费看| 亚洲国产精品一区二区三区| 欧美日韩亚洲国产精品| 久久超碰97中文字幕| 亚洲理论在线| 美腿丝袜亚洲色图| 欧美一区二区三区四区在线观看 | 这里只有精品丝袜| 国产综合精品| 欧美性猛交xxxx乱大交退制版| 久久久在线视频| 亚洲图片自拍偷拍| 亚洲精品一区在线| 欧美18av| 狼人社综合社区| 久久aⅴ国产欧美74aaa| 亚洲小视频在线|