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

滴滴國(guó)際化項(xiàng)目 Android 端演進(jìn)

開(kāi)發(fā) 開(kāi)發(fā)工具
目前,大家用滴滴 App 在美國(guó)是可以打車的,那今天我們就來(lái)講一下滴滴國(guó)際化項(xiàng)目 Android 端的演進(jìn)。

目前大家用滴滴 App 在美國(guó)是可以打車的,對(duì)的,不用下載新的 App,現(xiàn)在的滴滴 App 在美國(guó)打開(kāi)就會(huì)自動(dòng)顯示海外打車頁(yè)面。

國(guó)際化在技術(shù)上有一定的特殊性,主要包括:

滴滴 App 在美國(guó)打開(kāi)的頁(yè)面

(1) 地圖

地圖作為滴滴客戶端重要的支持及基礎(chǔ),而目前我們的友商都沒(méi)有海外的路網(wǎng)數(shù)據(jù),國(guó)際化我們需要接入新的國(guó)外地圖提供商。

(2) 對(duì)接不同的運(yùn)力

目前滴滴國(guó)際化是與海外投資的伙伴進(jìn)行合作,比如美國(guó)打車跟 Lyft 合作。

(3) 漫游網(wǎng)絡(luò)

目前國(guó)際化的主要用戶場(chǎng)景還是國(guó)內(nèi)用戶出國(guó)打車,這時(shí)用戶是用國(guó)內(nèi)手機(jī)和運(yùn)營(yíng)商海外漫游接入網(wǎng)絡(luò)。

以上的三個(gè)特殊性決定著我們需要在技術(shù)上的差異,下面的分享也圍繞地圖模塊、漫游網(wǎng)絡(luò)、多業(yè)務(wù)接入項(xiàng)目演進(jìn)進(jìn)行分享。

1. 地圖

這塊主要包括兩大問(wèn)題:(1) 地圖選型,(2) 地圖切換

1.1 地圖選型

滴滴是個(gè)重度依賴地圖的 App,而目前我們的友商及大部分國(guó)內(nèi)地圖提供商都沒(méi)有海外的路網(wǎng)數(shù)據(jù)。

我們前期針對(duì)的場(chǎng)景是國(guó)內(nèi)用戶海外打車,Google Map 依賴 Google Play Service,國(guó)內(nèi)手機(jī)幾乎都沒(méi)有這個(gè) Service,即便安裝了 Google Play Service 部分手機(jī)也無(wú)法運(yùn)行,另外即便都有了,漫游網(wǎng)絡(luò)也不能訪問(wèn) Google Map,所以最靠譜的 Google Map 一開(kāi)始便被排除。

另外國(guó)內(nèi)有些 App 在海外用了 Google Map,不過(guò)是通過(guò)中轉(zhuǎn)下發(fā)地圖切片的方式完成的,我們對(duì)地圖各方面的要求都很高,所以也不合適。

這些都要求我們?nèi)フ乙粋€(gè)合適的國(guó)外地圖。

(1) 海外地圖選型考察點(diǎn)

海外地圖選型考察點(diǎn)

我們對(duì)地圖強(qiáng)依賴,有些定制需求,如:很多 Marker 并且添加后需要修改、畫圓并可以動(dòng)態(tài)調(diào)整半徑等等

國(guó)外可用地圖數(shù)據(jù)源主要有 OpenStreetMap、Here、Tomtom,OpenStreetMap 是個(gè)開(kāi)源的地圖數(shù)據(jù)源,類似維基百科的模式,所以數(shù)據(jù)很全很新,甚至超過(guò) Google Map,但不可避免會(huì)有些臟數(shù)據(jù),前期的話我們主要是針對(duì)大城市,OpenStreetMap 的數(shù)據(jù)可以滿足我們的需求。

因?yàn)樯婕暗疆惖乜鐣r(shí)區(qū)溝通,所以我們希望技術(shù)支持力度夠大。

性能包括地圖啟動(dòng)時(shí)間、渲染速度、前端響應(yīng)速度、后端響應(yīng)速度。

在開(kāi)始國(guó)際化前,當(dāng)時(shí)滴滴的安裝包就已經(jīng)很大了,基本是國(guó)內(nèi)主流 App 之首(當(dāng)然現(xiàn)在滴滴 App 已經(jīng)挺小了),所以我們希望新的地圖夠小。

(2) 海外地圖全面對(duì)比

Mapbox、Nutiteq、Here、Tomtom、Bing 共五款海外地圖全面對(duì)比

這次我們調(diào)研了 Mapbox、Nutiteq、Here、Tomtom、Bing 共五款海外地圖。其中

Bing 沒(méi)有 Android 版;

Tomtom 有很古老的 Android 版,但功能過(guò)于簡(jiǎn)單,文檔又幾乎沒(méi)有;

Here SDK 高達(dá) 40M,與他們溝通后,精簡(jiǎn)也只能到 25M,這個(gè)大小對(duì)我們是絕對(duì)接受不了的;

所以我們重點(diǎn)集成和測(cè)試的是 Mapbox 和 Nutiteq 這兩家地圖供應(yīng)商。

Mapbox 和 Nutiteq 的功能和性能都滿足我們需求,地圖數(shù)據(jù)源也都是以 OSM(OpenStreetMap) 為主。

Mapbox 的 API 設(shè)計(jì)和國(guó)內(nèi)地圖類似,都是向 Google Map 靠攏,所以上手簡(jiǎn)單,并且整個(gè) SDK 都是開(kāi)源的,地圖的樣式也更美觀些,而 Nutiteq 的地圖底層設(shè)計(jì)比較獨(dú)特,API 用法很不尋常,這也給我們接入帶來(lái)了很大的麻煩。

Mapbox 有眾多的 Web 用戶,包括訪問(wèn)量都不低的 Foursquare、Pinterest 等,但 Android 端用戶并不多;Nutiteq 的 Android 用戶多些,但整體量也不是很大,不過(guò)我們并沒(méi)有更好的選擇,而且前期我們的量也不會(huì)很大,所以他們都在可接受范圍內(nèi)。

綜合下來(lái)看的話,我們是更傾向于 Mapbox,不過(guò) Mapbox 只能通過(guò) GitHub Issues 和郵件反饋問(wèn)題,反應(yīng)很慢;Nutiteq 可以 Skype 溝通,效率很高。為了保險(xiǎn)起見(jiàn),Mapbox 和 Nutiteq 都做了全面接入和測(cè)試,最終證明這樣是有用的。

跟多數(shù) App 一樣,為了使得包更小,我們的主工程配置了 abiFilter “armeabi”,僅打 armabi 的 so,而 Mapbox 的 armeabi so 無(wú)法跑在 armv7 機(jī)器上,前期集成測(cè)試我們通過(guò)修改 Gradle 腳本在編譯時(shí) copy so 的方式讓測(cè)試通過(guò),而 Mapbox 一直不愿意改,國(guó)內(nèi)市場(chǎng)又不支持 Google 的 Apk Splits 機(jī)制,所以最終放棄 Mapbox 而選擇 Nutiteq。

后話:Mapbox ***版已經(jīng)解決了這個(gè)問(wèn)題,而且國(guó)內(nèi)有相關(guān)的市場(chǎng)人員,溝通起來(lái)也順暢多了。

1.2 地圖切換

用不了 Google Map 帶來(lái)一個(gè)要求,我們選擇的地圖必須支持多國(guó)家,并且在設(shè)計(jì)時(shí)要支持以后不同地圖任意切換。是的,即地圖和 App 弱依賴。針對(duì)這個(gè)問(wèn)題我們?cè)O(shè)計(jì)了地圖隔離層。

總體設(shè)計(jì)如下:

地圖隔離層總體設(shè)計(jì)

上圖第二層 MapSDK 是地圖的標(biāo)準(zhǔn) API 層,App 只與此層打交道,標(biāo)準(zhǔn)層的 API 設(shè)計(jì)以 Google Map API 為標(biāo)準(zhǔn)。

第三層 Adapter 層是具體地圖到標(biāo)準(zhǔn) API 的適配實(shí)現(xiàn)層。每個(gè)地圖都有個(gè) Adapter,負(fù)責(zé)將地圖 API 轉(zhuǎn)換成標(biāo)準(zhǔn) API。

將原來(lái)的 App 與三方地圖直接依賴改為 App 依賴表示標(biāo)準(zhǔn) API 的 MapSDK 層,由 MapSDK 通過(guò)具體的 Adapter 調(diào)用三方 SDK,這樣地圖切換只需要替換依賴的 Adapter 即可,其他地方無(wú)需改動(dòng)。

新的設(shè)計(jì)后編譯依賴關(guān)系如下:

新的設(shè)計(jì)后編譯依賴關(guān)系

App 依賴 Map Adapter,Map Adapter 依賴我們的 MapSDK 和三方的 Map SDK。

當(dāng)我們需要更換三方地圖 SDK 時(shí),僅需更換對(duì)應(yīng)的 Map Adapter 即可。對(duì)于 Android,build.gradle 中更換依賴即可。

1.3 新的地圖模塊設(shè)計(jì)的好處

(1) 解耦,切換成本低

這個(gè)上面已經(jīng)介紹,再也不會(huì)因?yàn)閾Q了地圖牽一發(fā)而動(dòng)全身。

(2) 學(xué)習(xí)成本低

業(yè)務(wù)開(kāi)發(fā)人員只需要熟悉標(biāo)準(zhǔn) MapSDK API 即可,不用了解其他地圖的具體使用,時(shí)間成本降低。

(3) 通用

適用于所有 App,以后新增 App,可直接使用之前成型的 Adapter。

1.4 地圖切換實(shí)現(xiàn)的注意事項(xiàng)

(1) 所有 API 適配

理論上 MapSDK 應(yīng)為地圖所有 API ***集,實(shí)際可以根據(jù)情況先去做所需功能的定義和適配。

(2) 標(biāo)尺

需要統(tǒng)一標(biāo)尺,如縮放尺度、相同坐標(biāo)系等。

(3) 未支持 API 處理

因?yàn)闃?biāo)準(zhǔn)層的 MapSDK 是地圖功能***集,所以不可避免某些三方地圖不支持 MapSDK 定義的功能。比如根據(jù)一組點(diǎn)縮放這個(gè)功能,其對(duì)應(yīng)的 Adapter 在實(shí)現(xiàn)這個(gè)功能時(shí)如果是 Debug 模式則拋異常,Release 模式則空實(shí)現(xiàn)。

還有如 MapSDK 的 API 規(guī)范前面已經(jīng)介紹過(guò)以 Google Map API 為標(biāo)準(zhǔn)。另 Adapter 有具體的開(kāi)發(fā)規(guī)范要求。

2. 漫游網(wǎng)絡(luò)

前面介紹過(guò)我們初期針對(duì)的是國(guó)內(nèi)用戶海外打車場(chǎng)景,這時(shí)用戶是用國(guó)內(nèi)手機(jī)和運(yùn)營(yíng)商海外漫游接入網(wǎng)絡(luò),所以需要針對(duì)網(wǎng)絡(luò)訪問(wèn)進(jìn)行優(yōu)化。

一般漫游網(wǎng)絡(luò)流程如下圖:

海外漫游網(wǎng)絡(luò)訪問(wèn)流程圖

用戶由海外運(yùn)營(yíng)商接入國(guó)內(nèi)運(yùn)營(yíng)商,再通過(guò)公網(wǎng)(有墻)訪問(wèn) Web。我們的服務(wù)器部署在 AWS 上,用戶海外漫游打車網(wǎng)絡(luò)流程如下圖:

用戶海外漫游網(wǎng)絡(luò)打車訪問(wèn)流程圖

由于公網(wǎng)訪問(wèn) AWS 非常慢,我們添加了海外專線,優(yōu)化后用戶海外漫游打車網(wǎng)絡(luò)流程如下圖:

用戶海外漫游網(wǎng)絡(luò)打車訪問(wèn)優(yōu)化后流程圖

用戶先訪問(wèn)到國(guó)內(nèi)的中轉(zhuǎn)服務(wù)器,中轉(zhuǎn)服務(wù)器再通過(guò)海外專線訪問(wèn) AWS。

這個(gè)過(guò)程中客戶端要做的工作包括:

(1) 拉取中轉(zhuǎn)服務(wù)器域名列表

(2) 使用中轉(zhuǎn)服務(wù)器域名列表中域名訪問(wèn),出錯(cuò)則用原始域名降級(jí)重試

(3) 定時(shí)及推送更新域名列表

這里域名順序由服務(wù)端自己負(fù)載均衡,返回的中轉(zhuǎn)服務(wù)器域名列表是中轉(zhuǎn)服務(wù)器域名還是直接海外域名也由服務(wù)器決定。

3. Android 項(xiàng)目演進(jìn)

3.1 原有模式

之前國(guó)際化業(yè)務(wù)的工程是很簡(jiǎn)單的方式,所有業(yè)務(wù)、組件、工具放在一起,根據(jù)具體包名劃分:

國(guó)際化業(yè)務(wù)的工程

這個(gè)在早期問(wèn)題不大,并且開(kāi)發(fā)起來(lái)快速方便,但隨著更多業(yè)務(wù)接入,如我們前面說(shuō)過(guò)的新的國(guó)家運(yùn)力接入,問(wèn)題就日益明顯,包括:

(1) 組件之間耦合

雖然已經(jīng)劃分包名,但依然可以互相調(diào)用,組件間依賴關(guān)系不清,甚至有循環(huán)依賴。

(2) 添加新業(yè)務(wù)不便

(3) 開(kāi)發(fā)問(wèn)題

規(guī)模越來(lái)越大致提交沖突可能性變大。

3.2 SDK 工程提取

將原工程整體拆分為業(yè)務(wù)工程和 SDK 工程,單業(yè)務(wù)工程直接依賴 SDK,可獨(dú)立開(kāi)發(fā)、獨(dú)立運(yùn)行、獨(dú)立打包。如下:

Android 項(xiàng)目抽離 SDK 工程設(shè)計(jì)

這樣在接入新的業(yè)務(wù)后,總體項(xiàng)目結(jié)構(gòu)如下圖:

 SDK 工程總體項(xiàng)目結(jié)構(gòu)

每個(gè)業(yè)務(wù)作為單獨(dú)工程,共用組件、工具、業(yè)務(wù)統(tǒng)一到 SDK 層中。

集成工程負(fù)責(zé)集成 Lyft、Ola、GrabTaxi 項(xiàng)目,所有業(yè)務(wù)項(xiàng)目提供 AAR,由集成工程整體打包對(duì)外發(fā)布。

3.3 SDK 工程組件化拆分

為了解決組件之間耦合,防止后續(xù)問(wèn)題加劇,同時(shí)方便協(xié)同開(kāi)發(fā)和更好的復(fù)用,將 SDK 工程組件化拆分如下:

將 SDK 工程組件化拆分

SDK 整體拆分為 Business Library 和 Util Library 兩大部分,主要依據(jù)是是否可以獨(dú)立于我們業(yè)務(wù),他們間不允許反向依賴。每個(gè)部分包含若干組件,每個(gè)組件都以 Module 形式存在。

Business Library 為通用業(yè)務(wù)層,包含通用業(yè)務(wù)組件,如平滑移動(dòng)、上車點(diǎn)、定位、地理信息、打點(diǎn)、網(wǎng)絡(luò)封裝。

其中 CommonBusiness 存放暫時(shí)通用、但尚不足以作為一個(gè)單獨(dú)組件的公共業(yè)務(wù),以后可能獨(dú)立出來(lái),注意包名規(guī)范方便未來(lái)獨(dú)立。

Util Library 為工具庫(kù),大致分為 View 和 Util,DidiSDK 為滴滴 App 整體通用組件包,包含通用的圖片緩存、網(wǎng)絡(luò)請(qǐng)求、基礎(chǔ)登陸組件等等。

3.4 SDK 組件化拆分后依賴關(guān)系圖

SDK 組件化拆分后依賴關(guān)系圖

通過(guò)上圖我們可以發(fā)現(xiàn)即便只是 Business Library 層,組件也根據(jù)依賴關(guān)系劃分為明顯的上下層。

3.5 SDK 組件化劃分事項(xiàng)

(1) 單一及開(kāi)閉原則

每個(gè)模塊只代表一個(gè)功能模塊或一個(gè)公共業(yè)務(wù),對(duì)于個(gè)性化或定制功能以接口形式對(duì)外開(kāi)放。

PS:目前 CommonBusiness 模塊暫時(shí)作為國(guó)際化 SDK 整體集成打包的模塊,即國(guó)際化 SDK 項(xiàng)目中的 sdk Module,后續(xù)當(dāng)其中某個(gè)公共業(yè)務(wù)足夠成為一個(gè)模塊時(shí)可繼續(xù)拆分出來(lái)。

(2) 拆分粒度

項(xiàng)目的演進(jìn)是不斷進(jìn)行的,沒(méi)必要將每個(gè)細(xì)小組件都拆分出來(lái),這樣不僅增加了項(xiàng)目的復(fù)雜度,同時(shí)也會(huì)影響編譯時(shí)間。

先根據(jù)實(shí)際需要拆分必要的組件,太小暫不足以獨(dú)立的組件可以在以后不斷進(jìn)行的重構(gòu)中根據(jù)需要拆分。如上面的 CommonBusiness 模塊,當(dāng)然需要保持一定的規(guī)范方便以后拆分。

(3) 依賴關(guān)系

通過(guò)依賴圖整理依賴關(guān)系,防止重復(fù)依賴,同時(shí)看出沉淀關(guān)系。

1. Util Library 不能反向依賴 Business Library;

2. Business Library 除了基礎(chǔ)部分,如 Net、Geo、EventTrack 外,其他部分盡量不要相互依賴;

3. Business Library 中 Net、Geo、EventTrack 不允許反向依賴其他模塊。

(4) 開(kāi)發(fā)規(guī)范

為了保證擴(kuò)展性及方便以后繼續(xù)拆分:

  • 所有業(yè)務(wù)包名以 com.didi.{xx}.sdk.{businessName} 開(kāi)頭;
  • CommonUtil 模塊中所有工具包名以 com.didi.{xx}.sdk.util.{utilName} 開(kāi)頭;
  • CommonView 模塊中所有 View 包名以 com.didi.{xx}.sdk.view.{viewName} 開(kāi)頭;

(5) 組件間通信

放棄原來(lái)造成耦合嚴(yán)重的EventBus,改用原生的通信方式,包括原生 (startActivityForResult) 、內(nèi)部廣播、回調(diào)等。

3.6 SDK 組件化項(xiàng)目整體設(shè)計(jì)圖

SDK 組件化項(xiàng)目整體設(shè)計(jì)圖

其中虛線部分為 SDK 層。

3.7 組件化拆分后的好處

(1) 組件間解耦

(2) 業(yè)務(wù)并行開(kāi)發(fā)、測(cè)試

(3) 組件單獨(dú)測(cè)試

【本文是51CTO專欄作者Trinea的原創(chuàng)文章,轉(zhuǎn)載聯(lián)系作者本人獲取授權(quán)】

戳這里,看該作者更多好文

責(zé)任編輯:趙寧寧 來(lái)源: 51CTO專欄
相關(guān)推薦

2024-04-02 07:56:41

2011-07-08 11:13:42

Cocoa Touch XCode

2018-05-24 15:19:19

AWS創(chuàng)業(yè)云服務(wù)

2023-04-07 15:12:46

ReactReact-Intl

2021-05-17 10:13:24

iOS名詞復(fù)數(shù)開(kāi)發(fā)

2011-05-17 09:39:38

JavaSE

2010-01-04 13:09:51

Silverlight

2011-08-19 13:13:14

struts2Java

2009-06-25 16:04:30

2025-02-14 10:27:30

2010-03-02 16:44:59

CentOS Mono

2011-08-29 09:48:30

springMVC

2024-05-17 08:25:06

數(shù)據(jù)驅(qū)動(dòng)React語(yǔ)言包

2024-01-17 10:16:22

前端國(guó)際化消息鍵

2023-01-31 10:29:26

JavaScript國(guó)際化國(guó)際化庫(kù)

2010-07-28 14:52:29

Flex國(guó)際化

2022-07-27 10:39:14

Spring代碼IDEA

2009-12-29 15:05:29

WPF支持國(guó)際化

2009-02-04 15:04:13

2024-09-04 10:27:53

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

国产午夜精品久久| 在线国产精品一区| 日韩三级视频在线观看| 中文精品无码中文字幕无码专区| 国精产品一品二品国精品69xx| 一道本一区二区| 中文字幕亚洲无线码a| 久久精品一二三四| 日本免费久久| 亚洲精品网站在线观看| 精品日本一区二区三区| 一区二区日韩视频| 模特精品在线| 蜜月aⅴ免费一区二区三区 | 亚洲人成亚洲人成在线观看图片| 国产精品久久精品视| 最近中文字幕在线视频| 狠狠爱成人网| 色777狠狠综合秋免鲁丝| 国产一卡二卡三卡四卡| 亚洲午夜剧场| 日本高清视频一区二区| 欧美日韩福利在线| 免费a在线看| 久久人人爽爽爽人久久久| 亚洲专区中文字幕| 中文字幕乱码视频| 香蕉久久夜色精品国产| 久久国产视频网站| www.涩涩爱| 少妇一区二区视频| 精品国产91乱码一区二区三区| 亚洲综合婷婷久久| 性欧美超级视频| 五月天丁香久久| 人人妻人人澡人人爽欧美一区 | 免费看成人哺乳视频网站| 日韩欧美国产系列| 国产一区二区在线观看免费视频| 久久精品女人天堂av免费观看| 亚洲福利视频三区| av一区二区三区免费观看| 黄色网址在线免费观看| 国产农村妇女毛片精品久久麻豆| 欧美美乳视频网站在线观看| 天天色棕合合合合合合合| 粉嫩av亚洲一区二区图片| 91影院在线免费观看视频| 一级淫片免费看| 麻豆高清免费国产一区| 国产精品偷伦一区二区| 这里只有精品999| 久久最新视频| 国产精品福利网| 成年人视频免费| 老司机午夜精品视频| 国产a∨精品一区二区三区不卡| 亚洲男人第一av| 羞羞视频在线观看欧美| 欧美一性一乱一交一视频| 99精品视频99| 老妇喷水一区二区三区| 国产精品高清在线| 又骚又黄的视频| 国产一区二区在线观看免费| 亚洲自拍偷拍区| 亚洲伦理在线观看| 北条麻妃国产九九精品视频| 国产亚洲欧美一区二区| 外国精品视频在线观看| 久久久久国产精品人| 亚洲7777| 国产激情视频在线观看| 亚洲一区免费在线观看| 国产老熟妇精品观看| 樱桃视频成人在线观看| 欧美日韩在线播放一区| 亚洲精品乱码久久久久久动漫| 日韩精品成人在线观看| 日韩av一区在线| 调教驯服丰满美艳麻麻在线视频| 久久精品高清| 欧美激情综合亚洲一二区| 日韩福利片在线观看| 视频在线观看一区| 91精品啪aⅴ在线观看国产| 成人黄色免费视频| 久久久国产一区二区三区四区小说| 亚洲精品国产精品国自产| www在线观看播放免费视频日本| 亚洲午夜日本在线观看| 欧美亚洲日本在线观看| 亚洲网址在线观看| 精品五月天久久| 日本二区三区视频| 亚洲毛片在线| 国产日产亚洲精品| 性感美女福利视频| 亚洲男同性视频| 国产a级一级片| 国产美女精品视频免费播放软件| 亚洲精品国产精品久久清纯直播 | 亚州av乱码久久精品蜜桃| 欧美激情亚洲国产| 在线观看国产成人| 91在线丨porny丨国产| 综合操久久久| 成人美女黄网站| 日韩亚洲欧美一区二区三区| 久久精品老司机| 综合久久一区| 国产精品视频精品视频| 手机看片一区二区三区| 亚洲精品国产精品乱码不99| 日本999视频| 奇米影视777在线欧美电影观看| 精品国产一区二区在线| 欧产日产国产69| 成人丝袜高跟foot| 公共露出暴露狂另类av| 91另类视频| 亚洲人成电影网站色xx| 国产成人精品av久久| 久久99精品国产麻豆婷婷洗澡| 久久精品国产美女| 福利在线导航136| 欧美女孩性生活视频| 在线观看国产精品一区| 国产亚洲高清视频| 国产视频一区二区三区四区| 黄a在线观看| 欧美日韩激情在线| 精品亚洲aⅴ无码一区二区三区| 99亚洲视频| 国产伦精品一区二区三区视频黑人| 黄色av网站在线播放| 欧美日韩一级二级| 性欧美精品男男| 日韩电影在线免费| 欧美一区2区三区4区公司二百| 国内精彩免费自拍视频在线观看网址| 日韩欧美亚洲国产精品字幕久久久| 女人18毛片毛片毛片毛片区二| 人人超碰91尤物精品国产| 日韩精品无码一区二区三区| 美女100%一区| 亚洲日本中文字幕免费在线不卡| 亚洲欧美综合另类| 久久伊99综合婷婷久久伊| 精品这里只有精品| 伊人春色之综合网| 日本一区二区在线免费播放| 国产精品视频二区三区| 欧洲精品在线观看| 免费看一级黄色| 精品一区二区三区的国产在线播放| 中文字幕日韩一区二区三区不卡| 999精品视频在线观看| 欧美成人精品在线视频| 亚洲欧美激情国产综合久久久| 亚洲中国最大av网站| 欧类av怡春院| 另类亚洲自拍| 一区二区精品在线观看| 成人亚洲精品| 久久露脸国产精品| 男人天堂资源在线| 欧美色精品在线视频| 日韩va亚洲va欧美va清高| 国产福利一区在线| 黄色动漫在线免费看| 欧美丝袜激情| 91免费版网站入口| 91九色在线播放| 亚洲人成电影网| 96亚洲精品久久久蜜桃| 亚洲天堂av一区| 人妻精油按摩bd高清中文字幕| 一区二区三区国产盗摄| 日韩三级在线播放| 秋霞影院一区| 2019中文字幕在线观看| 日本中文字幕在线2020| 欧美大肚乱孕交hd孕妇| 无码人妻丰满熟妇奶水区码| 综合av第一页| 99久久免费看精品国产一区| 日韩在线一区二区三区| 男插女免费视频| 综合综合综合综合综合网| 亚洲a成v人在线观看| 女人高潮被爽到呻吟在线观看 | 潘金莲一级黄色片| 成人sese在线| www.色就是色.com| 久久xxxx精品视频| 成人在线免费高清视频| 怕怕欧美视频免费大全| 99porn视频在线| 国产精品字幕| 97在线看免费观看视频在线观看| 在线观看av黄网站永久| 亚洲精品成人免费| 国产精品热久久| 日本韩国一区二区三区| 国产亚洲精品久久久久久打不开| 久久精品一区二区三区四区| 少妇极品熟妇人妻无码| 七七婷婷婷婷精品国产| 日韩精品 欧美| 中文字幕免费一区二区三区| 日韩欧美一区二区三区四区| 欧美sss在线视频| 亚洲一区二区三区视频播放| 99热播精品免费| 91高清免费在线观看| 任你弄在线视频免费观看| 中文字幕日韩欧美精品在线观看| 亚洲日本香蕉视频| 欧美大片免费久久精品三p| 国产情侣在线播放| 欧美怡红院视频| 香蕉影院在线观看| 亚洲成人777| 国产网站在线看| 亚洲码国产岛国毛片在线| 久久视频一区二区三区| 国产调教视频一区| 人妻丰满熟妇av无码久久洗澡| 国产成人在线免费| 亚洲一区二区图片| 精品一区二区日韩| 蜜臀一区二区三区精品免费视频| 日韩成人免费看| 成年人黄色片视频| 国产精品一卡| 成人观看免费完整观看| 99成人在线| 亚洲熟妇av日韩熟妇在线| 亚洲午夜极品| 日韩视频免费播放| 99热精品在线| 啊啊啊一区二区| 亚洲一区激情| 少妇高清精品毛片在线视频| 久久国产日本精品| 青青在线免费观看视频| 久久综合九色综合欧美狠狠| caoporn超碰97| 日本视频一区二区三区| 牛夜精品久久久久久久| 久久99精品久久久| 日本网站在线看| 国产成人亚洲精品狼色在线 | 一区二区三区精彩视频| 欧美日本视频在线| 国产日韩一级片| 精品国产污网站| 亚洲三区在线观看无套内射| 日韩精品在线观看网站| 国产高清在线| 久久精品在线播放| 日本性爱视频在线观看| 91精品国产成人| 成人做爰视频www网站小优视频| 国产精品自产拍在线观看| 国产高清日韩| 国内外成人免费视频| 九九热线有精品视频99| 亚洲日本无吗高清不卡| 欧美全黄视频| 日韩视频第二页| 久久精品国产亚洲一区二区三区| 在线观看日本www| 成人免费毛片app| 男女做爰猛烈刺激| 亚洲色大成网站www久久九九| 国产在线一二区| 色综合天天视频在线观看| 艳妇乳肉豪妇荡乳av| 日韩精品一区二区三区三区免费| 天天爽夜夜爽夜夜爽| 综合网中文字幕| 久久99亚洲网美利坚合众国| 日本sm极度另类视频| 精品亚洲二区| 女同一区二区| 1024精品久久久久久久久| koreanbj精品视频一区| 久久国产三级精品| 亚洲av永久无码精品| 中文字幕电影一区| 国产午夜免费视频| 欧美日韩一本到| 日本激情一区二区| 中文字幕av一区中文字幕天堂 | 青青视频在线观| 另类天堂视频在线观看| 久久毛片亚洲| 99精品国产高清一区二区| 精品国产99| 亚洲精品蜜桃久久久久久| 免费看黄色91| asian性开放少妇pics| 亚洲精品国久久99热| 欧美成人一区二区视频| 亚洲国产精品免费| 中文在线字幕免费观看| 国产精品青青在线观看爽香蕉 | 日韩在线观看免费全集电视剧网站 | 欧美区在线播放| 成人久久网站| 精品无人区一区二区三区竹菊 | 欧美极品美女电影一区| 亚洲人体在线| 午夜久久资源| 免费精品视频| 一区二区三区少妇| 洋洋成人永久网站入口| 一级淫片免费看| 最新国产精品亚洲| 欧美韩国亚洲| 欧美极品一区二区| 一区二区福利| a视频免费观看| 亚洲国产一区二区视频| 国产成人精品一区二三区四区五区| 色香阁99久久精品久久久| 性感美女一区二区在线观看| 蜜桃视频在线观看91| 伊人精品成人久久综合软件| 美女流白浆视频| 亚洲激情五月婷婷| 国产男女猛烈无遮挡| www.欧美免费| 亚洲欧美久久精品| 在线一区高清| 久久成人羞羞网站| 99久久久免费精品| 欧美一区二区日韩| 大片免费在线看视频| 亚洲qvod图片区电影| 欧美一区二区三区免费看| 性欧美在线视频| 亚洲免费在线看| jlzzjlzzjlzz亚洲人| 欧美巨猛xxxx猛交黑人97人| 日韩中文字幕一区二区高清99| 日韩久久久久久久久久久久| 国产 日韩 欧美大片| 精品午夜福利在线观看| 亚洲国产美女精品久久久久∴| 国产在线88av| 久热国产精品视频一区二区三区| 久久久久久穴| 中文字幕免费在线看线人动作大片| 在线国产电影不卡| 日本欧美在线视频免费观看| 91亚洲精华国产精华| 欧美日韩少妇| 中文字幕日韩三级片| 91黄色免费看| 日韩成人影视| 国产一区二区精品免费| 亚洲影视在线| 欧美性猛交xxxx乱大交少妇| 欧美一区欧美二区| 国产精品探花在线| 欧美日韩精品综合| 久久精品国产一区二区三 | 久做在线视频免费观看| 999久久久| 亚洲自拍另类| 久久爱一区二区| 日韩av在线高清| 国产精品成人国产| 老司机激情视频| 26uuu成人网一区二区三区| 国产精品高清无码| 欧美人交a欧美精品| 美日韩中文字幕| 在线成人精品视频| 91久久一区二区| 国产视频一区二区| 免费国产一区二区| 激情成人综合网| 成人在线免费看视频| 日韩中文字幕视频在线| 国产91精品入| 色www免费视频| 五月天久久比比资源色| 国内精品不卡| 日本一区二区精品视频| 豆国产96在线|亚洲| 欧美一级淫片免费视频黄| 欧美人在线视频| 日韩精品欧美激情一区二区| 中文字幕在线永久| 91精品国产色综合久久ai换脸 | 欧美色爱综合网|