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

編寫 Restful 風(fēng)格的 API 接口正確姿勢(shì)

開發(fā) 前端
目前微服務(wù)架構(gòu)盛行,在了解了很多的實(shí)際微服務(wù)項(xiàng)目中,發(fā)現(xiàn)很多同時(shí)在設(shè)計(jì)業(yè)務(wù) API 接口時(shí),寫法五花八門,現(xiàn)總結(jié)下目前項(xiàng)目上設(shè)計(jì)業(yè)務(wù) API 接口的一些比較經(jīng)典誤區(qū)寫法。

背景

目前微服務(wù)架構(gòu)盛行,在了解了很多的實(shí)際微服務(wù)項(xiàng)目中,發(fā)現(xiàn)很多同時(shí)在設(shè)計(jì)業(yè)務(wù) API 接口時(shí),寫法五花八門,現(xiàn)總結(jié)下目前項(xiàng)目上設(shè)計(jì)業(yè)務(wù) API 接口的一些比較經(jīng)典誤區(qū)寫法。

[[391080]]

Restful 架構(gòu)風(fēng)格下,API 接口設(shè)計(jì)經(jīng)典誤區(qū)寫法

1、查詢某個(gè)對(duì)象接口:GET /app/getImportantApp

 

  1. @GetMapping(path = "/getImportantApp" 
  2. public R getImportionApp(@RequestHeader("pid") String pid 

2、查詢列表接口:GET /app/list

 

  1. @RequestMapping("/list" 
  2. public R list(String deptId) 

3、保存對(duì)象接口:POST /app/save

 

  1. @PostMapping("/save" 
  2. public R add(CmsAppLicationEntity appLication, String deptId) 

4、刪除對(duì)象接口:POST /app/delete

 

  1. @DeleteMapping("/delete/{applicationId}" 
  2. public R delete(@PathVariable("applicationId") long applicationId) 

5、更新對(duì)象接口:POST /app/batchUpdate

 

  1. @PostMapping("/batchUpdate"
  2. public R batchUpdate(@RequestBody List<CmsAppLicationEntity> list)  

是不是感覺很熟悉的代碼,難道寫的不對(duì)?看著挺直觀易懂的。如果采用 Restful 架構(gòu)風(fēng)格,上面這五種寫法當(dāng)然不對(duì),這是對(duì) Restful 架構(gòu)風(fēng)格不了解所致。

微信搜公眾號(hào)「猿芯」,后臺(tái)私信回復(fù) 1024 免費(fèi)領(lǐng)取 SpringCloud、SpringBoot,微信小程序、Java面試、數(shù)據(jù)結(jié)構(gòu)、算法等全套視頻資料。

Restful 架構(gòu)風(fēng)格定義

  • “Restful 是一種軟件架構(gòu)風(fēng)格、設(shè)計(jì)風(fēng)格,而不是標(biāo)準(zhǔn),只是提供了一組設(shè)計(jì)原則和約束條件。它主要用于客戶端和服務(wù)器交互類的軟件。基于這個(gè)風(fēng)格設(shè)計(jì)的軟件可以更簡潔,更有層次,更易于實(shí)現(xiàn)緩存等機(jī)制。

由于對(duì) Restful 架構(gòu)風(fēng)格理解的不夠透徹,一般會(huì)產(chǎn)生三種爭議的設(shè)計(jì)誤區(qū)。

  • 誤區(qū)一 請(qǐng)求路徑 URI 是動(dòng)詞,而不是名詞問題
  • 誤區(qū)二 URI中帶版本號(hào)問題
  • 誤區(qū)三 URI 中路徑大小寫問題

誤區(qū)一 請(qǐng)求路徑 URI 是動(dòng)詞,而不是名詞問題

按照對(duì) Restful 架構(gòu)風(fēng)格理解,每個(gè)業(yè)務(wù)實(shí)體代表一種資源,代表一個(gè)名詞。

比方說,設(shè)計(jì)產(chǎn)品列表接口時(shí):

錯(cuò)誤寫法

  1. /getProductList 

請(qǐng)求路徑 /getProductList 路徑出現(xiàn)動(dòng)詞 get,這種寫法是不對(duì)的。

推薦寫法

  1. /products 

另外 URL 出現(xiàn) /addProduct、/deleteProduct、/updateProduct 等寫法也是不對(duì)的。

如果某些動(dòng)作是 HTTP 動(dòng)詞表示不了的,你應(yīng)該把該動(dòng)作變成一種資源。

比方說,我們獲取用戶下的產(chǎn)品列表,錯(cuò)誤接口設(shè)計(jì)是:

  1. POST /users/1/getProducts 

或者

  1. POST /users/1/getProductList 

正確的寫法是把動(dòng)詞 getProducts 改成名詞 products

  1. POST /users/1/products 

誤區(qū)二 URI 中帶版本號(hào)問題

業(yè)界對(duì) URI 中是否帶版本號(hào)存在三種說法。

第一種說法是,在請(qǐng)求路徑中加入版本號(hào),比方說:

 

  1. POST /products/v1 
  2. GET /users/v1 
  3. POST /orders/v1 
  4. POST /items/v1 

這種說法認(rèn)為,在 URI 中加入版本避免了向后兼容,另外通過過期提示,重定向,文檔等手段也能降低用戶遷移到新的接口上的成本。

當(dāng)然有人贊成在請(qǐng)求路徑中加入版本號(hào),也有人反對(duì)這種加版本號(hào)的做法,他們認(rèn)為:

  • 加入版本號(hào)會(huì)讓服務(wù)接口變得混亂,經(jīng)常碰到的情況是,一些低版本的API接口調(diào)用一些高版本的API接口,導(dǎo)致數(shù)據(jù)解析錯(cuò)誤,這無疑加大了用戶遷移的成本。
  • 版本和資源的概念沒有任何關(guān)系,因此在 URI 中加入版本會(huì)讓用戶混淆。

還有一種說法是,在路徑中加版本號(hào)是錯(cuò)誤的設(shè)計(jì)方式,在老外寫的 Versioning REST Services 這篇文章指出,你應(yīng)該在請(qǐng)求頭的 Accept 指定你的版本號(hào),而不是請(qǐng)求路徑中。

例如:

 

  1. For example, for versions 1.0, 1.1, and 2.0 of the foo data type as JSON set the Accept/Content-Type header as follows: 
  2. 1.0: vnd.example-com.foo+json; version=1.0 
  3. 1.1: vnd.example-com.foo+json; version=1.1 
  4. 2.0: vnd.example-com.foo+json; version=2.0 

前端 js 在請(qǐng)求頭 Accept 指定 vnd.example-com.foo+json; version=1.1 的版本 version=1.1。

 

  1. $.ajax({ 
  2.     beforeSend: function (req) { 
  3.         req.setRequestHeader("Accept""vnd.example-com.foo+json; version=1.1");  
  4.         }, 
  5.     type: "GET"
  6.     url: "http://http://www.example.com/foo/12"
  7.     success: function (data) { 
  8.         /* code elided */ 
  9.     }, 
  10.     dataType: "json" 
  11. }); 

我個(gè)人是比較傾向請(qǐng)求路徑中加版本號(hào)的,因?yàn)槲艺J(rèn)為加版本號(hào)是站在程序角度來考慮新老版本的接口移植問題,特別是現(xiàn)在流行微服務(wù)架構(gòu),業(yè)務(wù)粒度很細(xì)的情況下,接口的升級(jí),原有版本是否保留呢?

那什么時(shí)候該加版本號(hào)呢?

  • “如果你開發(fā)的 restful 接口是開放的,你也不知道都有誰調(diào)用過,那么這個(gè)時(shí)候版本號(hào)就是必須的了。以百度地圖接口為例,百度發(fā)布了 restful 風(fēng)格的地圖接口在網(wǎng)上,全國甚至全世界各行各業(yè)都可以調(diào)用這些接口,百度要對(duì)接口進(jìn)行升級(jí),該怎么辦?如果百度直接在原有的url上進(jìn)行升級(jí),會(huì)產(chǎn)生什么樣的結(jié)果呢?不可預(yù)估。程序員:老板,咱們的產(chǎn)品崩潰了!老板:為啥?程序員:百度升級(jí)了接口!哪怕僅僅是多返回了一個(gè)字段,都可能導(dǎo)致調(diào)用者原有的代碼出現(xiàn)問題,畢竟百度無法知道所有人都是怎么解析返回值的。這個(gè)時(shí)候最好的做法就是加版本號(hào),保持原有版本,發(fā)布新的版本,所有問題迎刃而解。老用戶也不用因?yàn)榘俣鹊纳?jí),進(jìn)行代碼的更新,新用戶又能享受最新的接口,完美。

判斷是否要加版本號(hào)的方法:

  • 是否明確的知道都有誰調(diào)用了你的接口,并且能通知到,如果能,那可以不加版本號(hào);
  • restful接口升級(jí)的時(shí)候,原有版本是否保留,如果不保留,可以不加版本號(hào);

當(dāng)然,加版本號(hào)是有一定技巧的,版本號(hào)應(yīng)該放在一個(gè)功能模塊的后面,甚至一個(gè) url就應(yīng)該自己獨(dú)立的版本,如 api/user/v2,這樣調(diào)用者就不會(huì)有整套接口都升級(jí)到 v2的錯(cuò)覺。

誤區(qū)三 URI 中路徑大小寫問題

URL 中路徑最好是小寫,不要有駝峰式寫法,比如下面接口錯(cuò)誤寫法

  1. POST /orderItems/v1/1001 

推薦寫法

  1. POST /orders/v1/items/1001 

或者

  1. /order-items/v1/1001 

總結(jié)

我見過很多采用基于微服務(wù)架構(gòu)編寫的微服務(wù)代碼,大多數(shù)接口看似 restful 風(fēng)格,然而仔細(xì)辨識(shí)才發(fā)現(xiàn),原來是一堆的偽 restful 接口,要么動(dòng)詞名詞不分,要么路徑版本各種混亂。

實(shí)際上的場(chǎng)景是,restful 風(fēng)格基本上停留在口口相傳上,看起來逼格很高的東西也只能高高供起。大部分的程序員為了趕進(jìn)度,完成 KPI,那還顧得上這種規(guī)范,一直在瘋狂的打碼中。

附錄1 API 設(shè)計(jì)風(fēng)格基本規(guī)則

1、使用名詞而不是動(dòng)詞

不要使用:

 

  1. /getAllUsers 
  2. /createNewUser 
  3. /deleteAllUser 

2、Get 方法和查詢參數(shù)不應(yīng)該涉及狀態(tài)改變

使用 PUT, POST 和 DELETE 方法 而不是 GET 方法來改變狀態(tài),不要使用 GET 進(jìn)行狀態(tài)改變:

3、使用復(fù)數(shù)名詞

不要混淆名詞單數(shù)和復(fù)數(shù),為了保持簡單,只對(duì)所有資源使用復(fù)數(shù)。

 

  1. /cars 而不是 /car 
  2. /users 而不是 /user 
  3. /products 而不是 /product 
  4. /settings 而部署 /setting 

4、使用子資源表達(dá)關(guān)系 如果一個(gè)資源與另外一個(gè)資源有關(guān)系,使用子資源:

 

  1. GET /cars/711/drivers/ 返回 car 711的所有司機(jī)  
  2. GET /cars/711/drivers/4 返回 car 711的4號(hào)司機(jī) 

5、使用 Http 頭聲明序列化格式

在客戶端和服務(wù)端,雙方都要知道通訊的格式,格式在 HTTP-Header 中指定

  • Content-Type 定義請(qǐng)求格式
  • Accept 定義系列可接受的響應(yīng)格式

6、為集合提供過濾 排序 選擇和分頁等功能

Filtering 過濾: 使用唯一的查詢參數(shù)進(jìn)行過濾:

 

  1. GET /cars?color=red 返回紅色的cars  
  2. GET /cars?seats<=2 返回小于兩座位的cars集合 

Sorting 排序:允許針對(duì)多個(gè)字段排序

  1. GET /cars?sort=-manufactorer,+model 

這是返回根據(jù)生產(chǎn)者降序和模型升序排列的 car 集合。

移動(dòng)端能夠顯示其中一些字段,它們其實(shí)不需要一個(gè)資源的所有字段,給 API 消費(fèi)者一個(gè)選擇字段的能力,這會(huì)降低網(wǎng)絡(luò)流量,提高 API 可用性。

  1. GET /cars?fields=manufacturer,model,id,color 

Paging 分頁,使用 limit 和 offset.實(shí)現(xiàn)分頁,缺省 limit=20 和 offset=0;

  1. GET /cars?offset=10&limit=5 

為了將總數(shù)發(fā)給客戶端,使用訂制的 HTTP 頭:X-Total-Count。鏈接到下一頁或上一頁可以在 HTTP 頭的 link 規(guī)定,遵循 Link 規(guī)定:

 

  1. Link: <https://blog.mwaysolutions.com/sample/api/v1/cars?offset=15&limit=5>; rel="next"
  2. <https://blog.mwaysolutions.com/sample/api/v1/cars?offset=50&limit=3>; rel="last"
  3. <https://blog.mwaysolutions.com/sample/api/v1/cars?offset=0&limit=5>; rel="first"
  4. <https://blog.mwaysolutions.com/sample/api/v1/cars?offset=5&limit=5>; rel="prev"

7、版本化你的 API

使得 API 版本變得強(qiáng)制性,不要發(fā)布無版本的 API,使用簡單數(shù)字,避免小數(shù)點(diǎn)如 2.5

一般在 Url 后面使用 ?v

  1. /blog/api/v1 

8、使用 Http 狀態(tài)碼處理錯(cuò)誤

如果你的API沒有錯(cuò)誤處理是很難的,只是返回 500 和出錯(cuò)堆棧不一定有用,Http 狀態(tài)碼提供 70 個(gè)出錯(cuò),我們只要使用 10 個(gè)左右:

 

  1. 200 – OK – 一切正常 
  2. 201 – OK – 新的資源已經(jīng)成功創(chuàng)建 
  3. 204 – OK – 資源已經(jīng)成功擅長 
  4. 304 – Not Modified – 客戶端使用緩存數(shù)據(jù) 
  5. 400 – Bad Request – 請(qǐng)求無效,需要附加細(xì)節(jié)解釋如 "JSON無效" 
  6. 401 – Unauthorized – 請(qǐng)求需要用戶驗(yàn)證 
  7. 403 – Forbidden – 服務(wù)器已經(jīng)理解了請(qǐng)求,但是拒絕服務(wù)或這種請(qǐng)求的訪問是不允許的。 
  8. 404 – Not found – 沒有發(fā)現(xiàn)該資源 
  9. 422 – Unprocessable Entity – 只有服務(wù)器不能處理實(shí)體時(shí)使用,比如圖像不能被格式化,或者重要字段丟失。 
  10. 500 – Internal Server Error – API開發(fā)者應(yīng)該避免這種錯(cuò)誤。 

使用詳細(xì)的錯(cuò)誤包裝錯(cuò)誤:

 

  1.   "errors": [ 
  2.    { 
  3.     "userMessage""Sorry, the requested resource does not exist"
  4.     "internalMessage""No car found in the database" 
  5.     "code": 34, 
  6.     "more info""http://dev.mwaysolutions.com/blog/api/v1/errors/12345" 
  7.    } 
  8.   ] 

允許覆蓋http方法

一些代理只支持 POST 和 GET 方法, 為了使用這些有限方法支持 RESTful API,需要一種辦法覆蓋 http 原來的方法。使用訂制的 HTTP 頭 X-HTTP-Method-Override 來覆蓋 POST 方法.

附錄2 HTTP協(xié)議常用的動(dòng)詞說明

動(dòng)詞描述GET查詢列表或者單個(gè)對(duì)象的時(shí)候使用POST一般是提交表單或者是查詢參數(shù)比較多的時(shí)候使用PUT更新資源的時(shí)候使用DELETE刪除資源的時(shí)候使用

責(zé)任編輯:未麗燕 來源: 今日頭條
相關(guān)推薦

2022-03-28 11:10:35

ShellBash forLinux

2024-08-01 09:10:03

2018-01-11 15:31:39

命令Linux關(guān)機(jī)

2017-02-23 15:37:44

OptionObject容器

2016-05-09 10:41:03

算法分析開發(fā)

2017-07-10 13:09:45

前端Flexbox

2017-03-16 11:39:33

Openstack源碼姿勢(shì)

2023-01-30 07:41:43

2021-01-08 08:10:34

MySQL表空間回收

2017-10-12 11:30:34

Spark代碼PR

2019-12-27 15:58:57

大數(shù)據(jù)IT互聯(lián)網(wǎng)

2024-09-25 08:22:06

2016-12-12 08:48:24

2021-09-15 16:20:02

Spring BootFilterJava

2024-09-09 11:11:45

2019-10-30 17:06:50

AWS物聯(lián)網(wǎng)IoT

2016-01-05 11:28:20

按需付費(fèi)云計(jì)算docker

2020-02-24 15:26:40

Python短信免費(fèi)

2019-01-02 10:49:54

Tomcat內(nèi)存HotSpot VM

2017-06-19 17:43:04

網(wǎng)絡(luò)帶寬網(wǎng)絡(luò)設(shè)計(jì)
點(diǎn)贊
收藏

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

日韩人妻无码一区二区三区| 影音先锋中文字幕一区| 久久国产日韩| 51精品秘密在线观看| 欧美性视频网站| 伊人色在线视频| 日本福利片在线| 日韩成人一区| 久久久三级国产网站| 欧美激情在线观看| 黄色aaaaaa| 波多野结衣在线影院| 中文精品视频| 91精品国产欧美一区二区成人| 久久久水蜜桃| 国产69精品久久久久久久久久| 欧美区一区二区| 中文字幕一区二区三区在线播放 | 色网站在线视频| 好看的中文字幕在线播放| 韩国精品免费视频| 色狠狠久久aa北条麻妃| 一级黄色香蕉视频| 国产毛片在线看| 蜜桃伊人久久| 久久久综合av| 欧美性生交xxxxx| 美女精品导航| av在线一区二区| 午夜精品久久久久久久99黑人| 国产伦理在线观看| 高清电影在线观看免费| 国产精品色一区二区三区| 国产精品免费网站| 羞羞在线观看视频| 亚洲精品一区av| 亚洲视频 欧洲视频| 7777精品伊久久久大香线蕉语言| 国产探花在线播放| h视频久久久| 婷婷综合在线观看| 欧美大香线蕉线伊人久久国产精品| 国产小视频在线免费观看| 91亚洲成人| 日韩精品一区二区三区视频播放| 99久久免费观看| 天天干天天草天天射| 中日韩男男gay无套| 欧美国产在线电影| 成人免费毛片日本片视频| 91精品论坛| 国产精品家庭影院| 亚洲v欧美v另类v综合v日韩v| 亚洲一级视频在线观看| 一区二区中文| 精品欧美一区二区三区精品久久| 国产精品沙发午睡系列| 搞黄视频免费在线观看| 2020日本不卡一区二区视频| 国产区亚洲区欧美区| 一区二区视频免费看| 男人的天堂久久| 欧美天堂一区二区三区| 日本一级黄视频| 撸视在线观看免费视频| 九色综合国产一区二区三区| 欧美激情一级二级| 欧美xxxx黑人xyx性爽| 午夜日韩激情| 曰本色欧美视频在线| 欧洲成人午夜精品无码区久久| 久久国际精品| 精品国产污网站| 依人在线免费视频| 黄色污网站在线观看| 国产精品乱码一区二区三区软件| 午夜老司机精品| 欧美极品视频| 久久亚洲一区二区三区四区| 九色视频成人porny| 国产+人+亚洲| 中文字幕第80页| 米奇777四色精品人人爽| 国产精品久久一卡二卡| 色狠狠久久av五月综合| 加勒比一区二区三区在线| 国产一区二区在线免费观看| 欧美自拍视频在线| 欧美精品xxxxx| 欧美久久精品一级c片| 精品国产乱码久久久久久免费| 精人妻一区二区三区| 一本久久青青| 亚洲国产99精品国自产| 色婷婷一区二区三区在线观看| 日本精品在线播放| 制服丝袜一区二区三区| 最新中文字幕日本| 深爱激情综合网| 亚洲成人久久一区| 女女互磨互喷水高潮les呻吟| 成人爽a毛片免费啪啪红桃视频| 亚洲乱码一区二区| 国产制服丝袜在线| 成人激情自拍| 在线观看不卡av| 久草免费新视频| 日韩一区精品视频| 日本成人精品在线| 99国产在线播放| 久久精品国产免费看久久精品| 国产91色在线免费| 免费看毛片网站| 一本色道久久综合亚洲精品不卡| 国产精品电影一区| 亚洲精品无码久久久久| 日日夜夜精品视频天天综合网| 亚洲一区二区免费在线| 国产三级三级在线观看| 94色蜜桃网一区二区三区| 国产91免费视频| 欧美亚洲精品在线观看| 成人av免费在线| 国产精品香蕉视屏| 亚洲av成人精品一区二区三区在线播放 | 欧美videofree性高清杂交| 免费看黄色三级| 加勒比久久综合| 亚洲人成网在线播放| 久久久久亚洲av成人无码电影| 亚洲草久电影| 欧美人与物videos| 日韩三级视频在线| 丝袜a∨在线一区二区三区不卡 | 国产一级特黄aaa大片| 亚洲小说区图片区| 成人激情视频在线观看| 精品国产黄色片| 成人午夜伦理影院| 女同一区二区| 97最新国自产拍视频在线完整在线看| 中国av一区二区三区| 中文字幕中文字幕99| av大片在线| 午夜成人免费电影| 亚洲乱码国产一区三区| 日韩理论电影中文字幕| 国产一区二区久久精品| 国产午夜精品理论片在线| 欧美特黄一区| 日韩av成人在线| 色视频在线观看| 欧美日韩精品国产| 中日韩av在线播放| 成功精品影院| 国产做受高潮69| 欧美自拍偷拍一区二区| 亚洲国产美国国产综合一区二区| 中文字幕乱码人妻综合二区三区| 精品女同一区二区三区在线观看| 日韩欧美久久久| 成人观看免费视频| 国产99精品在线观看| 日韩精品第一页| 欧美日韩在线视频免费观看| 日韩一级高清毛片| 久久丫精品忘忧草西安产品| 久久人人精品| 亚洲精品国产精品国自产观看| 污片在线免费观看| 欧美在线免费播放| 制服.丝袜.亚洲.中文.综合懂| 欧美精品导航| 国产一区二区三区无遮挡| 欧美激情二区| 日韩一区二区精品在线观看| 久久国产精品波多野结衣av| 不卡的av电影| caopor在线视频| youjizz亚洲| 2023亚洲男人天堂| 日韩大片在线永久免费观看网站| 午夜精品久久久久久久久久 | 国产美女主播在线| 成人激情视屏| 日韩av在线网页| 欧美成人精品欧美一级| 国产91精品免费| 能在线观看的av| 婷婷激情综合| 国产精品亚洲自拍| 午夜性色福利影院| 欧洲精品一区二区三区在线观看| 国产探花在线视频| 波多野结衣中文字幕一区二区三区| 欧美 国产 小说 另类| 91麻豆精品国产91久久久平台 | 欧美精品在线免费| 中文字幕精品一区二| 97久久超碰国产精品| 欧美伦理片在线看| 国产一区日韩欧美| http;//www.99re视频| 国产原创精品视频| 欧美日本乱大交xxxxx| 国产精品久久久久无码av色戒| 老司机一区二区| 日日碰狠狠添天天爽超碰97| 国产成人aa在线观看网站站| 欧美激情亚洲精品| 国产福利片在线| 亚洲第一色中文字幕| 一级黄色大毛片| 欧美日韩一区二区免费在线观看 | 99久久激情| 欧美凹凸一区二区三区视频 | 久久一日本道色综合久久| 亚洲国产一二三精品无码| 欧美中文一区二区| 国产精品美女免费看| eeuss鲁一区二区三区| 欧美精品一区二区蜜臀亚洲| 亚洲视频久久久| 一本色道久久加勒比精品| 亚洲国产日韩一区无码精品久久久| 国产一区二区三区美女| 少妇网站在线观看| 99久久精品国产亚洲精品| 欧美日韩综合另类| 老牛影视av一区二区在线观看| 97在线精品视频| av在线播放国产| 亚洲成人黄色在线| 国产999久久久| 亚洲成精国产精品女| 手机在线免费看片| 成人av在线播放网址| 亚洲视频在线不卡| 亚洲国产三级| 日本成人黄色| 人人玩人人添人人澡欧美| 欧洲成人在线观看| 色在线中文字幕| 中日韩美女免费视频网站在线观看| 中文字幕第99页| 欧美午夜寂寞影院| 亚洲av无码乱码国产精品fc2| 欧美性xxxxx极品娇小| 国产免费嫩草影院| 国产成人午夜视频| 日韩 欧美 高清| 久久国产精品亚洲77777| 欧美丰满熟妇bbbbbb百度| 亚洲区第一页| 国产美女网站在线观看| 鲁一鲁一鲁一鲁一av| 黄网站视频在线观看| 中文字幕亚洲欧美日韩2019| 国产精品一二三区视频| 欧美一区综合| 欧美不卡福利| 欧美在线色图| 国产91av视频在线观看| 超碰在线视屏| 午夜精品国产精品大乳美女| 国内激情视频在线观看| 欧美综合在线第二页| 日本精品不卡| 色噜噜狠狠狠综合曰曰曰| eeuss影院www在线观看| 社区色欧美激情 | 成人ww免费完整版在线观看| 欧美人成在线视频| 中文字幕在线官网| 久久99热这里只有精品国产| 欧美卡一卡二| 欧美性受xxxx黑人猛交| 主播大秀视频在线观看一区二区| 欧美激情影音先锋| 亚洲精品一区| 成人疯狂猛交xxx| 玖玖玖免费嫩草在线影院一区| 欧美一区免费视频| 五月久久久综合一区二区小说| 精品一区二区三区无码视频| 国产精品毛片一区二区三区| 国产一级特黄a大片免费| 韩国午夜理伦三级不卡影院| 亚洲高清无码久久| 国产成人综合自拍| 亚洲最大成人免费视频| 精品视频成人| 国产亚洲欧美一区二区 | 成人欧美一区二区三区黑人免费| 精品国产午夜肉伦伦影院| 日本在线一区| 欧美国产专区| 日韩在线xxx| 国产成人精品aa毛片| 国产网站无遮挡| www.欧美亚洲| 国产成人免费观看网站| 免费在线观看成人| 日韩精品―中文字幕| 日本特黄久久久高潮| 欧美色图色综合| 九色porny丨国产精品| 五月天激情小说| 成人午夜免费av| 5252色成人免费视频| 日韩毛片在线| 国产伦精品一区二区三区高清| 日本激情一区| av免费观看网| 福利91精品一区二区三区| 国产真人真事毛片视频| 香蕉av福利精品导航| 国产人妻精品一区二区三| 国产亚洲视频在线观看| 国产精品xx| 99精彩视频| 欧美电影三区| 无码日韩人妻精品久久蜜桃| kk眼镜猥琐国模调教系列一区二区| 成人做爰视频网站| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 日本视频www| 在线播放91灌醉迷j高跟美女 | 日韩激情av在线免费观看| 午夜激情在线| 91久久久在线| 欧洲一区在线| 在线观看国产一区| 青椒成人免费视频| 性高潮久久久久久久| 欧美日韩亚洲成人| 无码精品人妻一区二区| 国内精品久久久久影院 日本资源| 亚洲专区**| 久久大片网站| 亚洲激情专区| 久久精品aⅴ无码中文字字幕重口| 亚洲女同ⅹxx女同tv| 黄色一级视频免费| 欧美一区午夜视频在线观看| 欧美18hd| 国产欧美日韩高清| 999精品色在线播放| 亚洲美女爱爱视频| 亚洲欧洲在线观看av| 国产主播在线观看| 91福利在线看| 性一交一乱一透一a级| 亚洲美女www午夜| 伊人成综合网站| 麻豆av一区二区三区久久| 亚洲精品婷婷| 亚洲精品乱码久久久久久久| 懂色aⅴ精品一区二区三区蜜月| 天堂在线视频观看| 欧美自拍大量在线观看| 欧美另类69xxxxx| 中文字幕亚洲乱码| 亚洲女人小视频在线观看| 亚洲a视频在线观看| 97免费在线视频| 国产日产精品_国产精品毛片| 看欧美ab黄色大片视频免费 | 美女网站视频久久| www.av免费| 亚洲第一天堂av| 26uuu亚洲电影| 中文字幕成人一区| 国产成人综合在线| 综合激情网五月| 91精品婷婷国产综合久久竹菊| 国产色在线观看| 国产伦精品一区二区三区视频免费 | 亚洲精品一区二区网址| 中文国产字幕在线观看| 国产91精品一区二区绿帽| 久久久蜜桃一区二区人| 色哟哟一一国产精品| 精品精品欲导航| 日本不卡一二三| 日韩video| 久久国产综合精品| 国产无码精品视频| 国产亚洲一级高清| 国产视频一区二区在线播放| 日日噜噜噜噜夜夜爽亚洲精品| 精品一区二区国语对白| 国产午夜精品无码一区二区| 亚洲天堂久久av| 色悠久久久久综合先锋影音下载| 亚洲熟妇国产熟妇肥婆| 国产精品入口麻豆原神| 三级在线观看网站| 国产日产久久高清欧美一区| 亚洲精品女人|