久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

淺談前端JS沙箱實現的幾種方式

瀏覽:133日期:2024-03-22 11:07:43
目錄前言iframe實現沙箱diff方式實現沙箱基于代理(Proxy)實現單實例沙箱基于代理(Proxy)實現多實例沙箱結束語參考前言

在微前端領域當中,沙箱是很重要的一件事情。像微前端框架single-spa沒有實現js沙箱,我們在構建大型微前端應用的時候,很容易造成一些變量的沖突,對應用的可靠性面臨巨大的風險。在微前端當中,有一些全局對象在所有的應用中需要共享,如document,location,等對象。子應用開發的過程中可能是多個團隊在做,很難約束他們使用全局變量。有些頁面可能會有多個不同的子應用,需要我們支持多沙箱,每個沙箱需要有加載,卸載,在恢復的能力。

iframe實現沙箱

在前端中,有一個比較重要的html標簽iframe,實際上,我們可以通過iframe對象,把原生瀏覽器對象通過contentWindow取出來,這個對象天然具有所有的屬性,而且與主應用的環境隔離。下面我們通過代碼看下

let iframe = document.createElement(’iframe’,{src:’about:blank’});document.body.appendChild(iframe);const sandboxGlobal = iframe.contentWindow;

注意:只有同域的ifame才能取出對應的contentWindow, iframe的src設置為about:blank,可以保證一定是同域的,也不會發生資源加載,參考iframe src

在前言中我們提到,微前端除了有一個隔離的window環境外,其實還需要共享一些全局對象,這時候我們可以用代理去實現。下面我們通過代碼看下

class SandboxWindow { /** * 構造函數 * @param {*} context 需要共享的對象 * @param {*} frameWindow iframe的window */ constructor(context, frameWindow) {return new Proxy(frameWindow, { get(target, name) {if (name in context) { // 優先使用共享對象 return context[name];}return target[name]; }, set(target, name, value) {if (name in context) { // 修改共享對象的值 return context[name] = value;}target[name] = value; }}) }}// 需要全局共享的變量const context = { document:window.document, history: window.history }// 創建沙箱const newSandboxWindow = new SandboxWindow(context, sandboxGlobal); // 判斷沙箱上的對象和全局對象是否相等console.log(’equal’,newSandboxWindow.document === window.document)newSandboxWindow.abc = ’1’; //在沙箱上添加屬性console.log(window.abc); // 在全局上查看屬性console.log(newSandboxWindow.abc) //在沙箱上查看屬性

我們運行起來,看下結果

淺談前端JS沙箱實現的幾種方式

以上我們利用iframe沙箱可以實現以下特性:

全局變量隔離,如setTimeout、location、react不同版本隔離 路由隔離,應用可以實現獨立路由,也可以共享全局路由 多實例,可以同時存在多個獨立的微應用同時運行diff方式實現沙箱

在不支持代理的瀏覽器中,我們可以通過diff的方式實習沙箱。在應用運行的時候保存一個快照window對象,將當前window對象的全部屬性都復制到快照對象上,子應用卸載的時候將window對象修改做個diff,將不同的屬性用個modifyMap保存起來,再次掛載的時候再加上這些修改的屬性。代碼如下:

class DiffSandbox { constructor(name) { this.name = name; this.modifyMap = {}; // 存放修改的屬性 this.windowSnapshot = {}; } active() { // 緩存active狀態的沙箱 this.windowSnapshot = {}; for (const item in window) { this.windowSnapshot[item] = window[item]; } Object.keys(this.modifyMap).forEach(p => { window[p] = this.modifyMap[p]; }) } inactive() { for (const item in window) { if (this.windowSnapshot[item] !== window[item]) {// 記錄變更this.modifyMap[item] = window[item];// 還原windowwindow[item] = this.windowSnapshot[item]; } } }}const diffSandbox = new DiffSandbox(’diff沙箱’);diffSandbox.active(); // 激活沙箱window.a = ’1’console.log(’開啟沙箱:’,window.a);diffSandbox.inactive(); //失活沙箱console.log(’失活沙箱:’, window.a);diffSandbox.active(); // 重新激活console.log(’再次激活’, window.a);

我們運行一下,查看結果

淺談前端JS沙箱實現的幾種方式

這種方式也無法支持多實例,因為運行期間所有的屬性都是保存在window上的。

基于代理(Proxy)實現單實例沙箱

在ES6當中,我們可以通過代理(Proxy)實現對象的劫持。基本實錄也是通過window對象的修改進行記錄,在卸載時刪除這些記錄,在應用再次激活時恢復這些記錄,來達到模擬沙箱環境的目的。代碼如下

// 修改window屬性的公共方法const updateWindowProp = (prop, value, isDel) => { if (value === undefined || isDel) {delete window[prop]; } else {window[prop] = value; }}class ProxySandbox { active() {// 根據記錄還原沙箱this.currentUpdatedPropsValueMap.forEach((v, p) => updateWindowProp(p, v)); } inactive() {// 1 將沙箱期間修改的屬性還原為原先的屬性this.modifiedPropsMap.forEach((v, p) => updateWindowProp(p, v));// 2 將沙箱期間新增的全局變量消除this.addedPropsMap.forEach((_, p) => updateWindowProp(p, undefined, true)); } constructor(name) {this.name = name;this.proxy = null;// 存放新增的全局變量this.addedPropsMap = new Map(); // 存放沙箱期間更新的全局變量this.modifiedPropsMap = new Map();// 存在新增和修改的全局變量,在沙箱激活的時候使用this.currentUpdatedPropsValueMap = new Map();const { addedPropsMap, currentUpdatedPropsValueMap, modifiedPropsMap } = this;const fakeWindow = Object.create(null);const proxy = new Proxy(fakeWindow, { set(target, prop, value) {if (!window.hasOwnProperty(prop)) { // 如果window上沒有的屬性,記錄到新增屬性里 // debugger; addedPropsMap.set(prop, value);} else if (!modifiedPropsMap.has(prop)) { // 如果當前window對象有該屬性,且未更新過,則記錄該屬性在window上的初始值 const originalValue = window[prop]; modifiedPropsMap.set(prop, originalValue);}// 記錄修改屬性以及修改后的值currentUpdatedPropsValueMap.set(prop, value);// 設置值到全局window上updateWindowProp(prop, value);return true; }, get(target, prop) {return window[prop]; },});this.proxy = proxy; }}const newSandBox = new ProxySandbox(’代理沙箱’);const proxyWindow = newSandBox.proxy;proxyWindow.a = ’1’console.log(’開啟沙箱:’, proxyWindow.a, window.a);newSandBox.inactive(); //失活沙箱console.log(’失活沙箱:’, proxyWindow.a, window.a);newSandBox.active(); //失活沙箱console.log(’重新激活沙箱:’, proxyWindow.a, window.a);

我們運行代碼,看下結果

淺談前端JS沙箱實現的幾種方式

這種方式同一時刻只能有一個激活的沙箱,否則全局對象上的變量會有兩個以上的沙箱更新,造成全局變量沖突。

基于代理(Proxy)實現多實例沙箱

在單實例的場景總,我們的fakeWindow是一個空的對象,其沒有任何儲存變量的功能,微應用創建的變量最終實際都是掛載在window上的,這就限制了同一時刻不能有兩個激活的微應用。

class MultipleProxySandbox { active() {this.sandboxRunning = true; } inactive() {this.sandboxRunning = false; } /** * 構造函數 * @param {*} name 沙箱名稱 * @param {*} context 共享的上下文 * @returns */ constructor(name, context = {}) {this.name = name;this.proxy = null;const fakeWindow = Object.create({});const proxy = new Proxy(fakeWindow, { set: (target, name, value) => {if (this.sandboxRunning) { if (Object.keys(context).includes(name)) {context[name] = value; } target[name] = value;} }, get: (target, name) => {// 優先使用共享對象if (Object.keys(context).includes(name)) { return context[name];}return target[name]; }})this.proxy = proxy; }}const context = { document: window.document };const newSandBox1 = new MultipleProxySandbox(’代理沙箱1’, context);newSandBox1.active();const proxyWindow1 = newSandBox1.proxy;const newSandBox2 = new MultipleProxySandbox(’代理沙箱2’, context);newSandBox2.active();const proxyWindow2 = newSandBox2.proxy;console.log(’共享對象是否相等’, window.document === proxyWindow1.document, window.document === proxyWindow2.document);proxyWindow1.a = ’1’; // 設置代理1的值proxyWindow2.a = ’2’; // 設置代理2的值window.a = ’3’; // 設置window的值console.log(’打印輸出的值’, proxyWindow1.a, proxyWindow2.a, window.a);newSandBox1.inactive(); newSandBox2.inactive(); // 兩個沙箱都失活proxyWindow1.a = ’4’; // 設置代理1的值proxyWindow2.a = ’4’; // 設置代理2的值window.a = ’4’; // 設置window的值console.log(’失活后打印輸出的值’, proxyWindow1.a, proxyWindow2.a, window.a);newSandBox1.active(); newSandBox2.active(); // 再次激活proxyWindow1.a = ’4’; // 設置代理1的值proxyWindow2.a = ’4’; // 設置代理2的值window.a = ’4’; // 設置window的值console.log(’失活后打印輸出的值’, proxyWindow1.a, proxyWindow2.a, window.a);

運行代碼,結果如下:

淺談前端JS沙箱實現的幾種方式

這種方式同一時刻只能有一個激活的多個沙箱,從而實現多實例沙箱。

結束語

以上是微前端比較常用的沙箱實現方式,想要在生產中使用,需要我們做很多的判斷和約束。下篇我們通過源碼看下微前端框架qiankun是怎么實現沙箱的。上面的代碼在github,如需查看,請移步js-sandbox

參考

iframe src ES6 Proxy

到此這篇關于淺談前端JS沙箱實現的幾種方式的文章就介紹到這了,更多相關JS 沙箱內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 久久久久久久一区 | 久久亚洲一区二区三 | 欧美色欧美亚洲另类七区 | 欧美一区二区伦理片 | 懂色一区二区三区av片 | 免费成人一级片 | 久久久国产视频 | 国产成人免费网站 | 密桃av| 精品亚洲国产成av人片传媒 | 国产成人免费 | 国产人成免费视频 | 成年人网站在线免费观看 | 香蕉久久av一区二区三区 | 午夜视频网站 | 欧美高清成人 | 三级成人在线 | 欧美啊v | 一区二区三区高清 | 久久一区二区视频 | 国产精品一二区 | 涩涩视频在线免费看 | 成人av免费 | 91一区二区 | 精品国产乱码久久久久久密桃99 | 久久国产精品视频 | 国产精品美女久久久 | 毛片免费观看视频 | 热久久免费视频 | 国产精品久久久久久久久 | 91偷拍精品一区二区三区 | 亚洲国产精品久久人人爱 | 国产精品中文字幕在线播放 | 激情欧美一区二区三区中文字幕 | 欧美三级电影在线播放 | 日韩视频在线观看 | 欧美日韩亚洲二区 | 国产成人一区 | 噜噜噜天天躁狠狠躁夜夜精品 | 国产在亚洲 线视频播放 | 狠狠狠 | 国产艳妇av视国产精选av一区 | 国产精品久久电影观看 | 欧美激情一区二区 | 久久久婷 | 免费国产wwwwwww网站 | 久久精品一区二区 | 久久成人av | 久久中文视频 | 黄色大片成人 | 91看片在线观看 | 激情一区 | 国产成人在线免费观看 | 亚洲成人一区二区三区 | 在线精品一区 | 美国一级毛片a | 久久在线 | 国产中文字幕一区 | 欧美一区久久 | 久久不卡| 九九热精品在线 | a级黄色毛片免费观看 | 日韩精品一二区 | 成人片免费看 | 成人免费视频网站在线看 | 亚洲一区国产精品 | 久久国产精品无码网站 | 国产精品久久久久9999鸭 | 黑人精品xxx一区一二区 | 国产www在线| 毛片入口| 国产极品视频在线观看 | 日韩亚洲| 美女视频一区二区三区 | 中文字幕亚洲欧美日韩在线不卡 | 国产精品成人3p一区二区三区 | 免费毛片网 | 一区二区三区国产 | 精品96久久久久久中文字幕无 | 久久一区二区三区四区 | 欧美顶级毛片在线播放 | 欧美日韩国产一区二区三区不卡 | 中文字幕天堂在线 | 久久女同互慰一区二区三区 | 色就是色网站 | 久久ri资源网 | 日韩国产精品一区二区 | 全免一级毛片 | 99精品一区二区三区 | www.操操操 | 99在线免费观看 | 伊人干 | 欧日韩免费 | 欧美精品一区二区三区在线 | 另类免费视频 | 国产日韩一区二区 | 欧美精品成人一区二区在线 | 欧美日韩另类在线 | 中文字幕第一页在线 | 国产伦精品一区二区三区四区视频 | 免费视频一区二区三区在线观看 | 99看片| 琪琪午夜伦伦电影福利片 | 亚洲国产精品网站 | 综合久久久久久久 | 国产亚洲精品久久久久久豆腐 | 99久久这里只有精品 | 亚洲欧洲精品视频在线观看 | 新疆少妇videos高潮 | 在线精品一区 | 北条麻妃一区二区三区在线 | 日韩第一区 | 亚洲不卡视频在线 | 欧美日本韩国一区二区 | 成人狠狠干 | 四虎av在线| 国产免费看 | 日韩精品第一页 | 亚洲成人天堂 | 久草精品视频在线播放 | 日韩视频中文字幕 | 免费日韩成人 | 亚洲成人动漫在线观看 | 国产一二三四在线 | 最新午夜综合福利视频 | 在线看h | 国产欧美综合一区二区三区 | 欧美色综合天天久久综合精品 | 日韩欧美一级在线 | 欧美在线视频不卡 | 免费福利视频一区 | 久久久久久亚洲国产 | 日本久久www成人免 成人久久久久 | 欧美激情综合五月色丁香小说 | 九色91九色porny永久 | 国产精品久久久久久久久久三级 | 中文字幕一区二区三区乱码图片 | 毛片网站大全 | 台湾佬成人网 | 亚洲精品一区二区三区蜜桃久 | 国产综合亚洲精品一区二 | 亚洲精品久久久久久一区二区 | 一区二区影院 | 日韩久久久久 | 中文字幕在线观看 | 久久久久国产亚洲日本 | 久久亚洲精品国产一区 | 欧美日韩亚洲在线 | 高清xxxx| 免费毛片网| 国产中文字幕在线 | 精品国产乱码久久久久久影片 | 欧洲一区二区三区 | 黄色在线 | 亚洲xx站| 久久久久综合 | 中文字幕一区二区三区乱码图片 | 国产精品毛片一区二区 | 99热精品在线 | 国产精品久久久久久久免费大片 | 91国偷自产一区二区三区亲奶 | 亚洲 中文 欧美 日韩 在线观看 | 亚洲国产网站 | 天天看片天天干 | 福利视频三区 | 香蕉成人啪国产精品视频综合网 | 欧美国产日韩一区 | 一级特黄aaa大片在线观看 | av一区二区三区四区 | 在线免费观看黄 | 国产一区二区欧美 | 国内精品国产成人国产三级粉色 | 91精品国产一区二区三区香蕉 | 欧美黄视频 | www精品| 国产一级免费在线观看 | 精品一二三区 | 91久久国产精品 | 久久久久久网站 | 日韩成人在线观看 | 色黄视频在线观看 | 国产免费av在线 | 国产一区二区h | a∨色狠狠一区二区三区 | 久草院线 | 亚洲午夜精品一区二区三区他趣 | 搞黄免费视频 | 国产精品高潮呻吟久久av野狼 | 色吊丝2288sds中文字幕 | 国产区视频在线观看 | 中文字幕精品一区 | 亚洲国产精品久久久久久 | 天堂av中文| 岛国av免费 | 免费成人av网 | 美日一级毛片 | 日韩欧美在线中文字幕 | 日韩在线亚洲 | 国产成人小视频 | 国产亚洲精品精品国产亚洲综合 | 成人tv| 97av视频| 麻豆视频91 | 99热这里有 | 中文字幕亚洲二区 | 亚洲精品视频在线观看网站 | 91精品国产一区二区 | 国产黄网 | 婷婷色国产偷v国产偷v小说 | 久久视频免费在线 | 在线精品亚洲欧美日韩国产 | 久久青| 天天爽天天草 | 亚洲国产成人精品女人 | 久久久久国产精品一区二区三区 | 夜夜骑首页 | 日韩在线一区二区 | 一区二区三区亚洲 | 男女羞羞视频免费看 | 成人综合在线观看 | 亚洲欧美日韩在线 | 亚洲欧美久久久 | 精品一区二区三区四区视频 | 久久91精品国产 | 999在线观看精品免费不卡网站 | 精品久久久久久久久久久 | 国产精品成人一区二区三区夜夜夜 | 色婷婷综合在线视频 | 高清视频一区 | 影音先锋国产 | 国产精品毛片久久久久久 | 国产在线精品一区 | 久久精品免费看 | 欧产日产国产一区 | 91久久精品一区二区二区 | 日韩免费视频一区二区 | 欧美日本国产 | 国产成人综合视频 | 久久99精品久久久水蜜桃 | 色吧一区 | 免费a爱片猛猛 | 日韩精品视频在线观看一区二区 | 亚洲精品国产第一综合99久久 | 亚洲精品视频在线观看免费 | 81精品国产乱码久久久久久 | 日韩国产在线观看 | 国产精品美女久久久久久久久久久 | 精品久久久久久久久久 | 美女中文字幕视频 | 成年人视频在线观看免费 | 日韩欧美~中文字幕 | 色婷婷久久一区二区三区麻豆 | 亚洲精品乱码久久久久久久久 | 欧美成年黄网站色视频 | 草草网站 | 欧美日韩国产在线观看 | 国产91在线免费观看 | 精品国产一区二区三区久久久蜜月 | 成人免费在线观看视频 | 欧美一区二区三区在线视频 | 日韩中文字幕 | 国产一二三区在线观看 | 亚洲精品综合 | 狠狠天天 | 夜夜操天天干 | 国产精品白浆 | 视频1区 | 人人干在线 | 一区二区三区免费网站 | 都市激情av | 欧洲精品一区二区 | 精品一区二区三区在线观看视频 | 日韩精品专区在线影院重磅 | 久久成人久久爱 | 国产成人天天爽高清视频 | 蜜桃视频一区 | 国产一级大片 | 综合久久亚洲 | 久久久精品一区 | 9久久婷婷国产综合精品性色 | 一区二区视屏 | 欧美一区二区三区在线 | 欧美日韩精品一区二区三区四区 | 黄网站免费在线 | 国产97碰免费视频 | а天堂中文最新一区二区三区 | 西西做爰免费视频 | 神马午夜 | 日韩免费网站 | 操操日| 久久精品这里热有精品 | 日韩电影中文字幕 | 色综合久久久久 | 亚洲一级黄色 | 午夜精品久久久 | 综合99| 色中色综合 | 亚洲精品专区 | 亚洲精品一区二区网址 | 国产精品久久精品 | 在线色网 | 久在线视频| 国产日韩视频 | 国产一区不卡 | 久热久热| 国产毛片精品 | 亚洲精品无| 日本黄色激情片 | 欧美日本国产 | 天天草av| 超碰在线91 | 中文字幕亚洲一区 | 日本精品久久久一区二区三区 | 在线观看不卡一区 | 欧美综合视频 | 自拍偷拍小视频 | 福利亚洲 | 综合av第一页| 91超碰caoporn97人人 | 色999精品 | 精品视频一区二区在线观看 | 日韩在线免费观看网站 | 日韩视频一区在线观看 | 中文字幕亚洲视频 | 青青草免费在线 | 蜜桃视频网站在线观看 | 一级毛片久久久 | 中文字幕在线观看2021 | 福利片一区二区 | 女同理伦片在线观看禁男之园 | 波多野结衣电影一区 | 伊人午夜| 日本视频二区 | 亚洲视频 欧美视频 | 国产三级久久久久 | 国产精品一区在线观看你懂的 | 午夜免| 一级黄色片日本 | 天天干人人 | 亚洲一级视频在线 | av一道本 | 成人午夜精品一区二区三区 | 午夜影院在线看 | 国产主播福利 | 成人av网址在线观看 | 日本aa级毛片免费观看 | 国产日韩免费视频 | 最新av在线网址 | 欧美视频在线播放 | 男女羞羞视频免费观看 | 黄色免费在线观看网址 | 精品久久久久久国产 | 国产日韩欧美一区 | 国产精品久久久久国产a级 日韩在线二区 | 日韩精品一区二区三区四区视频 | 欧美日韩亚洲三区 | 天天操妹子 | 亚洲欧洲一区二区 | 国产精品视频yy9299一区 | 欧美日韩免费一区二区三区 | 日韩三级电影免费观看 | 高清国产一区 | 视频一区在线 | 夜夜爽网址 | 国产在线一区二区 | 欧美一区二区三区成人 | 日本电影网址 | 国产亚洲一区二区三区在线观看 | 中文字幕在线视频观看 | 国产精品久久久一区二区 | 三区影院| 希岛爱理在线 | 亚洲综合大片69999 | 欧美日韩一区二区不卡 | 欧日韩在线视频 | 91精品久久久久久久久久 | 国产一区二区三区四区在线观看 | av网站在线免费观看 | 一区二区免费看 | 一区二区三区国产 | 婷婷视频在线 | 日本免费黄色 | 久久a视频 | 在线播放国产精品 | 在线观看亚洲精品视频 | 亚洲视频免费在线观看 | 国产精品一区二区久久久久 | 国产高清一二三区 | 日韩视频在线免费播放 | 国产在线不卡视频 | h视频免费看 | 亚洲三级在线观看 | 日韩精品999 | 亚洲毛片在线观看 | 男人的天堂视频 | 台湾佬成人网 | 亚洲午夜精品一区二区三区他趣 | 午夜免费电影 | 日韩欧美在线一区 | 亚洲一区二区中文字幕 | 成人一级片在线观看 | 久久福利电影 | 精产国产伦理一二三区 | 99精品国产高清在线观看 | 久久99久久99精品免观看粉嫩 | 精品国产一区二区三区日日嗨 | 日韩成人不卡 | 日韩精品成人 | 91在线免费看 | 精品免费国产一区二区三区四区 | 91视频在线看 | 精品一区二区三区在线视频 | 欧美激情小视频 | 成人av教育| 男人的天堂视频网站 | 午夜精品久久久久久久久久久久 | 欧美黄色网 | 热re99久久精品国产99热 | 亚洲精品国产a久久久久久 国产毛片毛片 | 欧美一区在线视频 | 二区在线观看 | 久久久久久免费 | 久久精品网 | 精品视频一区二区 | 日韩激情一区二区 | 精品久久国产 | 国产成人综合一区二区三区 | 亚洲精品乱码久久久久久蜜桃不爽 | 久久99精品视频 | 91在线视频观看 | 在线天堂新版最新版在线8 www.国产欧美 | 国产精品久久久久久久久福交 | 久久成人国产精品 | 中文av一区 | 亚洲第一区在线 | 欧美va天堂 | 91精品久久久久久9s密挑 | 免费观看一级特黄欧美大片 | 免费毛片a线观看 | www.蜜桃av.com| 日韩毛片免费视频一级特黄 | 国产精品久久久久久久久久 | 性做久久久久久久免费看 | 一本大道久久a久久精二百 国产精品片aa在线观看 | 精品乱码一区二区 | 欧美日韩在线视频一区二区 | 91亚洲国产成人久久精品网站 | 亚洲国产成人在线观看 | 国产中文字幕在线 | 中文字幕1区 | 亚洲二区视频 | 91在线视频 | 特级淫片裸体免费看 | 福利精品视频 | 韩国精品主播一区二区在线观看 | 国产一级在线观看 | 亚洲国产精品99久久久久久久久 | 激情婷婷| 久草精品视频 | 久久韩国 | 久久99精品国产99久久6尤 | 久久久在线 | 91精品一区二区三区久久久久久 | 欧美1314 | 99色资源 | 国产精品日韩在线 | 欧美成人综合在线 | 日本黄色大片免费看 | 国产精品久久久久久一级毛片 | 精品国产一区二区在线 | 不卡免费在线视频 | 国产精品美女久久久久久免费 | 国产精品久久一区 | www.天天操 | 亚洲骚片 | 久草在线视频免费播放 | 欧美视频在线播放 | 国产精品美女视频 | 精品欧美一区二区三区久久久小说 | 欧美一区二区日韩 | 中文字幕精品一区 | 天天拍天天操 | 看一级毛片视频 | 欧美精品久久久 | 久草热8精品视频在线观看 亚洲区在线 | 欧美性视频网站 | 亚洲欧美视频 | 伦理午夜电影免费观看 | 精品第一区 | 91婷婷射 | 国产精品毛片无码 | h片免费观看 | 不卡黄色 | 亚洲综合在线播放 | 一区二区精品在线 | 国产在线不卡 | 亚洲国产精品网站 | 精品一区二区三区国产 | 日韩色视频 | 粉嫩av网站 | 91精品国产综合久久久久久 | 欧美视频在线播放 | 久久精品中文字幕一区 | 欧美日韩亚洲一区二区 | 日韩欧美国产一区二区 | 久久久久黄 | 激情网五月天 | 欧美video | 久久不色| 欧美一级视频在线观看 | 99成人精品 | 日韩成人免费av | 亚洲国产精品一区二区www | 国产二区视频 | 午夜男人免费视频 | 在线成人亚洲 | 日韩中文字幕精品 | 国产欧美日韩综合精品一区二区 | 成人欧美一区二区三区视频xxx | 精品日韩视频 | 欧美亚洲视频在线观看 | 91精品国产自产精品男人的天堂 | 午夜精品网站 | 亚洲精品视频在线看 | 成人性大片免费观看网站 | 成人精品鲁一区一区二区 | 国产精品1区2区 | 成人福利在线 | 国产高清精品一区二区三区 | 亚洲精品久久久久久一区二区 | 高清国产视频 | 国产中文一区 | 精品91在线视频 | 久久最新网址 | 密色视频| 日韩成人在线视频 | 精品国产乱码久久久久久影片 | 国产精品一区二区不卡 | 欧美综合激情 | 国产视频中文字幕 | 日韩视频在线观看不卡 | 免费一看一级毛片 | 亚洲精品一区二区三区在线 | 97人人干| 免费在线一区二区三区 | 日av一区| 精品久久一二三区 | 久久视频一区 | 国产免费观看一区二区三区 | 久久女人精品 | 亚洲成人首页 | 午夜精品影院 | 欧美三级电影在线播放 | 亚洲毛片在线观看 | 精品二三区 | 久久久久久毛片免费播放 | 久久精品欧美一区二区三区不卡 | 久久综合狠狠综合久久综合88 | 色官网 | 欧美极品视频 | 亚洲国产成人精品女人久久久 | 久久精品无码一区二区日韩av | www.在线播放 | 涩涩视频在线免费看 | a级黄色在线观看 | 中文字幕一区二区三区乱码在线 | 国产精品成人一区二区三区夜夜夜 | 草草草久久久 | 亚洲一区视频 | 97成人在线 | 国产羞羞视频免费在线观看 | 国产精品美女久久久久aⅴ国产馆 | 国产精品黄网站在线观看 | 亚洲精品久久久久久久久 | 超黄视频在线观看 | 一区在线视频 | 羞羞的视频在线免费观看 | 日本啪啪网站 | 久久久精 | 国产精品视频久久久 | 午夜精品久久久久久久男人的天堂 | 日韩视频在线免费 | 亚洲高清在线 | 国产精品国产三级国产aⅴ中文 | 亚洲成人av | 国内精品国产成人国产三级粉色 | 久久久成人av | 国产噜噜噜噜噜久久久久久久久 | 中文精品一区二区三区 | 男女羞羞视频网站18 | 亚洲精品字幕 | 久久精品国产免费 | 91亚洲国产精品 | 亚洲激情在线 | 免费看片国产 | 在线看免费黄色片 | 精品超碰 | 欧美日韩成人在线 | 日韩国产| 精品免费在线 | 国产精品日本欧美一区二区三区 | 欧美一级网站 | 97av视频在线观看 | 天堂免费在线 | 在线观看91 | 日韩欧美国产成人一区二区 | 精品免费视频 | 91麻豆精品久久久久蜜臀 | 国产在线一二三区 | 日韩超级大片免费看国产国产播放器 | 精品国产欧美一区二区三区成人 | 日韩在线视频中文字幕 | 欧美日韩精品久久 | 欧美日本韩国一区二区三区 | 少妇一级淫免费放 |