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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

​SoundCloud的web播放库Maestro演进之路

發(fā)布時間:2024/4/11 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ​SoundCloud的web播放库Maestro演进之路 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.


Maestro是一款用于處理SoundCloud Web播放的庫,它在soundcloud.com、SoundCloud移動網(wǎng)站、網(wǎng)頁插件、Chromecast和Xbox應用中每天成功處理數(shù)千萬次的播放。如今,我們正在考慮開源,這篇博文將介紹我們迄今為止在Maestro開發(fā)過程中所取得的技術(shù)成就。感謝前熊貓直播前端技術(shù)專家姜雨晴對本文的翻譯和審校。


文 / Tom Jenkinson?

譯 & 技術(shù)審校 / 姜雨晴


支持性


在SoundCloud,我們希望可以支持所有現(xiàn)代網(wǎng)絡(luò)瀏覽器、移動瀏覽器和IE 11。我們的目標是利用瀏覽器提供的功能提供最佳的播放體驗。


媒體流


我們目前支持三個解碼器的媒體流:?


  • mp3?

  • opus?

  • aac


我們的主要協(xié)議是HLS(HTTP Live Streaming)。這意味著音頻內(nèi)容將被切割成片段,我們有一個單獨的文件(播放列表),其中包含所有片段的URL,以及它們在音頻內(nèi)容中的相應時間。您可以在此處找到有關(guān)HLS的更多信息。


瀏覽器提供的內(nèi)容


我們使用瀏覽器的audio標簽,媒體源擴展(MSE)和 Web Audio API。


我們需要瀏覽器至少支持 audio 標簽、擁有流媒體解碼和播放能力。MSE和Web Audio API 是獲得最佳體驗所必需的。


當 Web Audio API 或 MSE 丟失或播放期間出現(xiàn)錯誤時,我們可以正常降級。


我們將稍微介紹一下我們使用MSE和Web Audio API的內(nèi)容,但首先,讓我們看看該audio 標簽為我們做了些什么。


audio


如果瀏覽器支持解碼,則可以獲取音頻文件的URL并進行播放。它會content-type在響應的標頭中通知編解碼器,它提供了一個API,可用于控制播放并確定瀏覽器是否支持解碼:



媒體源擴展


僅使用audio 標簽,瀏覽器就可以完成幕后的所有工作,但您無權(quán)訪問它的底層緩沖區(qū)。


使用MSE,我們可以為瀏覽器支持的解碼器創(chuàng)建緩沖區(qū)。然后我們可以處理自己下載媒體并將其附加到緩沖區(qū)。這意味著我們可以進行優(yōu)化,如:預加載,這是我們在您單擊播放按鈕時,將其存儲在內(nèi)存中,預先下載我們認為您將播放的音頻文件的前幾秒。然后當您單擊播放時,我們將此數(shù)據(jù)直接從內(nèi)存中添加到緩沖區(qū),而不必從網(wǎng)絡(luò)獲取:


const?audio?=?document.createElement('audio');
const?mse?=?new?MediaSource()
const?url?=?URL.createObjectURL(mse)
audio.src?=?url
audio.play()

mse.addEventListener('sourceopen',?()?=>?{
??//?'audio/mpeg'?for?mp3
??const?buffer?=?mse.addSourceBuffer('audio/mpeg');
??buffer.mode?=?'sequence';
??const?request?=?new?Request('http://example.invalid/segment0.mp3');
??fetch(request).then((response)?=>?response.arrayBuffer()).then((data)?=>?{
????buffer.appendBuffer(data);
??});
});

Web Audio API


Web Audio API是這里提到的最新的API。當您播放,暫停或搜索時,我們會使用此API的一小部分來快速淡入淡出。這使得播放體驗更加的爽快、播放/暫停不那么突然:

const?audio?=?document.createElement('audio');
const?context?=?new?AudioContext();
const?sourceNode?=?context.createMediaElementSource(audio);
const?gainNode?=?context.createGain();
sourceNode.connect(gainNode);
gainNode.connect(context.destination);

audio.src?=?'http://example.invalid/something.mp3';
audio.play();

//?Schedule?fade?out.
gainNode.gain.linearRampToValueAtTime(0,?context.currentTime?+?1);


Maestro的目標


  • 簡單的API

  • 插件架構(gòu)

  • 易于檢測功能

  • 類型安全

  • 支持所有主流瀏覽器

  • 處理瀏覽器實現(xiàn)中的差異和錯誤

  • 優(yōu)異的性能?

能夠預加載

盡可能地響應

  • 可配置的緩沖區(qū)長度和緩存大小

  • 能夠在具有內(nèi)存受限的設(shè)備上工作,如Chromecast

  • 檢測?

提供錯誤數(shù)據(jù)和性能數(shù)據(jù),對其進行監(jiān)控,以檢測錯誤并進行改進


技術(shù)棧


  • TypeScript

  • Lerna

  • Yarn

  • WebPack


API


Maestro包含許多包。核心包提供了一個抽象BasePlayer類,它提供了播放器API。它將任務(wù)委派給特定的實現(xiàn),外部通信通過BasePlayer。可以通過player 方法檢索最新狀態(tài),并且在有任何更改時通知用戶。


例如,該play()方法返回Promise可以解析或拒絕。這BasePlayer將告知是縣城何時應該播放或暫停,實現(xiàn)層將告知BasePlayer實際播放的時間。每個播放器實現(xiàn)都與實際play()方法分離。這也意味著isPlaying()可以完全處理方法和相應的更新BasePlayer。另一個例子是getPosition(),除了通知實現(xiàn)層播放時間,除非正在seek,在這種情況下BasePlayer將返回請求的時間點。這意味著時間getPosition()總是有意義的,用戶在seek時可以保證它不會跳轉(zhuǎn),并覆蓋它。


播放器實現(xiàn)包含在單獨的包中,并且它們都擴展BasePlayer。我們目前有以下播放器:


  • HTML5Player - 這是最簡單的播放器。它采用URL和MIME類型,它們直接傳遞給媒體元素。

  • HLSMSEPlayer- 這擴展了HTML5Player,它需要一個Playlist對象來供段數(shù)據(jù)。該播放器使用MSE。

  • ChromecastPlayer - 此播放器是一個控制Chromecast的代理。

  • ProxyPlayer - 此播放器可以控制另一個播放器以便隨時切換。它還具有一些提供新播放器同步相關(guān)的配置。該播放器的一個好處是,它可以在真正的播放器還沒有的時候同步提供給應用程序。然后,一旦真實播放器可用,其狀態(tài)將被同步以匹配代理。其他一些用例是在Chromecast上播放和本地播放,或切換質(zhì)量。該應用程序只需與一個播放器進行交互,切換可以在幕后進行。


狀態(tài)管理和事件


在Maestro中,有很多播放狀態(tài)需要管理,它們大部分都包含在內(nèi)部BasePlayer。用戶還想知道某些部分的狀態(tài)何時發(fā)生變化,有時會通過執(zhí)行其他播放器操作來對變化作出反應。當我們在單個線程上運行時,這會帶來一些復雜性。有時我們還會以原子方式(跨多個函數(shù))更新狀態(tài)的幾個部分。例如:如果用戶跳轉(zhuǎn)到媒體的結(jié)尾,我們也想要將ended標志更新為true。更新ended標志有關(guān)的邏輯,與代碼中的查找邏輯無關(guān),但跳轉(zhuǎn)狀態(tài)和結(jié)束狀態(tài)的更新應該在API中一起發(fā)生。


為實現(xiàn)這一目標,我們構(gòu)建了一個名為的組件StateManager,它使我們能夠:


  • 在調(diào)用之前更新函數(shù)的多個部分,以通知用戶更改。

  • 在播放器調(diào)用堆棧的末尾通知用戶狀態(tài)更改,以便他們與播放器的任何交互不會因此而在調(diào)用堆棧中交錯。(例如,執(zhí)行工作然后觸發(fā)事件,而不是觸發(fā)事件然后執(zhí)行工作。)


StateManager


StateManager維護一個狀態(tài)對象。對該對象的所有更改都是使用update()方法進行的,并且可以提供回調(diào),然后在update()最后通知回調(diào)發(fā)生的任何狀態(tài)更改。這些調(diào)用可以嵌套:


type?ChangesCallback<State>?=?(changes:?Readonly<Partial<State>>,?state:?Readonly<State>)?=>?void;
type?Control?=?{
??remove:?()?=>?boolean;
};
type?Subscriber<State>?=?{
??callback:?ChangesCallback<State>,
??localState:?State
};

class?StateManager<State?extends?{?[key:?string]:?Object?|?null?}>?{

??private?_state:?State;
??private?_subscribers:?Array<Subscriber<State>>?=?[];
??private?_updating?=?false;

??constructor(initialState:?State)?{
????this._state?=?clone(initialState);
????//?...
??}

??public?update(callback:?(state:?State)?=>?void):?void?{
????const?wasUpdating?=?this._updating;
????this._updating?=?true;

????try?{
??????callback(this._state);
????}?catch(e)?{
??????//?error?handling...
????}

????if?(!wasUpdating)?{
??????this._updating?=?false;
??????this._afterUpdate();
????}
??}

??public?subscribe(callback:?ChangesCallback<State>,?skipPast?=?true):?Control?{
????//?...
??}

??private?_afterUpdate():?void?{
????this._subscribers.slice().forEach((subscriber)?=>?{
??????const?diff?=?this._calculateDiff(subscriber.localState);
??????//?We?always?recalculate?the?diff?just?before?calling?a?subscriber,
??????//?which?means?that?the?state?is?always?up?to?date?at?the?point?when
??????//?the?subscriber?is?called.
??????if?(Object.keys(diff).length)?{
????????subscriber.localState?=?clone(this._state);
????????deferException(()?=>?subscriber.callback(diff,?subscriber.localState));
??????}
????});
??}

??private?_calculateDiff(compare:?State):?Readonly<Partial<State>>?{
????//?...
??}
}


示例用法


type?OurState?=?{?a:?number,?b:?string,?c:?boolean,?d:?number?};
const?stateManager?=?new?StateManager<OurState>({
??a:?1,
??b:?'something',
??c:?true,
??d:?2
});

stateManager.subscribe(({?a,?b,?c,?d?})?=>?{
??//?On?first?execution:
??//?a?===?2
??//?b?===?'something?else'
??//?c?===?false
??//?d?===?undefined

??//?On?second?execution:
??//?a?===?undefined
??//?b?===?undefined
??//?c?===?undefined
??//?d?===?3
??updateD();
});

stateManager.subscribe(({?a,?b,?c,?d?})?=>?{
??//?a?===?2
??//?b?===?'something?else'
??//?c?===?false
??//?d?===?3
});

doSomething();

function?doSomething()?{
??stateManager.update((state)?=>?{
????state.a?=?2;
????updateB();
????state.c?=?false;
??});
}

function?updateB()?{
??stateManager.update((state)?=>?{
????state.b?=?'something?else';
??});
}

function?updateD()?{
??stateManager.update((state)?=>?{
????state.d?=?3;
??});
}


請注意,第一個訂閱回調(diào)將執(zhí)行兩次,第二個訂閱也只執(zhí)行一次,并且只執(zhí)行最新狀態(tài)(即d === 3)。


另請注意,我們不會獲得嵌套調(diào)用堆棧,因為回調(diào)只在工作完成后才會執(zhí)行。


瀏覽器限制


不幸的是,不同的瀏覽器具有不同的編解碼器支持(也可能取決于操作系統(tǒng))和不同的容器需求。


例如,Chrome支持MSE中的原始MP3文件,但Firefox要求MP3位于MP4容器中。這意味著在Firefox中,我們需要將我們下載的MP3打包到瀏覽器中的MP4中。其他編解碼器具有類似的復雜性。


有bug也是不可避免的。為支持在安全的方式下,處理各種媒體的媒體處理管道,并且不破壞Web瀏覽器的向后兼容性,這是一項艱巨的任務(wù)!幸運的是,Maestro有能夠處理不同瀏覽器中各種錯誤的變通方法,其中一些在版本之間有所不同。


瀏覽器之間的自動播放策略也不同,這意味著我們目前必須在播放器之間共享媒體元素。這增加了復雜性,因為當元素的源被更改時,仍然會在之后的短時間內(nèi)為前一個源發(fā)出事件,這意味著我們必須在嘗試使用它之前等待事件“清空”,并且我們必須保持跟蹤同時請求的所有內(nèi)容。Maestro的HTML5Player通過使用provideMediaElement(mediaEl)和revokeMediaElement()讓這變得簡單。這允許您在運行時在播放器之間移動媒體元素。當播放器沒有媒體元素時,播放器就會暫停。


測試


在BasePlayer和播放器的實現(xiàn)是通過單元測試和集成測試覆蓋:我們采用Mocha,Sinon,karma,以及mocha-screencast-reporter。后者非常適合遠程查看測試的運行進度。


確保API的行為正確,該BasePlayer自身目前擁有超過700次測試。例如,測試檢查play()實現(xiàn)是否正在播放時解析了promise。一個測試play()如果在播放請求完成之前播放器被釋放,則另一個測試會被拒絕并返回正確的報錯。還有一些測試可以檢查播放器是否在檢測到不一致時報錯。 例如,一個播放器實現(xiàn)在BasePlayer從未請求過seek操作時,無法完成seek請求。


我們還使用SauceLabs在各種瀏覽器和瀏覽器版本(包括Chrome和Firefox beta)上運行所有測試。這需要幾個小時才能完成,因此我們測試了各主流瀏覽器,我們在發(fā)布之前測試所有內(nèi)容。我們還每周運行所有測試,以確保新瀏覽器版本不會出現(xiàn)任何問題。這樣做,曾有一次高亮顯示了Firefox beta中的Web Audio錯誤,這會導致播放在前幾秒后停止。


漸進式流媒體(使用fetch()API)


我們最近添加了對漸進式流式傳輸?shù)闹С?#xff08;在支持的瀏 這意味著在我們處理它并將其附加到緩沖區(qū)之前不必等待整個段被下載,我們能夠在數(shù)據(jù)到達時處理數(shù)據(jù),這意味著我們能夠在段下載之前開始播放已完成。


這是通過fetch()API(以及moz-chunked-arraybuffer在Firefox中)實現(xiàn)的,它在下載時仍提供小部分數(shù)據(jù):


fetch(new?Request(url)).then(({?body?})?=>?{
??return?body.pipeTo(new?WritableStream({
????write:?(chunk)?=>?{
??????console.log('Got?part',?chunk);
????},
????abort:?()?=>?{
??????console.log('Aborted');
????},
????close:?()?=>?{
??????console.log('Got?everything');
????}
??}));
});


在我們添加漸進式流式傳輸之前,如果下載失敗,我們只會重試它,這個邏輯非常獨立。使用漸進式流式傳輸更為復雜,因為如果下載部分失敗,整個管道已經(jīng)開始處理數(shù)據(jù)。我們決定在錯誤時重試請求并丟棄我們已經(jīng)看到的所有字節(jié)。如果重試失敗,那么我們就能夠在管道中產(chǎn)生報錯。


這也帶來了更多的復雜性。之前,我們知道每個段包含完整數(shù)量的有效音頻單元,這意味著管道的不同部分可以做出某些響應。現(xiàn)在,每個數(shù)據(jù)部分都可以包含一小部分音頻單元,因此我們需要能夠檢測到何時發(fā)生這種情況,并保留和等待一個完整單元到達的緩沖區(qū)。


下一步是什么?


我們自2017年6月開始運行Maestro,而且對播放問題的不良反饋很少。我們能夠?qū)崟r監(jiān)控性能和錯誤,并且在發(fā)生錯誤的情況下,我們能夠檢索播放日志,這有助于調(diào)試。


我們正在尋找Maestro的下一個目標,那就是你的參與:讓我們知道你將如何使用它,以及你想看到的功能:D


如果您對此帖有任何疑問,或者您發(fā)現(xiàn)soundcloud.com上有任何播放問題;),請與我們聯(lián)系!


姜雨晴的補充資料


MSDN上關(guān)于 AudioContext的一些解釋 https://developer.mozilla.org/zh-CN/docs/Web/API/AudioContext 有關(guān)AudioContext,會稍微吃性能。


漸進式流媒體,就是我們所說的直播流媒體,它會涉及到有時候一個片段并非完整的問題,必須要等待完整片段,之前寫的代碼中有做過處理。https://github.com/xiongmaotv/open-mccree/blob/f8491e33770c59fe6288f1a05daf8375d4f01820/packages/mccree-core-loaderbuffer/src/index.js#L46


文章中反復提到的狀態(tài)處理,是因為媒體播放很多方法是異步,尤其在不同瀏覽器直接也有差異,比如停止下載的cancel在chrome中是Promise,異步的,FireFox中就不是。


LiveVideoStack? 招募

LiveVideoStack正在招募編輯/記者/運營,與全球頂尖多媒及技術(shù)專家和LiveVideoStack年輕的伙伴一起,推動多媒體技術(shù)生態(tài)發(fā)展。了解崗位信息請在BOSS直聘上搜索“LiveVideoStack”,或通過微信“Tony_Bao_”與主編包研交流。


點擊【閱讀原文】,了解更多大會講師及內(nèi)容信息。

總結(jié)

以上是生活随笔為你收集整理的​SoundCloud的web播放库Maestro演进之路的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

韩国精品视频在线观看 | 国产亚洲精品久久久网站好莱 | 久久综合福利 | 国产精品午夜免费福利视频 | 免费a v在线 | 欧美一级免费黄色片 | 国产二区电影 | 久久视频在线免费观看 | 日韩在线一区二区免费 | 国产一级不卡视频 | www.黄色片网站 | 91精品在线免费观看视频 | 久久再线视频 | 婷婷日 | 久久视频在线 | 午夜影院先| 狠狠色噜噜狠狠 | 国产精选在线 | 特级毛片在线免费观看 | 国产精品一区二区精品视频免费看 | 久久情爱| 国产小视频你懂的在线 | 国产裸体视频bbbbb | 欧美日韩国产精品一区二区亚洲 | 丁香九月婷婷 | av免费观看高清 | 日韩欧美一区二区三区在线观看 | 欧美国产亚洲精品久久久8v | 四虎国产精品免费 | 欧美在线91 | 精品你懂的 | 免费电影播放 | 在线免费成人 | 不卡av电影在线观看 | 在线v片 | 国产成人久久精品一区二区三区 | 亚洲专区中文字幕 | www.99热精品| 波多野结衣视频一区 | 最近最新最好看中文视频 | 久久天堂影院 | 中文字幕一区二区三区在线视频 | 九九欧美视频 | www亚洲一区 | 久久草视频 | 中文字幕在线看片 | 美女黄频视频大全 | 久久激情五月婷婷 | 色开心| av韩国在线 | 激情导航| 成人免费观看视频网站 | 狠狠色伊人亚洲综合网站色 | 婷婷激情在线观看 | 视频二区在线 | 国产亚洲精品女人久久久久久 | 国产人免费人成免费视频 | 国产91精品久久久久 | 在线之家免费在线观看电影 | 国产一区二区高清不卡 | 69久久夜色精品国产69 | 一级黄色av | 少妇bbb搡bbbb搡bbbb | 91麻豆国产 | 国产色拍拍拍拍在线精品 | 成人av动漫在线 | 国产成人一区二区三区久久精品 | 丁香导航| 麻豆传媒视频在线免费观看 | 国产精品久久久久久久久久免费看 | 国产一区二区成人 | 精品在线播放视频 | 精品天堂av| 国产伦精品一区二区三区… | 欧美精品二区 | 久久99精品国产91久久来源 | 国产精品爽爽爽 | 久草在线视频国产 | 天海翼一区二区三区免费 | 日韩av成人| 欧美国产精品一区二区 | 麻豆免费在线视频 | 久久精品一级片 | 国产免费看 | 国产做aⅴ在线视频播放 | 国产高清视频 | 色香蕉视频 | 日日夜夜狠狠干 | 亚洲国内精品 | 四虎影视8848dvd | 日韩一级电影在线观看 | 欧美成人aa| 国内精品久久久久久久影视麻豆 | 深爱婷婷久久综合 | 天天操天天操天天 | 免费在线国产黄色 | av福利在线免费观看 | 精品久久久久一区二区国产 | 精品国产免费人成在线观看 | 天天操天天草 | 看v片| 在线观看免费视频你懂的 | 六月久久婷婷 | 在线观看视频色 | 麻豆91在线播放 | 国产手机视频 | 亚洲国产剧情av | 国产精品欧美一区二区三区不卡 | 国产精品一区二区三区视频免费 | 久久久久免费视频 | 国产99久久久国产精品 | 久久精品一区二区三区中文字幕 | 91九色视频在线 | 天天碰天天操视频 | 国产涩图 | 国产精品ⅴa有声小说 | 亚洲精品99 | 亚洲精品一区中文字幕乱码 | 久久性生活片 | 欧美日韩在线精品 | 亚洲资源在线观看 | 久久久国产在线视频 | 国产不卡免费 | 婷婷激情影院 | 国产第一福利 | 在线免费中文字幕 | 欧美激情另类 | 日韩欧美91 | 五月婷婷视频在线 | 久久视频在线观看免费 | 国产成人精品午夜在线播放 | 五月天婷婷免费视频 | 波多野结衣久久精品 | 中文字幕在线观看免费观看 | 亚洲一二三久久 | 九色视频网址 | 国产又黄又爽无遮挡 | 久久久www成人免费精品 | 久产久精国产品 | 国产69精品久久久久99尤 | 四虎5151久久欧美毛片 | 国产在线一线 | 999久久久欧美日韩黑人 | 久草视频在线资源 | 激情片av | www.99在线观看| 精品久久久久久综合日本 | 国产精品永久久久久久久久久 | 国产精品淫片 | 国产精品美女毛片真酒店 | 中文字幕成人 | 日韩av播放在线 | 天天干天天玩天天操 | 天天插天天操天天干 | 国产亚洲精品久久久网站好莱 | 五月天亚洲综合小说网 | 国产精品资源网 | 天天操天天操天天操天天操天天操天天操 | 欧美激情第十页 | 色综合久久综合中文综合网 | 国产一级久久久 | 日韩激情视频在线观看 | 三级在线国产 | 香蕉国产91| 亚洲蜜桃在线 | 亚洲国产精品久久久久婷婷884 | 色在线视频网 | 激情婷婷在线观看 | 免费av网址在线观看 | 亚洲精品黄色在线观看 | 黄色www在线观看 | 日日操日日 | 中文字幕免费在线看 | 欧美黄色免费 | 国产福利91精品一区二区三区 | 91福利视频在线 | 国产成人精品一区二区三区在线 | 成人国产综合 | 久久 国产一区 | 免费99视频| 久久久麻豆精品一区二区 | 日韩亚洲国产中文字幕 | 国产精品2018 | 欧美a级成人淫片免费看 | 亚洲精品视频中文字幕 | 欧美人体xx | 日日夜夜人人天天 | 欧洲精品久久久久毛片完整版 | 亚洲精品免费播放 | 黄色毛片视频 | 成人精品久久久 | 韩国三级在线一区 | av高清一区二区三区 | 亚洲精品久久久久中文字幕二区 | 日韩综合在线观看 | 丰满少妇对白在线偷拍 | 米奇四色影视 | 久久久精品国产一区二区电影四季 | 欧美日一级片 | 色网址99 | 精品国产乱码一区二区三区在线 | 亚洲国产成人高清精品 | 91久久国产露脸精品国产闺蜜 | 久一网站| 日本在线免费看 | 久久久久成人精品免费播放动漫 | 91资源在线播放 | 久久艹艹| 成人av电影免费观看 | 国产精品久久久久久久久毛片 | 久久精品国产免费看久久精品 | 人人爱夜夜操 | 91久久国产自产拍夜夜嗨 | 永久免费观看视频 | 午夜美女av| 超碰在线9 | 成年人免费在线观看 | 精品国产1区2区 | www.97视频| 亚洲资源一区 | 国产精品a久久久久 | 亚洲自拍av在线 | 热re99久久精品国产66热 | 国产成人精品免高潮在线观看 | 欧美一级电影免费观看 | 日韩电影在线观看一区二区 | 精品国产区在线 | 成人av免费网站 | 日本中文字幕在线播放 | 91成人免费看片 | 在线观看视频一区二区 | 欧美精品资源 | 色香蕉在线视频 | 久久97视频 | 亚洲成人黄色 | 中文字幕无吗 | 久久伊人国产精品 | 成人影音在线 | 国产精品一区二区久久精品爱微奶 | 91av视屏| 永久黄网站色视频免费观看w | 丁香五月亚洲综合在线 | 亚洲成人精品av | 国产91免费在线 | 在线 成人 | 欧美日在线观看 | 久久久久久久影视 | 最新一区二区三区 | 在线免费观看视频你懂的 | 人人射人人插 | 久久久久久久久久久久久久av | 欧美一级特黄aaaaaa大片在线观看 | 欧美作爱视频 | 欧美日韩精品电影 | 国产免费二区 | 欧美久久久一区二区三区 | 正在播放国产一区二区 | 亚洲日本va中文字幕 | 国精产品永久999 | 亚洲电影图片小说 | 人人草天天草 | 久久精品牌麻豆国产大山 | 久热精品国产 | 在线亚洲小视频 | 国产精品日韩 | 亚洲精品视频网站在线观看 | 国产在线精品播放 | 久久人人97超碰com | 男女啪啪视屏 | 欧美精品二 | 天天操天天射天天爽 | 久久综合中文字幕 | 热久久免费国产视频 | 婷婷国产在线观看 | 91精品国产乱码久久桃 | 激情欧美一区二区三区免费看 | 亚洲区另类春色综合小说校园片 | 久久综合久久综合这里只有精品 | av在线播放中文字幕 | 在线免费观看麻豆视频 | 久久伊人国产精品 | 人人狠狠综合久久亚洲 | 日韩系列在线观看 | 中文字幕在线播放第一页 | 三级av网 | 久久免费视频在线观看 | 麻豆视频www | 成人免费网站在线观看 | 肉色欧美久久久久久久免费看 | 一区 二区 精品 | 亚洲激情六月 | 在线岛国av | 亚洲综合五月天 | 国产精品久久99综合免费观看尤物 | 亚洲免费成人av电影 | 日韩美av在线 | 国产精品岛国久久久久久久久红粉 | 国产精品一区二区三区在线 | 欧美一级xxxx | 探花视频在线观看+在线播放 | 深爱激情亚洲 | 久久久综合 | 久久人人97超碰com | av青草 | 中文字幕久久精品 | 亚洲精品电影在线 | 在线亚洲日本 | 日韩欧美一区视频 | 色综合天天综合 | 在线观看日本高清mv视频 | 国产色道 | 久久国产视频网 | 国产精品女人久久久久久 | 久久免费电影 | a√资源在线 | 18岁免费看片 | av丝袜制服 | 深爱综合网 | 国产第一页精品 | 久久a级片| 亚洲欧洲精品久久 | 国内精品久久影院 | 欧美日韩国产高清视频 | 国产精品1区 | 欧美综合色在线图区 | 日日日天天天 | 黄色特一级片 | 久久久精品在线观看 | 国产中年夫妇高潮精品视频 | 日本aaa在线观看 | 黄色a视频免费 | 五月天堂色| 人人干在线 | 日韩精品一区二区三区三炮视频 | 91精品国自产在线偷拍蜜桃 | 豆豆色资源网xfplay | 天天亚洲 | 婷婷网在线 | 麻花豆传媒一二三产区 | 黄色国产大片 | 欧美欧美 | 人人插人人射 | 精品国产一区二区三区日日嗨 | 婷婷色在线 | 超碰免费在线公开 | 久久免费视频这里只有精品 | 免费涩涩网站 | 国内精品久久久久国产 | 黄色免费网站下载 | 日本黄色大片免费 | www免费在线观看 | 女人18片毛片90分钟 | 久久久在线免费观看 | 免费视频在线观看网站 | 精品国产片 | 免费在线观看av网址 | 2023国产精品自产拍在线观看 | 亚洲一级二级 | 日韩精品一区二区三区中文字幕 | 国产欧美日韩精品一区二区免费 | 天天躁日日躁狠狠 | 天天躁天天躁天天躁婷 | 午夜骚影| 四虎成人精品在永久免费 | 开心丁香婷婷深爱五月 | 在线а√天堂中文官网 | 91精彩视频 | 超碰在线人人 | 日韩艹 | 亚洲国产欧洲综合997久久, | 激情综合网五月 | 伊人中文在线 | 黄色软件网站在线观看 | 99在线观看精品 | 最近免费中文字幕mv在线视频3 | 亚洲最新合集 | 亚洲精品在线观看的 | 国产无遮挡猛进猛出免费软件 | 日日躁夜夜躁aaaaxxxx | 国产精品国产亚洲精品看不卡 | 精品一区 在线 | 青青草国产精品视频 | 亚洲欧美综合精品久久成人 | 狠狠激情中文字幕 | 99精品免费久久久久久久久 | 精品福利视频在线 | 在线观看深夜视频 | 五月天综合网站 | 亚洲精品在线观看不卡 | 国产精品丝袜 | 国产福利91精品张津瑜 | 日韩成人在线一区二区 | 久久激情影院 | 97视频久久久 | 最近中文字幕mv免费高清在线 | av一区二区在线观看中文字幕 | 成人中文字幕在线观看 | 婷婷丁香激情五月 | 国产综合小视频 | 久久久亚洲精华液 | 久久国产精品精品国产色婷婷 | 又粗又长又大又爽又黄少妇毛片 | 国产日本三级 | 亚洲一级片在线看 | 国产精品99精品 | 91九色视频| 欧洲亚洲精品 | www.久久精品视频 | 91亚洲影院| 久艹视频在线免费观看 | 成人a级免费视频 | 96看片 | 国产精品美女视频网站 | 国产精品6 | 久久精品免费播放 | 国产精品成人在线观看 | 国产精品麻豆三级一区视频 | 欧美大片mv免费 | 91精彩视频在线观看 | www黄色大片| 久草精品视频在线播放 | 91xav| 免费观看国产精品视频 | 免费在线观看毛片网站 | 18久久久久| 97视频在线观看网址 | 精品国产福利在线 | 在线观看视频国产 | aaa免费毛片 | 日产乱码一二三区别在线 | 亚洲综合在线播放 | 99精品视频在线播放免费 | 99r在线 | 国产视频亚洲视频 | 91一区二区三区久久久久国产乱 | 日韩精品免费在线播放 | 波多野结衣在线中文字幕 | 久久久www成人免费毛片麻豆 | 国产精品欧美激情在线观看 | av在线日韩 | 国产一区二区三区高清播放 | av片子在线观看 | 久久久免费观看完整版 | 国产高清av免费在线观看 | 在线观看视频日韩 | 高清精品视频 | 丁香五月缴情综合网 | 久久久久国产一区二区三区四区 | 日本99精品 | 久久伊人五月天 | 色视频 在线 | 亚洲国产美女久久久久 | 日日夜夜干 | 亚洲a资源| 中文字幕乱码电影 | 午夜精品久久久久久久99水蜜桃 | 久草在线在线精品观看 | 亚洲精品综合欧美二区变态 | 在线中文字母电影观看 | 日本爽妇网 | 欧美精品久久久久久久 | 97在线精品视频 | 久草在线费播放视频 | 久久午夜免费观看 | 久草在线免费色站 | 国产一区二区日本 | 国产精品系列在线 | 婷婷色中文 | 久久久久在线 | 香蕉影视| 干 操 插| 免费视频你懂得 | 天干啦夜天干天干在线线 | 亚洲专区 国产精品 | 97视频资源 | 啪啪凸凸 | 欧美视频在线二区 | 伊人伊成久久人综合网小说 | 中文字幕在线观看第二页 | 国产综合福利在线 | 色噜噜日韩精品一区二区三区视频 | 国内精品久久久久久久影视简单 | 精品国产乱码久久久久久1区二区 | 在线观看国产一区 | 亚洲国产视频直播 | 91精品国产福利在线观看 | 久久久黄视频 | 亚洲精品久久久蜜桃直播 | www.午夜| 国产福利在线免费观看 | 久久在线免费视频 | 丁香资源影视免费观看 | 国产手机视频在线 | 免费国产在线视频 | 日韩视频一二三区 | 亚洲午夜av久久乱码 | 国产亚洲欧美在线视频 | 欧美精品亚州精品 | 美女国产精品 | 亚洲少妇自拍 | 欧美日韩国内在线 | 亚洲精品动漫成人3d无尽在线 | 综合激情av | av电影在线播放 | 特黄特黄的视频 | 99精品网站| 免费观看9x视频网站在线观看 | 最新av中文字幕 | 国产精选在线 | 夜夜躁狠狠躁日日躁视频黑人 | 狠狠干五月天 | 深爱婷婷网 | 三级av免费观看 | 中文字幕欧美激情 | 99久久9| 国产在线小视频 | 中文字幕在线看视频国产中文版 | 亚洲一本视频 | 久久伦理网| 深爱婷婷 | 国产一区免费在线 | 99免费观看视频 | 九九免费观看全部免费视频 | 欧美一二三四在线 | 波多野结衣综合网 | 欧美国产日韩一区二区三区 | 国产精品白浆视频 | 日批视频在线观看免费 | 高清国产午夜精品久久久久久 | 成人app在线播放 | www.五月激情.com | 天天操天天摸天天干 | 久久国产精品免费一区二区三区 | 日韩精品无码一区二区三区 | 免费看污片 | 日本成人免费在线观看 | 女人18精品一区二区三区 | av日韩av| 精品少妇一区二区三区在线 | 婷婷香蕉 | 亚洲综合成人婷婷小说 | 狠狠操狠狠干天天操 | 色丁香色婷婷 | 91黄色影视| 久久黄网站 | 国产日韩欧美精品在线观看 | 免费在线黄 | 久久精品麻豆 | 欧美日韩精品在线免费观看 | 99人成在线观看视频 | 国产精品久久亚洲 | 免费看黄在线网站 | 蜜桃av久久久亚洲精品 | 九九免费在线视频 | 婷婷色在线观看 | 91热爆在线观看 | 热热热热热色 | 国产精品综合久久 | 久久久精品网 | 少妇按摩av | 久久爱资源网 | 97色婷婷成人综合在线观看 | 日韩欧美一区二区三区视频 | 成人97视频一区二区 | 丝袜av一区| 日韩中文字幕电影 | 91tv国产成人福利 | 激情久久一区二区三区 | www.在线看片.com | 日产乱码一二三区别在线 | 九九激情视频 | 狠狠躁夜夜躁人人爽视频 | 日韩一区在线免费观看 | 日韩专区 在线 | 成人av在线亚洲 | 久久免费视频7 | 一级淫片在线观看 | 国产精品日韩在线播放 | 久久综合九色综合久久久精品综合 | 欧美三人交 | 婷婷激情在线观看 | 蜜桃传媒一区二区 | 91视频久久久 | 亚洲视频aaa| 中文字幕av网站 | 久久久麻豆精品一区二区 | 日本女人在线观看 | 日韩在线激情 | 超碰av在线播放 | www.激情五月.com | 久久久www成人免费精品张筱雨 | 深爱激情五月综合 | 456成人精品影院 | 亚洲一区二区三区在线看 | 欧美最猛性xxxxx免费 | 男女激情网址 | 国产在线国偷精品产拍免费yy | 国产乱对白刺激视频不卡 | 中文字幕一区在线 | 国产在线一区二区三区播放 | 亚洲 欧洲 国产 精品 | 国产69熟 | 怡红院久久 | 国产精品成人自产拍在线观看 | 激情网在线视频 | 免费看国产a | 福利网在线 | 欧美一区在线观看视频 | 日韩欧美在线免费观看 | 日本中文字幕一二区观 | 91亚洲影院 | 欧美日韩久 | 久久麻豆精品 | 亚洲欧美精品一区二区 | 国产视频二区三区 | 成人在线观看资源 | 精品uu | 欧美精品一区二区性色 | 久草网在线观看 | 国产精品成人av电影 | 日本一区二区三区视频在线播放 | 天天操福利视频 | 日本在线观看一区 | 久久美女高清视频 | 一区二区视频播放 | 中文字幕在线视频一区 | 日韩欧美国产免费播放 | 久久99精品久久只有精品 | 日韩毛片久久久 | 五月花婷婷 | 久久成人毛片 | 精品成人在线 | 欧美久久久久久久久久久久 | 精品久久久久久久久久久久久久久久 | av电影av在线 | 国产成人精品aaa | 国产精品手机播放 | 国产午夜精品免费一区二区三区视频 | 五月综合网站 | 在线免费av网 | www.888av| 91成品视频 | 国产小视频免费在线观看 | 国产亚洲精品福利 | 久久男人中文字幕资源站 | 六月丁香婷 | 亚洲第一香蕉视频 | 欧美国产日韩一区二区三区 | 国产中年夫妇高潮精品视频 | 久久成人精品电影 | 国产精品国内免费一区二区三区 | 国产成人一区二区在线观看 | 四虎成人精品永久免费av | 欧美性黑人 | 欧美少妇影院 | 久久久久久黄色 | 久草免费色站 | av在线永久免费观看 | 久久福利剧场 | 国产精品亚州 | 精选久久 | 99国内精品 | 精品 激情| 碰超人人| 黄色网址国产 | 亚洲涩涩一区 | 国产日韩欧美精品在线观看 | 午夜色性片 | 在线 视频 一区二区 | 国产主播大尺度精品福利免费 | 一区二区三区免费在线观看视频 | 免费看成年人 | 久久免费视频精品 | 伊人中文字幕在线 | 国产一级二级三级视频 | 91麻豆精品国产91久久久无限制版 | 国产99精品在线观看 | 国产色区| 成年人在线 | 国内一级片在线观看 | 精品亚洲成人 | 麻豆视频免费播放 | 国产一级精品在线观看 | 国产精品区一区 | 国产99在线免费 | 亚洲无吗av| 在线观看成年人 | 国产精品久久久久久爽爽爽 | 国产一区高清在线 | 久久精品成人 | 蜜臀av夜夜澡人人爽人人 | 九九热精 | 日韩av专区| 免费av的网站 | 91热爆视频 | 国产一级免费av | 久久人人爽人人爽人人片av软件 | 久久免费中文视频 | 成人av日韩| 午夜免费福利片 | 国产一区在线播放 | 日韩av区 | 69视频永久免费观看 | 欧美精品久久久久久久 | 中文字幕在线播放一区二区 | 91视频高清免费 | 麻豆91在线 | 亚洲mv大片欧洲mv大片免费 | 五月婷婷中文字幕 | 在线观看你懂的网址 | 超碰个人在线 | a在线观看国产 | 欧美亚洲成人xxx | 久久久黄色av | 亚洲精品一区二区久 | 日韩精品中文字幕在线播放 | 欧美色图88 | 国产剧情久久 | 波多野结衣视频在线 | 91网免费观看 | 日韩一二区在线观看 | 色婷婷av一区二 | 欧美久久久久久久久久 | 国产一区二区在线观看免费 | 国产精品日韩在线播放 | 欧美日韩国产xxx | 国产美女搞久久 | 久草精品免费 | 中文字幕精品三区 | 亚洲v精品| 国产欧美久久久精品影院 | 亚洲天堂精品 | 婷婷在线免费视频 | 国产中文在线字幕 | 国产亚洲婷婷免费 | 久久久久久久久久久影视 | 三级黄色大片在线观看 | 国产不卡在线观看 | 色999精品| 日日操狠狠干 | 五月婷久久 | 成人黄色在线看 | 亚洲人在线 | 久久激情视频免费观看 | 中文字幕中文字幕 | 成人精品久久 | 日韩欧美一区二区三区在线 | 久久久久在线 | 亚洲激情视频在线 | 九九九九热精品免费视频点播观看 | 福利久久久| 久久成人综合 | 国产一级特黄电影 | 97成人精品视频在线观看 | 欧美综合干 | 天天摸日日摸人人看 | 91久久国产综合精品女同国语 | 五月激情六月丁香 | 欧美aaaxxxx做受视频 | 999精品视频 | 国产高清在线a视频大全 | 九色最新网址 | 久久久久久亚洲精品 | 国产成人精品综合久久久 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 亚洲狠狠婷婷 | 久久精品一区二区三区中文字幕 | 日韩精品久久久久久久电影99爱 | 久久一区二区三区超碰国产精品 | 色婷久久| 国产97色在线| 超碰在线99 | 国模视频一区二区 | 最新av电影网站 | 在线观看中文字幕第一页 | 极品久久久 | 超碰人人舔 | 在线观看免费黄视频 | 日韩av区| 五月婷婷久久综合 | 国产精品视频地址 | 丁香婷婷激情国产高清秒播 | 蜜臀av夜夜澡人人爽人人桃色 | 日韩免费小视频 | 国产一区二区在线精品 | 久久精品一级片 | 五月色丁香 | 九九免费精品视频 | 精品国产乱码久久久久久浪潮 | 国际av在线| 91在线中文字幕 | 最近中文字幕第一页 | 免费色视频网站 | 久久精品亚洲精品国产欧美 | 三级视频国产 | 国产视频97 | 欧美视频18| 亚洲 欧洲av | 久久草精品 | 久久国产精品免费观看 | 免费视频a | 天天干天天射天天爽 | 欧洲亚洲精品 | 激情婷婷av| 黄色app网站在线观看 | 久久国产成人午夜av影院潦草 | 亚洲欧洲一区二区在线观看 | 视频99爱| 国产精品私人影院 | 日本视频精品 | 久草在线观看视频免费 | 国产成人精品av在线 | 天天插天天狠天天透 | 99九九视频| 日韩激情第一页 | 久久久www成人免费毛片 | 久久午夜电影 | 日本h在线播放 | 深爱激情婷婷网 | 在线观看国产中文字幕 | 99色视频在线| 五月婷社区 | 毛片一区二区 | 国产一级黄色电影 | 精品国产免费一区二区三区五区 | 亚洲国产日韩一区 | 国产一二三区在线观看 | 美女视频是黄的免费观看 | 久久国产成人午夜av影院宅 | 精品一区二区免费 | 美女视频黄频大全免费 | 九九热中文字幕 | 国产视频二区三区 | 在线中文字幕一区二区 | 美女久久久久久久久久久 | 久久久精品国产一区二区 | 在线韩国电影免费观影完整版 | 中国一级片在线播放 | 99在线观看免费视频精品观看 | 91精品国产九九九久久久亚洲 | 四虎欧美 | 9999激情 | 丁香九月婷婷综合 | 91av小视频| 99久久久国产精品 | 久久天天躁狠狠躁夜夜不卡公司 | 中文字幕丝袜美腿 | 韩日精品在线 | 超碰在线观看99 | 久久亚洲精品国产亚洲老地址 | 亚洲欧美色婷婷 | 亚洲色图av| 国产一区二区不卡视频 | 天天操天天射天天 | 日本天天操 | 精品国产精品久久一区免费式 | 91亚洲欧美激情 | 免费在线观看视频a | 国产免费av一区二区三区 | 免费在线黄色av | 深爱激情五月网 | 亚洲最大免费成人网 | 超碰免费在线公开 | 97在线视 | 日韩精品视频在线观看免费 | 一级黄色片在线播放 | 日韩精品第1页 | 天天插天天干天天操 | 在线探花 | 国产精彩视频 | 在线观看黄色免费视频 | 天天射网站 | 国产日韩欧美在线 | 色婷婷成人 | 国产精品女同一区二区三区久久夜 | 精品国产视频在线 | 国产黄色大片 | 国产亚洲免费的视频看 | 亚洲理论电影 | 亚洲污视频 | 国产一区二区在线免费播放 | 免费在线观看成人小视频 | 欧美日韩一区二区三区在线观看视频 | 亚洲国产日韩精品 | 一区二区三区国 | 亚洲久草视频 | 91成人小视频 | 国产91粉嫩白浆在线观看 | www.久久久| 看av免费网站 | 99亚洲精品在线 | 国模精品一区二区三区 | 毛片网站在线观看 | 九九视频网| 中文字幕有码在线 | 欧美片一区二区三区 | 麻豆视频免费网站 | 国产精品自在线拍国产 | 婷婷国产一区二区三区 | 韩国av免费观看 | 国产一二三精品 | 狠狠操.com| 成人久久18免费网站图片 | 欧美成人69av | 久艹在线免费观看 | 五月天婷婷免费视频 | 99免费在线播放99久久免费 | 天堂素人在线 | 久草在线免费在线观看 | 欧美性成人 | 手机在线欧美 | 日韩a欧美 | 国产精品久久久久免费 | 久久综合色天天久久综合图片 | 一区二区激情 | 波多野结衣在线中文字幕 | 国产精品成人aaaaa网站 | 亚洲天堂网在线观看视频 | 91精品在线视频观看 | 国产精品一区二区久久久久 | 久久国产精品影片 | 亚洲欧美视频一区二区三区 | www,黄视频 | 丁香激情视频 | 成人在线视频你懂的 | 国内精品小视频 | 在线成人免费 | 亚洲欧洲在线视频 | 大片网站久久 | www.午夜| 综合色播 | 在线免费观看国产视频 | 能在线观看的日韩av | 国内精品美女在线观看 | 免费黄色av电影 | 国产精品免费久久久久久 | 亚洲va韩国va欧美va精四季 | 超碰个人在线 | 91亚洲精品在线观看 | 色综合久久综合 | 国产高清在线 | 亚洲在线视频观看 | 久久久久亚洲精品国产 | 国产一区二区三区高清播放 | www.久久com | 久久久久在线 | 人人爽人人爱 | 狠狠色丁香婷综合久久 | 亚洲综合一区二区精品导航 | 国产精品乱码久久 | 粉嫩av一区二区三区四区五区 | 中文字幕黄色av | 久久精品欧美一 | 成人影音在线 | 99国产在线 | 欧美日韩在线观看一区 | 国产一区二区三区免费视频 | 精品免费久久久久 | 少妇bbb好爽 | 亚洲午夜精品一区二区三区电影院 | 丁香婷婷电影 | 五月婷在线播放 | 亚洲国产wwwccc36天堂 | 麻豆影视网站 | 视频在线99re| 成人免费视频免费观看 | 亚州精品成人 | 国产精品高清一区二区三区 | 91最新在线 | 2021国产精品视频 | 伊人五月天av | 欧洲视频一区 | 在线精品在线 | 亚洲情婷婷 | 国产免费一区二区三区最新6 | 精品国产乱子伦一区二区 | 一级黄色片在线播放 | 日韩免费视频观看 | 亚洲精品免费观看 | 国产免费小视频 | 亚洲精品h | 色成人亚洲网 | 日本久久电影网 | 亚洲精品久| 一本一本久久aa综合精品 | 国产精品乱码久久久久久1区2区 | 亚洲久草视频 | 99在线免费观看视频 | 日韩av在线小说 | www.久久成人| 国产福利一区二区在线 | 成人在线免费视频观看 | 亚洲一级在线观看 | av福利网址导航大全 | 久久撸在线视频 | 九九热精品视频在线观看 | 国产一二三区av | 成人资源在线播放 |