日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

摆脱客户端?网页发起直播势在必行!

發布時間:2024/3/13 编程问答 65 豆豆
生活随笔 收集整理的這篇文章主要介紹了 摆脱客户端?网页发起直播势在必行! 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

背景

近幾年直播行業飛速發展,但是由于Web端這方面功能的長時間缺失,使得直播端以客戶端為主;WebRTC 的出現使得網頁也可以成為直播端。那么究竟WebRTC是什么呢?

WebRTC,即Web Real-Time Communication,web實時通信技術。簡單地說就是在web瀏覽器里面引入實時通信,包括音視頻通話等,它使得實時通信變成一種標準功能,任何Web應用都無需借助第三方插件和專有軟件,而是通過JavaScript API即可完成;而且WebRTC提供了視頻會議的核心技術,包括音視頻的采集、編解碼、網絡傳輸、展示等功能,還支持跨平臺,包括主流的PC和移動端設備。

下面介紹下需要用到的幾個API:

getUserMedia

我們可以通過調用navigator.mediaDevices.getUserMedia(constraints)去初始化一個本地的音視頻流,然后把直播流通過video標簽播放。代碼如下:

html:

<div id="container"><video id="gum-local" autoplay playsinline></video><button id="showVideo">Open camera</button><button id="switchVideo">switch camera</button> </div>

js:

const constraints = {audio: false,video: true };async function init(e) {try {const stream = await navigator.mediaDevices.getUserMedia(constraints);const video = document.querySelector('video');video.srcObject = stream;} catch (e) {console.log(e, 'stream init error');} } document.querySelector('#showVideo').addEventListener('click', (e) => init(e));

示例效果:

當然,如果有多個設備,就需要考慮設備選擇和設備切換的問題。那就需要用到下面的這個API。

設備

我們看看如何用原生的Web API去獲取設備(以下示例代碼可適用于Chrome,其他瀏覽器暫未測試;具體瀏覽器兼容性可參考官方文檔,本文檔底部有鏈接)。

navigator.mediaDevices.enumerateDevices()

如果枚舉成功將會返回一個包含MediaDeviceInfo實例的數組,它包含了可用的多媒體輸入輸出設備的信息。

下面是調用代碼示例。

navigator.mediaDevices.enumerateDevices().then((devices) => {console.log(devices, '-----enumerateDevices------'); });

設備參數說明:

  • deviceId:設備id,具有唯一性
  • groupId:設備組id,不具有唯一性
  • kind:設備類別(audioinput:音頻輸入設備,audiooutput:音頻輸出設備,videoinput:視頻輸入設備)
  • label:設備名稱(未經過授權允許的設備,label值為空,授權允許后可拿到label的值,如下兩圖所示)
  • 獲取的所有設備截圖(未授權):

    deviceInfo--所有設備信息(未授權)

    videoinput已授權截圖:

    videoinput授權后截圖

    獲取到設備列表后,可設置navigator.mediaDevices.getUserMedia(constraints)的constraints參數選擇所用設備。

    const { audioList, videoList } = await getDevices(); const constraints = {audio: {deviceId: audioList[0].deviceId},video: {deviceId: videoList[0].deviceId} }; navigator.mediaDevices.getUserMedia(constraints); ...

    然而,我們在更換deviceId切換設備的時候發現一些異常情況。在某些deviceId之間切換時,攝像頭畫面或者是麥克風采集處并沒有發生變化。進一步調試發現,這些切換后沒有發生變化的deviceId都具有相同的groupId。因此,相同groupId下的設備,選擇一個用于切換即可。

    篩選麥克風、攝像頭設備示例:

    function getDevices() {return new Promise((resolve) => {navigator.mediaDevices.enumerateDevices().then((devices) => {const audioGroup = {};const videoGroup = {};const cameraList = [];const micList = [];devices.forEach((device, index) => {if ((!device.groupId || !audioGroup[device.groupId]) && device.kind === 'audioinput') {micList.push(device);audioGroup[device.groupId] = true;}if ((!device.groupId || !videoGroup[device.groupId]) && device.kind === 'videoinput') {cameraList.push(device);videoGroup[device.groupId] = true;}});resolve({ cameraList, micList });});}); }

    注意:在Chrome下,電腦外接攝像頭后拔出設備,此時還有可能獲取到拔出的設備信息,在進行切換的時候會有問題,可以采用在頁面進行友好提示處理這種情況。

    屏幕共享

    MediaDevices.getDisplayMedia

    Chrome 72+、Firefox 66+版本已經實現了WebRTC規范中的MediaDevices.getDisplayMedia,具備屏幕共享功能。

    navigator.mediaDevices.getDisplayMedia({video: true,audio: false }).then(stream => {video.srcObject = stream; }).catch(err => {console.error(err); });

    示例效果:

    對于Chrome 72以下的版本,想要實現屏幕共享的功能需要借助Chrome插件去獲取screen(顯示器屏幕)、application windows(應用窗口)和browser tabs(瀏覽器標簽頁)。 Chrome插件:由manifest.json和script.js組成。

    manifest.json 填入一些基本數據。

    background中scripts傳入需執行的js文件。添加permissions: ['desktopCapture'],用來開啟屏幕共享的權限。externally_connectable用來聲明哪些應用和網頁可以通過`runtime.connect`和`runtime.sendMessage`連接到插件。 {"manifest_version": 2,"name": "Polyv Web Screensharing","permissions": [ "desktopCapture" ],"version": "0.0.1","background": {"persistent": false,"scripts": [ "script.js" ]},"externally_connectable": {"matches": ["*://localhost:*/*"]} }

    script.js

    // script.js chrome.runtime.onMessageExternal.addListener(function(request, sender, sendResponse) {if (request.getStream) {// Gets chrome media stream token and returns it in the response.chrome.desktopCapture.chooseDesktopMedia(['screen', 'window', 'tab'], sender.tab,function(streamId) {sendResponse({ streamId: streamId });});return true; // Preserve sendResponse for future use}} );

    在頁面中開始屏幕共享。通過chrome.runtime.sendMessage發送消息到Chrome插件調起屏幕共享。獲取到streamId后,通過mediaDevices.getUserMedia得到stream。

    const EXTENSION_ID = '<EXTENSION_ID>'; const video = $('#videoId'); chrome.runtime.sendMessage(EXTENSION_ID, { getStream: true }, res => {console.log('res: ', res);if (res.streamId) {navigator.mediaDevices.getUserMedia({video: {mandatory: {chromeMediaSource: 'desktop',chromeMediaSourceId: res.streamId}}}).then((stream) => {video.srcObject = stream;video.onloadedmetadata = function(e) {video.play();};})} else {// 取消選擇} });

    而Firefox 66版本以下,不需要像Chrome借助插件才能實現屏幕共享。Firefox 33之后可以直接通過使用mediaDevices.getUserMedia,指定約束對象mediaSource為screen、window、application來實現屏幕共享。不過在Firefox中,一次只能指定一種mediaSource。

    navigator.mediaDevices.getUserMedia({video: {mediaSource: 'window' } }).then(stream => {video.srcObject = stream; });

    傳輸

    WebRTC的RTCPeerConnection可以建立點對點連接通信,RTCDataChannel提供了數據通信的能力。

    WebRTC的點對點連接的過程為:

  • 呼叫端給接收端發送一個offer信息。在發送給接收端之前先調用setLocalDescription存儲本地offer描述。
  • 接收端收到offer消息后,先調用setRemoteDescription存儲遠端offer,再創建一個answer信息給呼叫端。
  • RTCDataChannel提供了send方法和message事件。使用起來與WebSocket類似。

    由于沒有服務器,以下代碼為呼叫端和接收端在同一頁面上,RTCPeerConnection對象之間是如何進行數據交互。

    // 創建數據通道 sendChannel = localConnection.createDataChannel('通道名稱', options); sendChannel.binaryType = 'arraybuffer';sendChannel.onopen = function() {sendChannel.send('Hi there!'); }; sendChannel.onmessage = function(evt) {console.log('send channel onmessage: ', evt.data); };// 遠端接收實例 remoteConnection = new RTCPeerConnection(servers); remoteConnection.onicecandidate = function(evt) {if (evt.candidate) {localConnection.addIceCandidate(new RTCIceCandidate(evt.candidate));} }; // 當一個RTC數據通道已被遠端調用createDataChannel()添加到連接中時觸發 remoteConnection.ondatachannel = function() {const receiveChannel = event.channel;receiveChannel.binaryType = 'arraybuffer';//接收到數據時觸發receiveChannel.onmessage = function(evt) {console.log('onmessage', evt.data); // log: Hi there!};receiveChannel.send('Nice!'); };// 監聽是否有媒體流 remoteConnection.onaddstream = function(e) {peerVideo.srcObject = e.stream; };localConnection.addStream(stream);// 創建呼叫實例 localConnection.createOffer().then(offer => {localConnection.setLocalDescription(offer);remoteConnection.setRemoteDescription(offer);remoteConnection.createAnswer().then(answer => {remoteConnection.setLocalDescription(answer);// 接收到answerlocalConnection.setRemoteDescription(answer);}) });

    至此我們已經介紹完畢瀏覽器設備檢測采集和屏幕分享的基本流程,但是光有這些可還遠遠不夠,一套完整的直播體系包括音視頻采集、處理、編碼和封裝、推流到服務器、服務器流分發、播放器流播放等等。如果想節省開發成本,可以使用第三方SDK。下面簡單介紹下使用聲網SDK發起直播的流程。

    瀏覽器要求:

  • Chrome 58+
  • Firefox 56+
  • Safari 11+(屏幕共享不可用)
  • Opera 45+(屏幕共享不可用)
  • QQ 10+(屏幕共享不可用)
  • 360 安全瀏覽器 9.1+(屏幕共享不可用)
  • 設備檢測

    調用AgoraRTC.getDevices獲取當前瀏覽器檢測到的所有可枚舉設備,kind為'videoinput'是攝像頭設備,kind為'audioinput'是麥克風設備,然后通過createStream初始化一個本地的流。 獲取設備:

    AgoraRTC.getDevices((devices) => {const audioGroup = {};const videoGroup = {};const cameraList = [];const micList = [];devices.forEach((device, index) => {if ((!device.groupId || !audioGroup[device.groupId]) && device.kind === 'audioinput') {micList.push(device);audioGroup[device.groupId] = true;}if ((!device.groupId || !videoGroup[device.groupId]) && device.kind === 'videoinput') {cameraList.push(device);videoGroup[device.groupId] = true;}});return { cameraList, micList }; });

    初始化本地流:

    // uid:自定義頻道號,cameraId設備Id const stream = AgoraRTC.createStream({streamID: uid,audio: false,video: true,cameraId: cameraId,microphoneId: microphoneId }); stream.init(() => {// clientCamera <div id="clientCamera" ></div>stream.play('clientCamera', { muted: true }); }, err => {console.error('AgoraRTC client init failed', err); });

    stream.init()初始化直播流;如果當前瀏覽器攝像頭權限為禁止,則調用失敗,可捕獲報錯Media access NotAllowedError: Permission denied; 若攝像頭權限為詢問,瀏覽器默認彈窗是否允許使用攝像頭,允許后調用play()可看到攝像頭捕獲的畫面。 如果不傳入cameraId,SDK會默認獲取到設備的deviceId,如果權限是允許,同樣會顯示攝像頭畫面。

    采集

    攝像頭

    順利拿到cameraId和microphoneId后就可以進行直播。通過SDK提供的createStream創建一個音視頻流對象。執行init方法初始化成功之后,播放音視頻(見上文)。最后通過client發布流以及推流到CDN(見下文)。

    屏幕共享

    Web 端屏幕共享,通過創建一個屏幕共享的流來實現的。Chrome屏幕共享需要下載插件,在創建的流的時候還需要傳入插件的extensionId。

    const screenStream = AgoraRTC.createStream({streamID: <uid>,audio: false,video: false,screen: true,extensionId: <extensionId>, // Chrome 插件idmediaSource: 'screen' // Firefox });

    傳輸

    通過AgoraRTC.createStream創建的音視頻流,通過publish發送到第三方服務商的SD-RTN(軟件定義實時傳輸網絡)。

    client.publish(screenStream, err => {console.error(err); });

    別的瀏覽器可以通過監聽到stream-added事件,通過subscribe訂閱遠端音視頻流。

    client.on('stream-added', evt => {const stream = evt.stream;client.subscribe(stream, err => {console.error(err);}); });

    再通過startLiveStreaming推流到CDN。

    // 編碼 client.setLiveTranscoding(<coding>); client.startLiveStreaming(<url>, true)

    在推攝像頭流的時候,關閉攝像頭,需要推一張占位圖。這個時候先用canvas畫圖,然后用WebRTC提供的captureStream捕獲靜態幀。再調用getVideoTracks,制定AgoraRTC.createStream的videoSource為該值。視頻源如來自 canvas,需要在 canvas 內容不變時,每隔 1 秒重新繪制 canvas 內容,以保持視頻流的正常發布。

    const canvas = document.createElement('canvas'); renderCanvas(canvas); setInterval(() => {renderCanvas(canvas); }, 1000); canvasStream = canvas.captureStream();const picStream = AgoraRTC.createStream({streamID: <uid>,video: true,audio: false,videoSource: canvasStream.getVideoTracks()[0] });// 畫圖 function renderCanvas(canvas) {... }

    一個client只能推一個流,所以在進行屏幕共享的時候,需要創建兩個client,一個發送屏幕共享流,一個發送視頻流。屏幕共享流的video字段設為false。視頻流的video字段設為true。然后先通過setLiveTranscoding合圖再推流。

    const users = [{x: 0, // 視頻幀左上角的橫軸位置,默認為0y: 0, // 視頻幀左上角的縱軸位置,默認為0width: 1280, // 視頻幀寬度,默認為640height: 720, // 視頻幀高度,默認為360zOrder: 0, // 視頻幀所處層數;取值范圍為 [0,100];默認值為 0,表示該區域圖像位于最下層alpha: 1.0, // 視頻幀的透明度,默認值為 1.0uid: 888888, // 旁路推流的用戶 ID},{x: 0,y: 0,width: 1280,height: 720,zOrder: 1,alpha: 1.0,uid: 999999} ];var liveTranscoding = {width: 640,height: 360,videoBitrate: 400,videoFramerate: 15,lowLatency: false,audioSampleRate: AgoraRTC.AUDIO_SAMPLE_RATE_48000,audioBitrate: 48,audioChannels: 1,videoGop: 30,videoCodecProfile: AgoraRTC.VIDEO_CODEC_PROFILE_HIGH,userCount: user.length,backgroundColor: 0x000000,transcodingUsers: users, }; client.setLiveTranscoding(liveTranscoding);

    因為業務需求是攝像頭和屏幕共享可以切換,攝像頭和屏幕共享的分辨率和碼率均不相同,屏幕共享需要更高的分辨率和碼率。但是開發中發現切換時設置碼率無效。SDK那邊給的答復是:因為緩存問題,會以第一次推流設置的參數為準,將會在下個版本中修復。

    總結

    以上是生活随笔為你收集整理的摆脱客户端?网页发起直播势在必行!的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    免费视频在线观看网站 | 美女视频久久 | 婷婷六月色| 五月天激情电影 | 一区二区三区免费看 | www.夜夜骑.com| 伊人色**天天综合婷婷 | 一区二区在线影院 | 国产精品免费久久久 | 欧美国产日韩激情 | 久久久久电影 | 免费三级av | 天天操偷偷干 | 国内精品一区二区 | 热re99久久精品国产66热 | 91亚洲精品国偷拍自产在线观看 | 亚洲三级精品 | 日韩伦理一区二区三区av在线 | 激情欧美一区二区三区免费看 | 在线观看国产v片 | 99综合久久 | www日日夜夜| 欧美另类xxxxx| www.激情五月.com | 日韩精品aaa| 国产黄色一级大片 | 99精品国产99久久久久久福利 | 最新精品国产 | 国产成人精品亚洲日本在线观看 | 久久影院精品 | 99精品免费久久久久久久久日本 | 国产精品免费成人 | 日韩欧美一区二区三区免费观看 | 国产欧美精品一区aⅴ影院 99视频国产精品免费观看 | adc在线观看 | 热久久免费国产视频 | 粉嫩av一区二区三区免费 | 亚洲日韩精品欧美一区二区 | 国产午夜在线观看视频 | 三上悠亚一区二区在线观看 | 亚洲精品午夜久久久 | 欧美日韩不卡一区二区三区 | 国产精品99久久久久久久久 | 婷婷六月色 | 日日摸日日 | 欧美大码xxxx| 日韩精品不卡在线 | 一级黄色电影网站 | 国产三级精品三级在线观看 | 中文国产成人精品久久一 | 一区二区伦理电影 | 日韩一区正在播放 | 国产精品久久久久一区二区三区共 | 99久久婷婷国产一区二区三区 | 久久字幕精品一区 | 五月天久久狠狠 | 久久久久久久久精 | 欧美午夜久久 | 亚洲人人精品 | 精品久久久久久亚洲综合网站 | 国产精品永久久久久久久久久 | 日韩精品首页 | 成 人 黄 色 视频免费播放 | 免费高清在线观看电视网站 | 狠狠干 狠狠操 | 五月天网页 | 欧美在线18 | 久久精品高清视频 | 天天人人综合 | 国产精品永久久久久久久www | 在线亚洲成人 | 久久婷婷网 | 亚洲一级片在线看 | 人人看看人人 | 岛国av在线不卡 | 在线观看黄色 | 欧美日韩国产三级 | 国产视频在线观看免费 | 国产精品久久免费看 | 色噜噜在线观看 | 国产精品久久在线观看 | 韩国精品视频在线观看 | 国产精品第一页在线观看 | 在线亚洲人成电影网站色www | 天天搞天天干 | 国产五月天婷婷 | 亚洲自拍自偷 | 中文字幕精品一区二区三区电影 | 日韩免费在线视频观看 | 91成人天堂久久成人 | 成人av在线网 | 久视频在线 | 久久久久女教师免费一区 | 天天操网站| 欧美日韩国产网站 | 午夜美女视频 | 中文字幕在线视频第一页 | 国产精品人成电影在线观看 | 99热这里是精品 | 中文字幕国产精品 | 伊色综合久久之综合久久 | 国产精品久久一区二区无卡 | 国产精品美女视频 | 一区二区 久久 | 午夜三级理论 | 天天爽综合网 | 国产日韩三级 | 精品国偷自产国产一区 | 亚洲精品九九 | 国产一区二区网址 | 国产原厂视频在线观看 | 国产福利91精品一区 | 国产涩涩网站 | 精品中文字幕在线 | 日韩二区在线播放 | 99精品系列 | 美女网站色 | 青青河边草免费直播 | 色a资源在线 | 久草视频在线资源站 | 国产成人精品电影久久久 | 激情五月综合网 | 在线观看不卡视频 | 国产欧美最新羞羞视频在线观看 | 91av中文| 99免费国产| 日本久久免费电影 | 亚洲激情网站免费观看 | 在线视频欧美亚洲 | 色多多污污在线观看 | 黄色av免费看 | 狠狠色丁香久久婷婷综合五月 | 国产精品美女免费看 | 成人在线观看资源 | 亚洲一区天堂 | 亚洲综合在线视频 | 高清国产午夜精品久久久久久 | 经典三级一区 | 97在线播放| 在线观看的a站 | 婷婷久久亚洲 | 成人欧美一区二区三区在线观看 | 日日干,天天干 | 蜜臀精品久久久久久蜜臀 | 天天·日日日干 | 日韩激情视频在线 | 黄色毛片网站在线观看 | 亚洲成人xxx | 91探花视频 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 99色视频在线 | 国产在线高清视频 | 亚洲精品h| 91九色国产 | 在线亚洲欧美日韩 | 欧美资源| 免费h漫在线观看 | 国内精品在线看 | 日本性生活免费看 | 超碰97国产在线 | 天天综合网~永久入口 | 亚洲精品国产精品国 | 狠狠干天天操 | 免费一级片久久 | 久草观看视频 | 日韩免费在线观看视频 | 久久精品一区二区 | 探花国产在线 | 国产最新在线 | 美女免费网视频 | 97在线免费视频观看 | 超碰99在线 | 99精品视频在线观看播放 | 福利视频一区二区 | 国产黑丝一区二区 | 日韩av不卡在线观看 | 色中色亚洲| 国产精品片 | 国产一区在线视频播放 | 成年人黄色免费视频 | 中文字幕丰满人伦在线 | 亚洲最新视频在线 | 欧美日韩大片在线观看 | 人人爽人人片 | 视频在线观看91 | 国产精品久久久久婷婷二区次 | 午夜av在线播放 | 在线视频久 | 去干成人网 | 狠狠色免费 | 久久影视中文字幕 | 在线观看完整版 | 波多野结衣一区二区 | 久久久久成人精品免费播放动漫 | 奇米影视四色8888 | 久久精品女人毛片国产 | 黄色大片免费网站 | 经典三级一区 | 夜夜夜夜夜夜操 | 狠狠色网 | 日本亚洲国产 | 久久久国产精品人人片99精片欧美一 | 成人综合婷婷国产精品久久免费 | 久久在线影院 | 亚洲精品久久激情国产片 | 国产精品国产三级国产aⅴ9色 | 日韩伦理一区二区三区av在线 | 日韩欧美一二三 | 久热香蕉视频 | 免费又黄又爽的视频 | 91在线永久 | 激情亚洲综合在线 | www视频免费在线观看 | 久久久免费精品 | 一区二区三区电影大全 | 午夜在线观看一区 | 麻豆成人在线观看 | a在线免费观看视频 | 久久一区二区免费视频 | 豆豆色资源网xfplay | 日韩精品视频免费 | 国产在线不卡一区 | 97人人模人人爽人人喊网 | 久久午夜精品影院一区 | 久久99国产精品 | 国产色久 | 一级α片免费看 | 揉bbb玩bbb少妇bbb | 久久久久中文字幕 | 91免费日韩 | 免费在线观看av网站 | 国产精品爽爽爽 | 在线成人av | 一区二区三区在线免费观看视频 | 国产精华国产精品 | 欧美国产日韩一区二区三区 | 国产麻豆电影 | bbbb操bbbb| 日韩久久久久久久久久久久 | 天天操天天色综合 | 亚洲精品视频免费看 | 亚洲日本va在线观看 | 黄色激情网址 | 久久a久久 | 中文字幕在线视频网站 | 91精品国产91久久久久 | av在线播放中文字幕 | 国产专区欧美专区 | 国产亚洲精品久久19p | 69国产精品视频 | 一级性生活片 | 国产精品久久久久久久久久尿 | 国产精品嫩草影院123 | 日韩在线视频不卡 | 能在线观看的日韩av | 亚洲视屏在线播放 | www五月天com | 91精品一区二区在线观看 | 亚洲国产成人精品在线观看 | 人人干人人干人人干 | 九九九热| 久久久免费观看完整版 | 日韩一区二区三区视频在线 | 久久好看| 成人精品影视 | 人人插人人艹 | 国产视频久久久 | 狠狠色狠狠综合久久 | 久久有精品 | 青青河边草观看完整版高清 | 精品夜夜嗨av一区二区三区 | 亚洲精品视 | 久久不卡av | 97在线成人 | 久久精品国产免费 | 一区二区三区韩国免费中文网站 | 精品不卡视频 | 国产性天天综合网 | 成人在线视频一区 | 日韩精品综合在线 | 午夜精品一区二区三区可下载 | 二区三区精品 | 草久在线观看 | 97超碰在线人人 | 懂色av懂色av粉嫩av分享吧 | 香蕉精品视频在线观看 | 日韩v在线91成人自拍 | 中文在线a∨在线 | 操高跟美女 | 不卡av电影在线观看 | 美女福利视频在线 | 特级毛片在线免费观看 | 日韩电影在线一区二区 | 亚洲精品456在线播放 | 欧美肥妇free | 中文字幕在线看视频国产 | 91手机电影 | 亚洲h色精品 | 久久视频精品在线观看 | 国产中文字幕一区二区三区 | 91系列在线观看 | 国产精品久久久久久久久久久免费看 | 国产黄色av网站 | 91精品导航| 亚洲a网| 色综合人人 | 亚洲精品乱码久久久久v最新版 | 国产一级片在线播放 | 最新av在线免费观看 | 日韩av一区二区三区四区 | av成人动漫 | 日韩夜夜爽 | 日韩在线免费电影 | av福利网址导航 | 精品夜夜嗨av一区二区三区 | 超碰97中文 | 中文字幕网址 | 在线黄av | 9999精品免费视频 | 懂色av一区二区在线播放 | 操老逼免费视频 | 久久久久免费精品 | 人人澡人人爽 | 日韩动态视频 | 少妇性xxx| 99久久婷婷国产 | 免费在线观看av不卡 | 国产一级片视频 | 精品福利在线 | 久久a国产| 中文字幕一区二区三区四区在线视频 | 一本一本久久a久久精品综合小说 | 一区电影 | 欧美精品久久久久久 | 日本不卡一区二区三区在线观看 | 国产三级在线播放 | 日韩欧美在线中文字幕 | 五月天综合婷婷 | 精品一区二区免费 | 天天综合区 | 日本一区二区三区免费看 | 国产精品99久久久久久宅男 | 亚洲黄色成人 | www.天天干 | 天堂av一区二区 | 日本aa在线 | 在线观看岛国av | 日韩大陆欧美高清视频区 | 天天爽夜夜爽精品视频婷婷 | 西西www4444大胆在线 | 欧美日本高清视频 | 国产拍揄自揄精品视频麻豆 | 激情视频综合网 | 国产美女无遮挡永久免费 | 久久天天躁狠狠躁夜夜不卡公司 | 日韩电影中文字幕在线观看 | 在线影院av | 99久久精品日本一区二区免费 | 国产精品毛片一区视频播不卡 | 五月黄色 | 国产精品久久久久久电影 | 亚洲第一区在线播放 | 精品亚洲欧美无人区乱码 | 日女人电影 | 国产精品一级在线 | 国产精品久久久久久模特 | 国产精品免费久久久久影院仙踪林 | 中文乱码视频在线观看 | 99精品视频在线观看视频 | 激情综合狠狠 | 国产中文字幕一区二区 | 国产成本人视频在线观看 | 亚洲欧美经典 | 免费在线一区二区 | 久久久久免费精品视频 | 亚洲 欧洲 国产 精品 | 国产一二区在线观看 | 久久综合精品国产一区二区三区 | 欧美激情视频在线免费观看 | 黄免费在线观看 | 成+人+色综合 | 久久天堂影院 | 在线播放日韩av | 欧美尹人 | 久久久久国产精品免费免费搜索 | 91丨九色丨91啦蝌蚪老版 | 看国产黄色大片 | 国产免费高清 | 国产一级特黄毛片在线毛片 | 久艹视频在线免费观看 | 日韩欧美视频免费观看 | 亚洲欧美成人网 | 欧美精品一区二区在线观看 | 激情综合网色播五月 | 午夜在线国产 | 亚洲免费成人 | 国产精品入口传媒 | 国产精品成人av电影 | 免费看的黄色 | 久久不见久久见免费影院 | 在线色资源 | 操操操人人人 | 色视频在线观看免费 | 久久无码av一区二区三区电影网 | 在线视频久 | 最近av在线 | 麻豆传媒在线免费看 | 成人久久综合 | 免费黄色网址大全 | 中文字幕国产精品一区二区 | 欧美一区二区在线免费看 | 国产中文字幕视频 | 亚洲精品日韩在线观看 | 视频国产精品 | 国产在线黄 | 香蕉视频在线播放 | 91成人精品一区在线播放69 | 亚洲高清不卡av | 99热这里有| 久久手机看片 | 午夜精品视频一区 | 久久久蜜桃一区二区 | 精品久久久久一区二区国产 | 中文有码在线视频 | 97精品久久人人爽人人爽 | 日韩一区二区三区视频在线 | 中文字幕在线观看你懂的 | 中文字幕在线免费观看视频 | 中文字幕免费观看全部电影 | 手机av电影在线 | 午夜91在线 | 伊人资源视频在线 | 九九热免费观看 | 亚洲精品乱码久久久久久写真 | 亚洲最大成人网4388xx | 日韩欧美高清不卡 | 黄色大片日本 | 久久免费av电影 | 久久精选视频 | 国产亚洲婷婷免费 | 国产色区 | 亚洲二区精品 | 日韩大陆欧美高清视频区 | 天天精品视频 | 日韩超碰在线 | 国产一区麻豆 | 久久久久国产精品免费网站 | 欧美日韩观看 | 国产一区二区在线观看免费 | 久久久污 | 粉嫩av一区二区三区四区 | 亚洲精品视频在线观看免费视频 | 国产拍在线 | 日韩免费在线视频 | 精品国产免费久久 | 欧美 亚洲 另类 激情 另类 | 国产精品一区免费在线观看 | 亚州精品视频 | 精品国产免费久久 | 在线观看一区 | 99在线免费视频观看 | 成人精品国产免费网站 | 国产精品 日韩 | 丁香一区二区 | 97超碰在线播放 | 久久久久成人精品亚洲国产 | 亚洲人在线7777777精品 | 在线激情av电影 | 日本久久久久久久久久 | 亚洲精品 在线视频 | 久久精品99国产精品亚洲最刺激 | 国产精品一区二区 91 | 欧洲精品亚洲精品 | 玖玖在线看 | 国产视频黄 | www激情久久 | 欧美一区二区在线看 | 亚洲国产精品传媒在线观看 | 国产69精品久久久久久久久久 | 视频一区二区精品 | 日韩免费电影 | 国产精品99久久久久久宅男 | 国产日产精品久久久久快鸭 | 久久综合婷婷 | www色网站| 国产福利91精品一区 | 国产精品视频地址 | 精品人人爽 | 免费网站黄色 | 亚州av网站大全 | av.com在线| 日韩精品一区二 | 亚洲精品久久激情国产片 | 国产成人高清在线 | 夜夜爽天天爽 | 久久免费a | 国产精品久久久久三级 | 91精品国产成人www | 国产精品久久久久久久婷婷 | 亚洲日韩欧美一区二区在线 | 丁香六月婷 | 久久久久精| 成人免费亚洲 | 中文乱码视频在线观看 | 毛片基地黄久久久久久天堂 | 91传媒免费在线观看 | 久久精品99国产精品酒店日本 | 在线视频观看成人 | 国产精品久久久久久69 | 亚洲一区二区麻豆 | 91精品久久香蕉国产线看观看 | 91麻豆精品国产91 | 黄色大片视频网站 | 西西4444www大胆无视频 | 国产在线色| 欧美一级黄色片 | 日韩精品免费在线观看视频 | 在线视频成人 | av电影中文字幕在线观看 | 91久久奴性调教 | 国内久久看 | 色婷婷综合久久久中文字幕 | 国产精品黄色 | 2019天天干夜夜操 | 成人黄色大片在线免费观看 | 亚洲最新av在线网址 | 欧美性色网站 | 99久久精品国产亚洲 | 国产性xxxx | 在线观看视频中文字幕 | 国内视频 | 91精品视频免费观看 | 久久在线电影 | 国产又黄又爽又猛视频日本 | 日日夜夜免费精品 | 91精品国产一区二区在线观看 | 国产96av| 超碰午夜| 国产一区二区三区四区在线 | 国产精品色婷婷 | 色婷婷视频 | av网站在线观看免费 | 亚洲精品在线播放视频 | 在线国产欧美 | 超碰在线日韩 | 最新的av网站 | 亚洲精品美女久久久久网站 | 99在线观看免费视频精品观看 | 91高清完整版在线观看 | 国产精品一区二区久久国产 | 人人草在线视频 | 97精品欧美91久久久久久 | 精品亚洲午夜久久久久91 | 中文国产成人精品久久一 | 成年人免费电影在线观看 | 国产高清视频在线观看 | 欧美日韩午夜 | 久久久精品一区二区三区 | 国产精品久久三 | 人人爽人人搞 | 人人爽久久久噜噜噜电影 | 黄色的视频 | 国产精品人人做人人爽人人添 | 日韩视频在线观看免费 | 精品国产乱码久久久久久浪潮 | 手机色站| 伊色综合久久之综合久久 | 精品自拍sae8—视频 | 日韩二区在线观看 | 久久综合色综合88 | 久久久.com | 美女黄频在线观看 | 日韩电影在线观看中文字幕 | 国产成人精品三级 | 成人三级视频 | 超碰97人人在线 | 国产精品麻豆三级一区视频 | 国内外成人在线视频 | 久久久久久综合网天天 | 91视频免费网站 | 五月网婷婷 | 欧美黑人性猛交 | 亚洲做受高潮欧美裸体 | 在线看国产视频 | 精品久久久网 | 国产视频中文字幕在线观看 | 天天干天天操av | 2019精品手机国产品在线 | 天天操夜操 | 97免费视频在线 | 国产精品久久久久久久久久尿 | 四虎永久精品在线 | 2018亚洲男人天堂 | 在线中文字幕视频 | 黄色精品久久 | 久久激情五月丁香伊人 | 玖玖视频| 国产精品网站一区二区三区 | 亚洲涩涩一区 | 久久www免费人成看片高清 | 国产精品久久艹 | 免费观看的黄色片 | 久久国产免费 | 色偷偷97 | 国产又粗又猛又爽又黄的视频先 | 999免费视频 | 亚洲国产中文字幕 | 国产精品免费久久久久 | 亚洲视频高清 | 成人蜜桃 | 91中文在线 | 成人av高清 | 国产在线看一区 | 免费观看黄 | 婷婷视频在线 | 亚洲精品国产成人 | 欧美亚洲xxx| 91黄色在线视频 | 精品一区二区免费在线观看 | 亚洲一级黄色大片 | 精品一区二区av | av电影av在线 | 九色91在线 | 激情婷婷欧美 | 国产精品福利av | 欧美综合久久 | 色婷婷一区 | 日本在线视频网址 | 午夜精品视频在线 | 久久久精品国产一区二区电影四季 | 91亚洲精品久久久 | 91高清免费在线观看 | 国产精品 中文字幕 亚洲 欧美 | 91视频一8mav | 国产亚洲精品精品精品 | 九九视频精品在线 | 美女av免费| av最新资源| 午夜美女av | 国产免费观看久久 | 精品综合久久久 | 69国产盗摄一区二区三区五区 | 久久国产精品久久久 | 粉嫩av一区二区三区入口 | 成年人在线电影 | 最近中文字幕第一页 | 国产破处视频在线播放 | 色综合天天天天做夜夜夜夜做 | 国产不卡在线视频 | 国产高清小视频 | 婷婷狠狠操 | 综合国产在线 | 成人丁香花 | 亚洲精品玖玖玖av在线看 | 久久久久久高潮国产精品视 | 日韩在线观看高清 | 国产免费视频在线 | 中文字幕一区二区三区久久蜜桃 | 日本狠狠色 | 欧美a√大片 | 精品久久久久一区二区国产 | 91人人射 | 国产真实精品久久二三区 | 精品国产99国产精品 | 丁香一区二区 | 国产精品av久久久久久无 | 黄色高清视频在线观看 | 午夜视频不卡 | 色婷婷在线视频 | 91国内在线视频 | 免费网站在线 | 色国产精品| 欧美成人中文字幕 | 国产一区在线观看视频 | 六月色丁香 | av高清影院 | 国产无限资源在线观看 | 青青久草在线视频 | 亚洲精品综合在线观看 | 欧洲精品二区 | 国产精品日韩在线 | 99色免费| 日本中文字幕在线一区 | 亚洲每日更新 | 在线亚洲激情 | aaa日本高清在线播放免费观看 | 久久免费99精品久久久久久 | 免费高清看电视网站 | 午夜.dj高清免费观看视频 | 高清视频一区 | 伊人天天| 国产黄色观看 | 精品一区二三区 | www.在线观看av| 亚洲黄色小说网 | 九九热视频在线免费观看 | 国产999精品视频 | 亚洲视频播放 | 91久草视频 | 久久这里只精品 | 国产精品一区二区精品视频免费看 | 国产精品涩涩屋www在线观看 | 国产精品免费观看国产网曝瓜 | 欧美国产在线看 | 国产91精品高清一区二区三区 | 成年人看片 | av资源免费在线观看 | 一区二区激情视频 | 日韩欧美电影网 | 狠狠综合久久av | 欧美性黑人 | 国产精品一区二区62 | 国产剧情在线一区 | 久久国产精品免费看 | 五月婷婷综合激情 | 天天伊人狠狠 | 国产一级视频在线观看 | 亚洲成a人片在线www | 婷婷伊人网 | 欧美va在线观看 | 激情视频二区 | 国产黄色片久久 | 手机成人在线电影 | 国产精品免费看久久久8精臀av | 婷婷在线网 | 中文字幕资源网 国产 | 日韩激情免费视频 | 免费a视频在线观看 | 日韩激情视频在线观看 | 特片网久久 | 成人午夜精品久久久久久久3d | 日韩1级片 | 欧美精品成人在线 | 丁香六月久久综合狠狠色 | av电影亚洲 | av韩国在线 | 国产精品日韩在线观看 | 国产在线看一区 | 国产精品9999 | 亚洲欧美日韩在线看 | 高清中文字幕av | 久久精品视频网站 | 久久精品免费观看 | 99综合电影在线视频 | 欧美日韩伦理一区 | 一区二区三区中文字幕在线 | 日本精品视频一区二区 | 97夜夜澡人人爽人人免费 | 国产午夜精品在线 | 亚洲免费观看视频 | 日韩av视屏| 草草草影院 | 在线а√天堂中文官网 | 96亚洲精品久久 | 中文在线a√在线 | 91精品国产高清自在线观看 | 91九色蝌蚪国产 | 亚洲一级片免费观看 | 中文字幕人成人 | 国产手机免费视频 | 亚洲国产一区av | 91久久丝袜国产露脸动漫 | 久久久www成人免费毛片 | 中文字幕一区二区在线播放 | 国产一区自拍视频 | av免费试看 | 91污视频在线 | 国产精品亚洲人在线观看 | av九九| 国产手机精品视频 | 亚洲永久国产精品 | 在线激情电影 | 色在线视频网 | 欧美久久久久久久 | 日韩电影中文,亚洲精品乱码 | 免费成人av| 西西4444www大胆视频 | 九九九热| 夜色成人av | 在线黄色国产 | 日韩理论在线视频 | 日韩在线视频免费播放 | 在线播放国产一区二区三区 | av免费线看 | 天天干天天天 | 成人黄色av网站 | 在线观看亚洲免费视频 | 激情五月在线观看 | 狠狠色狠狠综合久久 | 精品国产诱惑 | 亚洲天堂网在线视频 | 天天伊人狠狠 | 中文字幕 欧美性 | 亚洲欧美综合精品久久成人 | 一级成人免费视频 | 久久久91精品国产 | 人人精品久久 | 日本h视频在线观看 | 波多野结衣网址 | 欧美日韩国产区 | 在线a亚洲视频播放在线观看 | 丁香六月综合网 | 国产传媒一区在线 | 超碰在线亚洲 | 在线视频亚洲 | 色在线中文字幕 | 麻豆传媒视频观看 | 亚洲欧美日韩精品一区二区 | 欧美日产在线观看 | 一二三区在线 | 最新av网址在线观看 | 日本精品一二区 | 特级西西444www大胆高清无视频 | av网站地址 | 午夜电影久久 | 亚洲狠狠操 | 97视频人人澡人人爽 | 天天草天天干天天 | 色999五月色 | 黄色国产在线观看 | 韩日电影在线免费看 | avv天堂| 日韩黄色免费在线观看 | 亚洲综合爱 | 久久久久久国产一区二区三区 | 久久久久欧美精品999 | 久久久久国产精品免费网站 | 日本三级全黄少妇三2023 | 日韩在观看线 | 操操操日日日干干干 | 黄色片视频免费 | 美女视频黄是免费的 | 99精品乱码国产在线观看 | 超碰成人免费电影 | 色91在线 | 国产成人在线观看免费 | 亚在线播放中文视频 | 青青河边草观看完整版高清 | 国内精自线一二区永久 | 91在线中文字幕 | av在线亚洲天堂 | 欧美另类高清 | 国产小视频在线观看 | 久久理伦片 | 国产精品欧美一区二区三区不卡 | 青青久草在线 | 欧美伦理一区 | 黄色在线免费观看网站 | 伊人影院99 | 欧美一区二区日韩一区二区 | 午夜性福利| 日韩网 | 国产手机av | 日韩高清一二三区 | 日韩成人看片 | 成 人 黄 色 片 在线播放 | 91精品视频免费观看 | 亚洲国产精品一区二区尤物区 | 日韩精品中文字幕有码 | 狠狠伊人| 亚洲欧美国产精品 | 国产成人99av超碰超爽 | 99久视频| 亚洲理论电影网 | 欧美无极色 | 精品一区二区三区久久久 | 久久精品免费看 | 香蕉97视频观看在线观看 | 日韩免费观看一区二区三区 | 欧美精品中文在线免费观看 | 手机在线永久免费观看av片 | 91九色最新地址 | 天天色天天射天天操 | 人人看人人草 | 亚洲日本国产精品 | 欧美极品少妇xxxx | 亚洲一区精品二人人爽久久 | 国产 在线 高清 精品 | 九九九九九国产 | 国产精品久久久久高潮 | 丁香激情五月婷婷 | 国产18精品乱码免费看 | 99热999| 欧美日韩破处 | 激情影院在线 | 天天操天天插 | 免费三级在线 | 国产在线资源 | 国产一级视频在线观看 | 国产专区在线 | aⅴ精品av导航 | 亚洲dvd| 91色亚洲 | 色噜噜狠狠狠狠色综合久不 | 国产91精品在线播放 | 日韩一三区 | 天天干夜夜爱 | 日韩视频一区二区三区 | 日韩久久在线 | 精品久久福利 | 精品三级av | 日韩成人精品一区二区 | 亚洲天堂在线观看完整版 | 成片免费观看视频大全 | h视频在线看 | 看av免费 | 黄色片免费看 | 激情六月婷婷久久 | 精品久久福利 | 国产在线看一区 | 亚洲精品美女久久 | 久久欧美视频 | 天堂av在线网站 | 国产视频欧美视频 | 日本丶国产丶欧美色综合 | 久久久久久久精 | 国产亚洲视频在线观看 | 精品在线观 | 国产视频在线观看一区 | 91精品视频在线免费观看 | 亚洲最新av | 毛片一级免费一级 | 91香蕉视频色版 | 精品国产一区二区三区久久久久久 | 天天色天天综合 | 91看国产| 成人黄色av网站 | 97国产在线 | 日韩黄色免费在线观看 | 欧美日韩成人 | 日韩电影在线观看一区二区三区 | av经典在线 | 国产精品成人久久久久 | 欧美日韩免费一区二区三区 | 最新高清无码专区 | 一区二区精品在线 | av综合在线观看 | 青青射 | 99色在线视频 | 色五月色开心色婷婷色丁香 | www.99热精品 | 91成人欧美 | 久久久久久久久免费视频 | 国产精品综合久久久久久 | 免费激情在线电影 | 香蕉视频亚洲 | 色先锋av资源中文字幕 | 中文视频在线看 | 精品国产激情 | 国产色拍拍拍拍在线精品 | 伊人永久 | av天天澡天天爽天天av | 99精品网站 | 在线视频99 | av综合网址 | 免费久久网站 | 日韩网站免费观看 | 日日爱网站| 亚洲视频免费在线看 | 91精品久久久久久综合乱菊 | 久久伊人五月天 | 免费三级黄色片 | 97在线观视频免费观看 | 日韩在线在线 | 伊人天天色 | 91九色精品国产 | 91人人揉日日捏人人看 | 久久婷婷视频 | 亚洲影视资源 | 亚洲久草在线 | 国产免费不卡av | 人人玩人人弄 | 欧美网站黄色 | 99色国产| 99精品久久久久久久 | 国产日韩欧美中文 | 欧美日韩性视频在线 | 国产淫片免费看 | 精品久久久久久国产91 | 欧美日韩99 | 日韩在线视频线视频免费网站 | 日本一区二区不卡高清 | 91丨九色丨丝袜 | 国产精品一区二区在线 | 在线视频 精品 | 高清av不卡| 精品在线一区二区三区 | 99re久久资源最新地址 | 91精品国自产在线观看欧美 | 天堂久久电影网 | 91成人精品在线 | 久久综合九色综合久99 | 久久9视频 | 日韩三级视频在线观看 | 99热超碰在线 | 99在线视频免费观看 | 国产一级特黄毛片在线毛片 | 欧美日本在线观看视频 |