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

SpringBoot輕松整合WebSocket實現Web在線聊天室

開發 架構
我們就把Spring Boot整合WebSocket,實現BBS聊天室的功能介紹完了。WebSocket能夠以非常簡單的方式,實現客戶端與服務器端的雙向通訊。在實際項目開發過程中使用越來越廣泛,希望大家能熟悉掌握。

前面為大家講述了 Spring Boot的整合Redis、RabbitMQ、Elasticsearch等各種框架組件;隨著移動互聯網的發展,服務端消息數據推送已經是一個非常重要、非常普遍的基礎功能。今天就和大家聊聊在SpringBoot輕松整合WebSocket,實現Web在線聊天室,希望能對大家有所幫助。

一、WebSocket簡介

1.1 什么是WebSocket?

WebSocket協議是基于TCP的一種網絡協議,它實現了瀏覽器與服務器全雙工(Full-duplex)通信。它允許服務端主動向客戶端推送數據,這使得客戶端和服務器之間的數據交換變得更加簡單高效。在WebSocket API中,瀏覽器和服務器只需要完成一次握手,兩者之間就可以創建持久性的連接,并進行雙向數據傳輸。

圖片

WebSocket 在握手之后便直接基于 TCP 進行消息通信,只是 TCP的基礎上的一層非常輕的封裝,它只是將TCP的字節流轉換成消息流(文本或二進制),至于怎么解析這些消息的內容完全依賴于應用本身。

1.2 為什么需要 WebSocket?

我們知道HTTP 協議有一個缺陷:通信只能由客戶端發起,服務器端無法向某個客戶端推送數據。然而,在某些場景下,數據推送是非常必要的功能,為了實現推送技術,所用的技術都是輪詢,即:客戶端在特定的的時間間隔(如每 1 秒),由瀏覽器對服務器發出 HTTP 請求,然后由服務器返回最新的數據給客戶端的瀏覽器。

例如,在外賣場景下,當騎手位置更新時,服務器端向客戶端推送騎手位置數據。如果使用HTTP協議,那么就只能輪詢。輪詢模式具有很明顯的缺點,即瀏覽器需要不斷地向服務器發出請求,然而 HTTP 請求可能包含較長的頭部,其中真正有效的數據可能只是很小的一部分,顯然這樣會浪費很多的帶寬等資源,同樣,數據時效性較低,存在一定的數據延遲。

在這種情況下,WebSocket 出現了,使用 WebSocket 協議可以實現由服務端主動向客戶端推送消息,同時也可以實現客戶端向服務器端發送消息。這樣能更好得節省服務器資源和帶寬;并且能夠更實時地進行通訊。隨著HTML 5 的流行, WebSocket已經成為國際標準,目前主流的瀏覽器都已經支持。

1.3 WebSocket的優點

  • 較少的控制開銷。在連接建立后,服務端和客戶端之間交換數據時,用于協議控制的數據包頭部相對較小。在不包含擴展的情況下,對于服務器到客戶端的內容,此頭部大小只有 2 至 10 字節(和數據包長度有關);對于客戶端到服務器的內容,此頭部還需要加上額外的 4 字節的掩碼。這相對于 HTTP 協議每次都要攜帶完整的頭部信息,此項開銷顯著減少了。
  • 更強的實時性。由于WebSocket協議是全雙工的,所以服務器可以隨時主動向客戶端推送數據。相對于 HTTP 請求必須等待客戶端發起請求服務端才能響應,延遲明顯更少;即使是和Comet 等類似的長輪詢比較,WebSocket也能在短時間內更高效的傳遞數據。
  • 保持連接狀態。與 HTTP 不同的是, Websocket 需要先創建連接,這就使得其成為一種有狀態的協議,之后通信時可以省略部分狀態信息,而 HTTP 請求需要在每個請求都攜帶狀態信息(如Token等)。
  • 更好的二進制支持。 Websocket 定義了二進制幀,相對 HTTP,可以更輕松地處理二進制數據。Websocket 定義了擴展,用戶可以擴展協議、實現部分自定義的子協議。如部分瀏覽器支持Gzip壓縮等。
  • 更好的壓縮效果。相對于 HTTP 壓縮, Websocket 在適當的擴展支持下,可以沿用之前內容的上下文,在傳遞類似的數據時,可以顯著地提高壓縮率。

1.4 WebSocket的應用場景

隨著移動互聯網的發展,WebSocket的使用越來越廣泛。基本上只要是時效性要求高的業務場景都可以使用WebSocket,例如:

  • 協同編輯
  • 基于位置的應用
  • 體育實況更新
  • 股票基金報價實時更新
  • 多玩家游戲
  • 音視頻聊天
  • 視頻會議
  • 在線教育
  • 社交訂閱

除此之外,還有系統消息通知、用戶上下線提醒、客戶端數據同步,實時數據更新,多屏幕同步,用戶在線狀態,消息掃描二維碼登錄/二維碼支付,彈幕、各類信息提醒,在線選座,實時監控大屏等等;

二、WebSocket的事件

我們知道HTTP協議使用http和https的統一資源標志符。WebSocket與HTTP類似,使用的是 ws 或 wss(類似于 HTTPS),其中 wss 表示在 TLS 之上的Websocket。例如:

ws://example.com/wsapiwss://secure.example.com/

WebSocket 使用和 HTTP 相同的 TCP 端口,可以繞過大多數防火墻的限制。默認情況下, WebSocket 協議使用80 端口;運行在 TLS 之上時,默認使用 443 端口。

WebSocket 只是在 Socket 協議的基礎上,非常輕的一層封裝。在WebSocket API中定義了open、close、error、message等幾個基本事件,這就使得WebSocket使用起來非常簡單。 下面是在WebSocket API定義的事件:

事件

事件處理程序

描述

open

Sokcket onopen

連接建立時觸發

message

Sokcket onmessage

客戶端接收服務端數據時觸發

error

Sokcket onerror

通訊發生錯誤時觸發

close

Sokcket onclose

連接關閉時觸發


三、Spring Boot整合WebSocket實現聊天室

Spring Boot 提供了 Websocket 組件 spring-boot-starter-websocket,用來支持在 Spring Boot環境下對Websocket 的使用。

下面我們就以多人在線聊天室為例,演示 Spring Boot 是如何整合Websocket 實現服務端消息推送的。

3.1 創建前端頁面

首先,創建spring boot項目:spring-boot-starter-websocket。接下來,我們構建前臺交互頁面,創建index.html頁面并在 js 中實現WebSocket通訊,完整頁面代碼如下所示:



<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head>    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />    <title>Chat Room</title>    <script type="text/javascript">        var urlPrefix ='ws://localhost:8080/chat/';        var ws = null;        // 加入function join() {            var username = document.getElementById('uid').value;            var url = urlPrefix + username;            ws = new WebSocket(url);function(event){                var ta = document.getElementById('responseText');                ta.value += event.data+"\r\n";            };function(event){                var ta = document.getElementById('responseText');                ta.value += "建立 websocket 連接... \r\n";            };function(event){                var ta = document.getElementById('responseText');                ta.value += "用戶["+username+"] 已經離開聊天室! \r\n";                ta.value += "關閉 websocket 連接. \r\n";            };        }
// 退出function exit(){ if(ws) { ws.close(); } }
// 發送消息function send(){ var message = document.getElementById('message').value; if(!window.WebSocket){return;} if(ws.readyState == WebSocket.OPEN){ ws.send(message); }else{ alert("WebSocket 連接沒有建立成功!"); } }</script></head><body><form onSubmit="return false;"> <h3>BBS聊天室</h3> <textarea id="responseText" style="width: 1024px;height: 300px;"></textarea> <br/> <br /> <label>昵稱 : </label><input type="text" id="uid" />   <input type="button" value="加入聊天室" onClick="join()" />  
<input type="button" value="離開聊天室" onClick="exit()" /> <br /> <br /> <label>消息 : </label><input type="text" id="message" />   <input type="button" value="發送消息" onClick="send()" /></form></body></html>

上面的示例中,js中定義了WebSocket通訊相關的代碼,如:ws.onopen、ws.onmessage、ws.onclose等事件。

3.2 創建后端服務

接下來,我們開始創建后臺WebSocket服務,實現WebSocket后臺通訊服務。

step 1 :引入相關依賴

首先,修改項目的pom.xml文件,主要添加 Web 和 Websocket 組件。具體代碼如下所示:

<dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-web</artifactId>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-websocket</artifactId>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-test</artifactId>            <scope>test</scope>        </dependency>

step2:消息接收

首先創建ChatServerEndpoint類,并使用@ServerEndpoint注解創建WebSocket EndPoint實現客戶端連接、消息的接收、等事件。具體示例代碼如下所示:

@RestController@ServerEndpoint("/chat/{username}")public class ChatServerEndpoint {    private static final Logger logger = LoggerFactory.getLogger(ChatRoomServerEndpoint.class);
@OnOpen public void openSession(@PathParam("username") String username, Session session) { ONLINE_USER_SESSIONS.put(username, session); String message = "歡迎用戶[" + username + "] 來到聊天室!"; logger.info("用戶登錄:"+message); sendMessageAll(message); }
@OnMessage public void onMessage(@PathParam("username") String username, String message) { logger.info("發送消息:"+message); sendMessageAll("用戶[" + username + "] : " + message); }
@OnClose public void onClose(@PathParam("username") String username, Session session) { //當前的Session 移除 ONLINE_USER_SESSIONS.remove(username); //并且通知其他人當前用戶已經離開聊天室了 sendMessageAll("用戶[" + username + "] 已經離開聊天室了!"); try { session.close(); } catch (IOException e) { logger.error("onClose error",e); } }
@OnError public void onError(Session session, Throwable throwable) { try { session.close(); } catch (IOException e) { logger.error("onError excepiton",e); } logger.info("Throwable msg "+throwable.getMessage()); }}

上面的示例中,我們使用 @ServerEndpoint("/chat/{username}") 注解監聽此地址的 WebSocket 信息,客戶端也是通過此地址向服務端接收和發送消息。同時使用@OnOpen?注解實現客戶端連接事件,@OnMessage?注解實現消息發送事件,@OnClose?注解實現客戶端連接關閉事件,@OnError注解實現消息錯誤事件。

step3:消息發送

我們先創建一個 WebSocketUtils 工具類,用來存儲聊天室在線的用戶信息,以及向客戶端發送消息的功能。具體代碼如下所示:

public final class WebSocketUtils {    private static final Logger logger = LoggerFactory.getLogger(WebSocketUtils.class);
// 存儲 websocket session public static final Map<String, Session> ONLINE_USER_SESSIONS = new ConcurrentHashMap<>();
/** * @param session 用戶 session * @param message 發送內容 */public static void sendMessage(Session session, String message){ if (session == null) { return; } final RemoteEndpoint.Basic basic = session.getBasicRemote(); if (basic == null) { return; } try { basic.sendText(message); } catch (IOException e) { logger.error("sendMessage IOException ",e); } }
/** * 推送消息到其他客戶端 * @param message */public static void sendMessageAll(String message){ ONLINE_USER_SESSIONS.forEach((sessionId, session) -> sendMessage(session, message)); }}


step4:開啟 WebSocket 功能

修改項目啟動類,需要添加 @EnableWebSocket 開啟 WebSocket 功能。具體示例代碼如下所示:

@EnableWebSocket@SpringBootApplicationpublic class WebSocketApplication {
public static void main(String[] args){ SpringApplication.run(WebSocketApplication.class, args); }
@Beanpublic ServerEndpointExporter serverEndpointExporter(){ return new ServerEndpointExporter(); }}

以上,我們WebSocket服務端內容就實現完畢了。接下來我們驗證整個聊天室功能是否正常?

3.3 驗證測試

前面,我們已經把整個WebSocket聊天室的前后臺功能介紹完了。接下來我們驗證整個聊天室功能是否正常?

首先,啟動項目,在瀏覽器中分別輸入地址:http://localhost:8080/ 打開三個聊天室頁面。如下圖所示:

圖片


然后,分別在三個聊天室頁面中,輸入三個昵稱并加入聊天室,與服務端成功建立WebSocket連接,即可在聊天室發送消息。

圖片

點擊頁面上的離開聊天室,此頁面與服務端建立的WebSocket連接就會斷開。其他連接不受影響。

圖片

最后

以上,我們就把Spring Boot整合WebSocket,實現BBS聊天室的功能介紹完了。WebSocket能夠以非常簡單的方式,實現客戶端與服務器端的雙向通訊。在實際項目開發過程中使用越來越廣泛,希望大家能熟悉掌握。


責任編輯:武曉燕 來源: 架構師精進
相關推薦

2023-01-05 09:17:58

2023-02-10 08:16:48

WebSocket簡易聊天室

2022-07-26 14:53:10

WebSocket網絡通信協議

2025-05-09 08:35:00

聊天室FastAPIWebSocket

2024-09-11 08:35:54

2011-06-09 15:44:29

Spring

2025-05-09 08:34:57

RSocketSpringBoot聊天系統

2011-12-15 11:11:51

JavaNIO

2022-11-14 08:01:48

2015-07-06 10:42:18

PHP聊天室應用

2021-10-14 18:46:29

Websocket瀏覽器API

2023-08-09 08:01:00

WebSockett服務器web

2021-11-16 09:38:10

鴻蒙HarmonyOS應用

2022-12-01 08:25:23

eTsTCP聊天室

2011-11-30 16:37:58

sync

2021-03-26 08:16:32

SpringbootWebsocket前端

2015-08-06 17:17:33

swoole聊天室

2024-10-07 10:45:12

2022-04-18 10:36:48

社交軟件聊天平臺rocket.cha
點贊
收藏

51CTO技術棧公眾號

人人超在线公开视频| 在线观看xxxx| 老牛影视av一区二区在线观看| 一区二区三区中文字幕在线观看| 成人资源av| 日韩黄色三级视频| 国产成人手机高清在线观看网站| 欧美三级乱人伦电影| 法国空姐在线观看免费| 神马久久久久久久久久| 日韩国产一区二| 久久精品福利视频| 国产精品一区二区在线免费观看| 中国色在线日|韩| 中文字幕av不卡| 99re视频| 中文字幕激情视频| 亚洲欧美一级二级三级| 亚洲毛片在线看| 中文字幕国产高清| gogo高清午夜人体在线| 91老师片黄在线观看| 91日本在线视频| 久久久国产精品成人免费| 色狮一区二区三区四区视频| 亚洲成人久久一区| 91精品999| 亚洲欧美韩国| 夜夜嗨av一区二区三区四季av| 欧美日韩在线播放一区二区| 精品人妻无码一区二区| 日韩精彩视频在线观看| 欧美精品999| 精品视频第一页| 一本色道久久综合亚洲精品酒店| 日韩一区二区高清| 亚洲综合欧美在线| 波多野结衣亚洲一二三| 一区二区三区四区中文字幕| 日韩一本精品| 日韩精品福利| 成人精品高清在线| 亚洲最大的免费| 中文字幕 视频一区| 亚洲欧美日本日韩| 久久久免费精品视频| 亚洲波多野结衣| 亚洲欧美tv| 亚洲成人av在线| 国产毛片久久久久久| 日韩一区二区三区在线免费观看 | 日韩手机在线观看视频| a级影片在线| 欧美极品美女视频| 日韩国产高清一区| 黄色片在线免费观看| 成人av网址在线| 国产高清在线一区| 国产99久一区二区三区a片| 蜜臀99久久精品久久久久久软件 | 成人性生交大片免费网站| 亚洲一区影音先锋| 久久久久久av无码免费网站下载| 免费在线观看av片| 国产精品护士白丝一区av| 性欧美.com| 二区在线视频| 中文字幕第一区第二区| 视频一区三区| a中文在线播放| 国产女人18毛片水真多成人如厕| 欧美一区二区福利| 国产精品99999| 欧美国产综合色视频| 五月天久久综合网| 精品国产99久久久久久| 亚洲天堂av一区| 在线免费观看成人网| 成人在线影视| 一级中文字幕一区二区| www.日本在线视频| 爱情岛亚洲播放路线| 香蕉加勒比综合久久| 国产免费黄色av| 在线观看欧美日韩电影| 欧美主播一区二区三区美女| 99热一区二区| 免费看一区二区三区| 欧美一区中文字幕| 337p日本欧洲亚洲大胆张筱雨| 成人av婷婷| 精品在线欧美视频| 国产一二三四区在线| 婷婷亚洲五月色综合| 粗暴蹂躏中文一区二区三区| 久久午夜无码鲁丝片| 国产精品呻吟| 国产伦精品一区二区三区精品视频| 国产精品视频一二区| 国产成人午夜片在线观看高清观看| 国产精品区免费视频| 精品av中文字幕在线毛片| 国产精品久久久久久久蜜臀| 中国黄色录像片| 9765激情中文在线| 欧美伊人久久久久久久久影院| 免费成人黄色大片| 久久91在线| 中文字幕精品av| 欧美精品入口蜜桃| 小嫩嫩精品导航| 91在线视频导航| 青青青草原在线| 最近中文字幕一区二区三区| 九一国产精品视频| 亚洲男男av| 日韩精品欧美国产精品忘忧草 | 国产最新精品精品你懂的| 国产精品theporn88| 欧美新色视频| 亚洲免费观看高清完整版在线观看 | 国产无遮无挡120秒| 免费在线观看日韩欧美| 国产精品对白刺激久久久| 成人免费一区二区三区视频网站| 亚洲精品乱码久久久久久久久| 欧美极品欧美精品欧美图片| 日本免费一区二区视频| 尤物tv国产一区| 日韩黄色a级片| 国产一二精品视频| 日韩欧美手机在线| 黄毛片在线观看| 欧美一区日本一区韩国一区| 日本二区在线观看| 一本久道久久综合婷婷鲸鱼| 91亚洲精品久久久久久久久久久久| 日本福利片高清在线观看| 亚洲综合激情另类小说区| av亚洲天堂网| 国产aⅴ精品一区二区三区久久| 欧美精品videosex牲欧美| 一级二级三级视频| 国产欧美日韩激情| 黄色片视频在线播放| 国产精品欧美大片| 欧美日韩aaaa| 国产精品视频在线观看免费| 中文字幕免费观看一区| 欧美视频第三页| 人人香蕉久久| 韩国日本不卡在线| 刘亦菲久久免费一区二区| 亚洲精品久久久久久国产精华液| www.超碰97.com| 日韩中文首页| 国产精品中文在线| 色的视频在线免费看| 欧美性猛片aaaaaaa做受| mm131美女视频| 国产婷婷精品| 加勒比在线一区二区三区观看| 欧美videos另类精品| 欧美本精品男人aⅴ天堂| 欧美成人三级在线观看| 国产999精品久久| 国产欧美精品aaaaaa片| 91九色鹿精品国产综合久久香蕉| 欧美黑人又粗大| 亚洲国产一二三区| 亚洲国产日韩在线一区模特 | 国产suv一区二区三区88区| 久久免费一级片| 亚洲国产aⅴ精品一区二区| 久久久久九九九九| 天天操天天干天天爱| 精品美女国产在线| a天堂中文字幕| 蜜臀久久99精品久久久久宅男| 亚洲一区三区视频在线观看| 国产亚洲观看| 久久久久久久久久国产| 日本不卡视频一区二区| 欧美亚洲日本一区| www.毛片com| 成人免费av资源| 亚洲国产精品久久久久爰色欲| 精品国产精品| 成人动漫网站在线观看| 狂野欧美性猛交xxxxx视频| 亚洲成人网在线观看| 国产黄色免费视频| 亚洲婷婷综合久久一本伊一区| 无码人妻丰满熟妇区毛片蜜桃精品 | 国产精品久久久久久久久久妞妞| 欧美久久久久久一卡四| 四虎影视精品永久在线观看| 欧美国产中文字幕| 日本啊v在线| 91精品国产综合久久精品图片 | 久久久久久综合网天天| 欧美色图另类| 7777精品久久久大香线蕉| 日韩欧美a级片| 亚洲国产电影在线观看| 欧美日韩一区二区区| 久久国产精品99国产| 宅男噜噜99国产精品观看免费| 超碰97久久| 国产精品视频网站| 超碰中文在线| 伊人伊人伊人久久| 黑人精品一区二区三区| 在线观看免费视频综合| 久久免费小视频| 国产精品久久久久久久久久免费看 | av网站免费在线看| 国产精品18久久久久久久久久久久 | 欧美超碰在线观看| 亚洲影院久久精品| 天堂网av2018| kk眼镜猥琐国模调教系列一区二区| 999在线免费视频| 亚洲国产黄色| 艳母动漫在线观看| 国产亚洲电影| 国产伦精品一区二区三区| 只有精品亚洲| 国产精品pans私拍| 黄色软件视频在线观看| 欧美裸身视频免费观看| 成人精品一区二区三区免费| 亚洲第一级黄色片| jizz国产视频| 欧美日韩国产首页| 天天射天天干天天| 欧美日韩一区免费| 久久在线视频精品| 一区二区三区高清不卡| 永久免费看mv网站入口| 中文无字幕一区二区三区| 欧美色图亚洲激情| 99久久精品久久久久久清纯| 国产a√精品区二区三区四区| 另类欧美日韩国产在线| 免费一级特黄录像| 天堂av在线一区| 男人日女人bb视频| 亚洲影音一区| 妞干网在线观看视频| 国产精品va| 欧美一区二区三区综合| 在线中文一区| 国产一二三四五| 91av精品| 中文字幕av久久| 亚洲最新色图| 日韩video| 午夜精品亚洲| 免费视频爱爱太爽了| 欧美日韩综合| 少妇久久久久久被弄到高潮| 欧美午夜视频| 激情小视频网站| 亚洲精品看片| 国产91在线视频观看| 欧美综合国产| 黄色片在线免费| 蜜桃在线一区二区三区| 久久国产激情视频| 国产真实乱偷精品视频免| 亚洲精品久久久久久| 懂色av一区二区三区蜜臀| 美女伦理水蜜桃4| 95精品视频在线| 一区二区黄色片| 国产欧美日韩综合| 成人信息集中地| 亚洲精品欧美专区| 日韩精品一卡二卡| 色噜噜狠狠成人中文综合| 一区二区三区麻豆| 88在线观看91蜜桃国自产| 99久久国产热无码精品免费| 精品日韩av一区二区| 天天干天天爽天天操| 永久免费精品影视网站| 男人天堂久久久| 欧美夫妻性生活视频| sis001欧美| 91精品视频网站| 福利在线一区| 欧美日韩另类综合| 99久久www免费| 日韩 欧美 视频| 日日摸夜夜添夜夜添亚洲女人| 亚洲午夜激情影院| 99re这里只有精品视频首页| 日本理论中文字幕| 一区二区三区四区五区视频在线观看| 日本在线视频中文字幕| 欧美日韩国产影片| 日本高清视频网站| 中文字幕九色91在线| 青青草视频在线免费直播| 日本高清+成人网在线观看| 亚洲我射av| 久久久影院一区二区三区| 国产精品久久久久久麻豆一区软件 | 少妇精品久久久久久久久久| 欧美日韩a区| 国产三级三级三级看三级| 国产91精品在线观看| 国产精成人品免费观看| 亚洲无人区一区| 中文 欧美 日韩| 精品播放一区二区| 日本高清在线观看wwwww色| 97精品国产97久久久久久免费| 精品女同一区二区三区在线观看| 豆国产97在线| 国产精品久久久久蜜臀| 国产精品第12页| 成人午夜激情视频| 911国产在线| 在线看日本不卡| 好男人在线视频www| 久久久国产精品视频| 亚洲伦乱视频| 激情小说综合区| 国产一区二区三区四区三区四| 8x8x成人免费视频| 国产三级精品三级| 九九热在线视频播放| 日韩精品一区在线观看| 黄色一级片在线观看| 国产精品久久久久久五月尺 | 六月婷婷久久| 在线精品亚洲| 好吊操视频这里只有精品| 亚洲私人黄色宅男| 中文字幕乱码在线观看| 亚洲视频999| 伊人色综合一区二区三区影院视频| 成人一区二区在线| 女人天堂亚洲aⅴ在线观看| 免费成人黄色大片| 成人欧美一区二区三区白人| 中文在线观看av| 亚洲午夜精品久久久久久性色| 欧美gv在线观看| 国产区一区二区三区| 激情欧美亚洲| 秘密基地免费观看完整版中文 | 午夜一级免费视频| 国产精品美女久久久久久久久久久 | 亚洲va久久久噜噜噜久久| 国产精品久久中文字幕| 成人深夜视频在线观看| 久久久久成人精品无码| 日韩美女一区二区三区| 女同一区二区免费aⅴ| av一区二区在线看| 黄页网站一区| 亚洲自拍偷拍精品| 亚洲成人精品在线观看| 深夜福利视频一区| 国产成人午夜视频网址| 精品美女在线视频| 国产精品入口免费软件| 国产精品久久久久久久久免费相片 | 色悠悠久久综合| 男人av在线| 国产精品视频一区国模私拍| 97精品在线| 日韩久久久久久久久久久| 一区二区三区av电影| 手机看片1024国产| 日本人成精品视频在线| 色999国产精品| 日韩精品xxx| 婷婷开心激情综合| 蜜桃成人在线视频| 成人黄色在线观看| 欧美精品一级| 亚洲天堂资源在线| 在线免费观看成人短视频| 欧美96在线| 官网99热精品| 模特精品在线| 成人做爰视频网站| 亚洲精品一区二区三区精华液 | 香蕉精品久久| jizz大全欧美jizzcom| 一区二区三区四区乱视频| 亚洲av成人精品毛片| 国产精品吴梦梦| 欧美午夜一区| 四季av中文字幕| 精品免费日韩av|