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

如何在.NET Core中為gRPC服務(wù)設(shè)計(jì)消息文件(Proto)

開發(fā) 前端
使用協(xié)議緩沖區(qū)規(guī)范定義gRPC服務(wù)非常容易,但從需求轉(zhuǎn)換為.NET Core,然后管理服務(wù)的演變時(shí),需要注意幾件事。

本文轉(zhuǎn)載自微信公眾號(hào)「DotNET技術(shù)圈」,作者 Peter Vogel 。轉(zhuǎn)載本文請(qǐng)聯(lián)系DotNET技術(shù)圈公眾號(hào)。 

如何在.NET Core中為gRPC服務(wù)設(shè)計(jì)消息

使用協(xié)議緩沖區(qū)規(guī)范定義gRPC服務(wù)非常容易,但從需求轉(zhuǎn)換為.NET Core,然后管理服務(wù)的演變時(shí),需要注意幾件事。

創(chuàng)建gRPC服務(wù)的核心是.proto文件,該文件以與語言無關(guān)的格式描述了該服務(wù)。使用.proto文件,Visual Studio可以為您的服務(wù)生成基類(您只需編寫特定于業(yè)務(wù)的代碼),或者可以生成用于可靠訪問服務(wù)的客戶端類。

.proto文件必須符合Google的協(xié)議緩沖區(qū)規(guī)范(通常稱為ProtoBuf)。原始文件的內(nèi)容使您可以指定服務(wù)的接口。服務(wù)接口由兩部分組成:

  • 您的gRPC服務(wù)提供的方法
  • 這些方法的參數(shù)和返回值的數(shù)據(jù)結(jié)構(gòu)

您可以使用Protocol Buffers規(guī)范中[1]定義的標(biāo)量類型來構(gòu)建這些數(shù)據(jù)結(jié)構(gòu)(在ProtoBuf中稱為“消息”)。可用的類型包括布爾值,字符串,字節(jié)數(shù)組和各種數(shù)字類型(浮點(diǎn)型,整數(shù)型和長(zhǎng)型)。沒有日期或固定的十進(jìn)制類型。在接下來的專欄中,我將向您展示如何添加時(shí)間戳類型。對(duì)于小數(shù),您可以使用float ...并伴隨著float帶來的精度損失。

如果您要開始一個(gè)新項(xiàng)目,則要使用自2016年以來的proto3語法。但是,您必須在.proto文件的第一行“非空”行上明確指定proto3標(biāo)準(zhǔn)。引用規(guī)范[2]),否則將使用proto2規(guī)范解析您的.proto文件。指定您的文件使用proto3看起來像這樣:

  1. syntax = "proto3"

消息和C#類

使用proto3規(guī)范,用于客戶信息的消息格式可能如下所示:

  1. message CustomerResponse { 
  2.   int32 custid = 1; 
  3.   string firstName = 2; 
  4.   string lastName = 3; 
  5.   int32 age = 4; 
  6.   fixed32 creditLimit = 5; 

等號(hào)后的數(shù)字指定消息中字段的位置,從位置1開始(在我的示例中,firstName將是消息中的第二個(gè)字段)。這些數(shù)字在消息中必須是唯一的(即,您不能在同一位置使用兩個(gè)字段)。您不必按數(shù)字順序列出字段,但是如果您這樣做的話,則可以更輕松地發(fā)現(xiàn)重復(fù)的字段編號(hào)(盡管Visual Studio將發(fā)現(xiàn)任何重復(fù)的編號(hào),并在構(gòu)建應(yīng)用程序時(shí)將其報(bào)告在“錯(cuò)誤列表”中)。如果需要,您也可以跳過職位。此定義僅使用奇數(shù),例如:

  1. message CustomerResponse { 
  2.   int32 custid = 1; 
  3.   string firstName = 3; 
  4.   string lastName = 5; 

在.NET Core中,消息格式被轉(zhuǎn)換為類,每個(gè)字段都成為與消息同名的類的屬性。命名這些屬性時(shí),.NET Core還將字段名稱的第一個(gè)字符轉(zhuǎn)換為大寫。因此,例如,我上一個(gè)示例中的custId字段將成為我代碼中CustomerResponse類上的CustId屬性。

在此過程中,還得刪除字段名稱中的所有下劃線,并且將以下字母大寫(即,Last_name字段名稱變?yōu)長(zhǎng)astName屬性)。

該過程還涉及將.NET類型映射到ProtoBuf類型(例如,ProtoBuf int32變?yōu)?NET int,ProtoBuf的int64變?yōu)閘ong,fixed32變?yōu)閡int),這需要向.NET Core添加一些新類。例如,ProtoBuf支持字節(jié)數(shù)組,其類型為字節(jié)。名為ByteString的新.NET數(shù)據(jù)類型支持該字段類型。要加載ByteString,請(qǐng)使用ByteString類的靜態(tài)CopyFrom方法,并傳遞一個(gè)字節(jié)數(shù)組,如下所示:

  1. byte[] bytes = new byte[1000]; 
  2. cr.Valid = ByteString.CopyFrom(bytes); 

要從ByteString檢索字節(jié)數(shù)組,請(qǐng)使用對(duì)象的CopyTo方法,并傳遞要將字節(jié)復(fù)制到的數(shù)組和起始位置:

  1. cr.Valid.CopyTo(bytes,0); 

數(shù)組和字典

您也可以使用【repeated】的關(guān)鍵字將集合包括在定義中(在ProtoBuf中,不是集合的字段稱為“單數(shù)”)。如果我的客戶消息需要一組重復(fù)的交易金額,則可以指定如下字段:

  1. message Customer { 
  2.    int32 id = 1; 
  3.    repeated fixed32 transactionAmounts = 4; 

重復(fù)的字段在轉(zhuǎn)換為類的屬性時(shí),也使用新的類型:Google.Protobuf.RepeatedField。例如,我的示例將生成Google.Protobuf.RepeatedField(無符號(hào)整數(shù))的屬性。您可以使用{}語法來初始化數(shù)組,如下所示:

  1. CustomerResponse cr = new CustomerResponse 
  2.             { 
  3.                 CreditLimit = {10, 15, 100}     
  4.             }; 

您可能更可能使用其各種Add方法將項(xiàng)目放入集合中:

  1. cr.CreditLimit.Add(200); 

您可以使用LINQ方法(例如First())或按位置訪問RepeatedField中的項(xiàng)目。可以正常工作,例如:

  1. uint tranAmount = cr.CreditLimit [1]; 

ProtoBuf還支持稱為map的Dictionary-type集合,該集合允許您為字典的鍵和值指定類型。我的客戶消息可能會(huì)使用“友好名稱”來跟蹤客戶的各種信用卡,以定義一個(gè)字典,該字典包含密鑰(“彼得卡”,“我的旅行卡”)和值(信用卡號(hào))的字符串):

  1. message CustomerResponse { 
  2.   int32 custId = 1; 
  3.   map<string, string> cards = 2; 

有趣的是,在Visual Studio 2019預(yù)覽版中,編輯器不會(huì)像其他類型一樣突出顯示map對(duì)象(盡管編譯得很好)。

相應(yīng)的屬性將為Google.Protobuf.Collections.MapField類型,您可以通過將其Add方法傳遞給鍵和一個(gè)值來加載它,就像其他任何Dictionary一樣。

管理變更

上線后(客戶端開始使用它)更改.proto文件相對(duì)容易。例如,您可以將具有新位置編號(hào)的字段添加到服務(wù)器端軟件使用的.proto文件中,而不會(huì)打擾仍在使用該文件的早期版本的客戶端:客戶端只是忽略未在其.proto文件中列出的字段。

同樣,在相反的情況下(當(dāng)服務(wù)器.proto文件沒有客戶端的.proto字段具有的字段時(shí)),客戶端只會(huì)發(fā)現(xiàn)服務(wù)器未發(fā)送的屬性被設(shè)置為其默認(rèn)值。順便說一句,在服務(wù)器的.proto文件中定義的,未在客戶端的.proto文件中定義的字段仍會(huì)發(fā)送到客戶端,但是.NET不能提供一種方便的方式來訪問它(至少現(xiàn)在還沒有)。

確實(shí),隨著服務(wù)的發(fā)展和修改其.proto文件,您僅應(yīng)遵守兩個(gè)規(guī)則:

  • 不要更改現(xiàn)有字段的位置編號(hào)
  • 不要回收職位編號(hào)(即不要用新的字段3替換過時(shí)的字段3)

但是,從.proto文件生成的屬性不可為空,因此,如果未將屬性設(shè)置為值,則它將被設(shè)置為其默認(rèn)值。這意味著數(shù)字被設(shè)置為0;數(shù)字被設(shè)置為0。將string設(shè)置為string.Empty(長(zhǎng)度為零的字符串);布爾變成虛假的;ByteString屬性默認(rèn)為ByteString對(duì)象,其IsEmpty屬性設(shè)置為true;并且RepeatedField和MapField屬性均默認(rèn)為其對(duì)應(yīng)的對(duì)象,每個(gè)對(duì)象均不包含任何項(xiàng)目,并且其Count屬性設(shè)置為0。

由于這種行為,存在從服務(wù)的.proto文件中刪除字段并且不更新所有客戶端(或者只是在服務(wù)器上生成響應(yīng)時(shí)未在對(duì)象上設(shè)置屬性)的危險(xiǎn)。危險(xiǎn)是客戶端無法區(qū)分未使用的字段和已設(shè)置為其默認(rèn)值的屬性之間的區(qū)別。如果將我的客戶的有效屬性設(shè)置為false,則客戶端將無法確定客戶是否無效或服務(wù)器是否不再生成該字段。

您可能需要考慮將屬性初始化為某個(gè)“不合理的”值(例如,數(shù)字為-1),以便客戶端可以區(qū)分設(shè)置為默認(rèn)值的屬性和已刪除的字段之間的區(qū)別。因?yàn)檫@對(duì)于布爾值是不可能的(布爾值沒有不合理的值),所以您要特別警惕刪除(甚至不再使用)布爾類型的字段。

效率和局限性

正如我在較早的概述中[3]所討論的那樣[4],gRPC服務(wù)的功能之一是它們的消息比基于HTTP的(RESTful)服務(wù)小得多。如果您真的想利用這種效率,請(qǐng)注意位置1到15僅需要一個(gè)字節(jié)的額外開銷(即超出存儲(chǔ)值的數(shù)據(jù)),而位置16到2047則需要兩個(gè)字節(jié)。將消息格式保持在16位以下似乎是個(gè)好主意。

有關(guān)將數(shù)據(jù)打包到盡可能小的空間的選擇類型方面的其他效率提示,請(qǐng)參閱規(guī)范中的標(biāo)量類型說明[5]。

順便說一句,您不能使用以下任何一種作為字段位置編號(hào):負(fù)數(shù),0、19,000到19,999(保留給ProtoBuf使用)或大于536,870,911的數(shù)字。我是否也可以建議,如果您想使用這些數(shù)字,那么您將遇到在本專欄中我無法解決的問題。

真的。別那樣做。

References

[1] Protocol Buffers規(guī)范中: https://developers.google.com/protocol-buffers/docs/proto3#scalar

[2] 規(guī)范: https://developers.google.com/protocol-buffers/docs/proto3

[3] 較早的概述中: https://visualstudiomagazine.com/articles/2019/08/28/grpc-web-services.aspx

[4] 那樣: https://visualstudiomagazine.com/articles/2019/08/28/grpc-web-services.aspx

[5] 標(biāo)量類型說明: https://developers.google.com/protocol-buffers/docs/proto3#scalar

 

責(zé)任編輯:武曉燕 來源: DotNET技術(shù)圈
相關(guān)推薦

2024-05-31 12:54:37

.NET CoreLinux語言

2021-11-11 16:46:02

CPU使用率 .NET

2019-01-21 09:55:25

LinuxNET Core SD命令

2021-08-03 15:33:05

gRPC服務(wù)器

2021-01-15 05:38:28

ASPHttp端口

2021-01-13 07:33:41

API數(shù)據(jù)安全

2021-01-11 05:20:05

Controller代碼數(shù)據(jù)層

2021-02-06 21:40:13

SignalR通訊TypeScript

2021-02-02 16:19:08

Serilog日志框架

2021-11-01 14:52:38

ElasticSear索引SQL

2021-03-17 09:45:31

LazyCacheWindows

2021-01-31 22:56:50

FromServiceASP

2021-02-28 20:56:37

NCache緩存框架

2021-03-10 09:40:43

LamarASP容器

2021-02-03 13:35:25

ASPweb程序

2021-01-07 07:39:07

工具接口 Swagger

2021-01-28 22:39:35

LoggerMessa開源框架

2021-03-03 22:37:16

MediatR中介者模式

2024-04-07 09:41:18

SignalR實(shí)時(shí)通信開發(fā)

2021-03-08 07:32:05

Actionweb框架
點(diǎn)贊
收藏

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

日日夜夜亚洲精品| 国产区在线视频| 亚洲九九精品| 在线成人免费网站| 成人高清在线观看视频| 国产粉嫩在线观看| 国产精品夫妻自拍| 国产女人水真多18毛片18精品| 国产嫩bbwbbw高潮| 影音先锋成人在线电影| 亚洲美女av在线播放| av亚洲天堂网| 日本在线播放一二三区| 亚洲欧洲99久久| 麻豆成人小视频| 国产伦精品一区二区三区视频痴汉 | 国产精品伊人日日| 伊人久久国产精品| 国产农村妇女精品一区二区| 久久国产精品电影| 国产精品美女高潮无套| 国产三级精品三级在线观看国产| 欧美日韩中文字幕精品| 国产av人人夜夜澡人人爽麻豆| 成全电影播放在线观看国语| 成人国产精品免费网站| 成人午夜一级二级三级| 波多野结衣高清在线| 亚洲精品美女91| 欧美大码xxxx| 小嫩苞一区二区三区| 九九视频免费观看视频精品| 亚洲高清久久网| 俄罗斯女人裸体性做爰| 欧美高清免费| 色婷婷综合久久久中文一区二区| 国产不卡一区二区视频| 污污的视频在线观看| 国产精品福利影院| 天堂社区 天堂综合网 天堂资源最新版| 欧美视频在线观看一区二区三区| 激情综合色播五月| 国产乱人伦真实精品视频| 日本一本在线观看| 日精品一区二区三区| 88国产精品欧美一区二区三区| 久久久久无码国产精品| 亚洲精品国产偷自在线观看| 色黄久久久久久| 少妇一级黄色片| 波多野结衣在线观看一区二区三区| 亚洲成人网在线观看| 97超碰免费在线观看| 国产一区一区| 91精品国产欧美日韩| 中文字幕剧情在线观看| 精品国产一区二区三区2021| 欧美一区二区三区免费大片| 北条麻妃亚洲一区| 久久爱www.| 日韩免费电影网站| 美国黄色一级视频| 欧美精品密入口播放| 日韩精品在线观| 91l九色lporny| 日韩欧美高清| 久久资源免费视频| 欧美精品99久久久| 激情久久中文字幕| 欧美一区深夜视频| 综合久久中文字幕| 老汉av免费一区二区三区 | 粉嫩av一区二区| 亚洲国产美女精品久久久久∴| 女同性恋一区二区三区| 免费一区二区| www.久久撸.com| 欧美人妻精品一区二区免费看| 激情久久久久久久| 国产精品扒开腿爽爽爽视频| 一区二区日韩视频| 成人免费黄色在线| 日本一区二区三区四区在线观看 | 美女在线视频一区二区| 95精品视频| 亚洲高清久久网| 欧美熟妇激情一区二区三区| 91精品一区国产高清在线gif | 精品免费久久久久久久| 波多野结衣视频一区二区| 色欧美片视频在线观看在线视频| 五月天av在线播放| 精品三级av在线导航| 一本色道久久综合狠狠躁篇的优点| 日韩欧美123区| 宅男噜噜噜66国产日韩在线观看| 国产精品免费观看在线| 高h震动喷水双性1v1| 国产午夜三级一区二区三| 国产精品一二三在线观看| 忘忧草在线日韩www影院| 欧美日韩国产成人在线免费| 日韩av无码一区二区三区不卡| 欧美在线观看视频一区| 高清一区二区三区四区五区| 青青艹在线观看| 成人激情动漫在线观看| 亚洲无玛一区| 涩涩视频在线免费看| 欧美一级日韩免费不卡| wwwwxxxx国产| 国自产拍偷拍福利精品免费一| 国产福利精品av综合导导航| 亚洲av无码国产综合专区 | 欧美日韩精品久久| 图片区小说区亚洲| 欧美色视频在线观看| jizz日本免费| 国产伊人精品| 国产精品久久久久国产a级| 色婷婷激情五月| 亚洲欧美日韩人成在线播放| 丝袜制服一区二区三区| 日本午夜精品久久久| 欧美精品性视频| 亚洲系列在线观看| 国产色产综合产在线视频| 精品视频在线观看一区| 99ri日韩精品视频| 欧美成人合集magnet| 一个人看的www日本高清视频| 久久蜜桃av一区二区天堂| 秋霞无码一区二区| 成人偷拍自拍| 国语自产在线不卡| 成人午夜免费福利| 亚洲一区影音先锋| 女教师高潮黄又色视频| 一区二区三区四区电影| 国产精品精品国产| 国产98在线| 在线视频欧美区| 色综合99久久久无码国产精品| 国产精品腿扒开做爽爽爽挤奶网站| 国产精品美女诱惑| 欧美激情成人动漫| 亚洲电影成人av99爱色| 久久精品人妻一区二区三区| 国产成人三级在线观看| 18黄暴禁片在线观看| 国产香蕉精品| 欧美亚洲激情在线| 青青草免费在线| 在线一区二区三区| 99re6热在线精品视频| 久久国产剧场电影| 麻豆md0077饥渴少妇| 三级欧美日韩| 97国产精品视频人人做人人爱| 乱精品一区字幕二区| 欧美午夜视频在线观看| 国产伦理片在线观看| 免费高清不卡av| 国产欧美自拍视频| 999国产精品一区| 91精品国产色综合久久不卡98口 | 国产亚洲精品bt天堂精选| 久久久久久久少妇| 天天综合国产| 国产a一区二区| 中文在线免费二区三区| 在线视频一区二区| 99在线无码精品入口| 亚瑟在线精品视频| 免费看91的网站| 国产老女人精品毛片久久| 亚洲精品蜜桃久久久久久| 免费一区二区| 成人性生交大片免费看小说| 日本孕妇大胆孕交无码| 日韩黄在线观看| 亚洲综合网av| 亚洲大型综合色站| 卡一卡二卡三在线观看| 国产在线精品免费| 欧洲黄色一级视频| 日韩欧美综合| 国产精品国产精品国产专区蜜臀ah| 自拍在线观看| 久久亚洲精品一区| 久久天堂电影| 91精品国产91久久久久久一区二区 | 久久草.com| 亚洲一区二区小说| 91国产高清在线| 黄色av电影在线播放| 日韩高清有码在线| 一级特黄aaa大片在线观看| 偷窥国产亚洲免费视频| 99热这里只有精品4| 91亚洲精品久久久蜜桃网站| 午夜啪啪小视频| 午夜在线一区二区| 国产小视频免费| 成人a'v在线播放| 免费电影一区| 国产一区二区三区精品在线观看 | 亚洲熟女综合色一区二区三区| 成人欧美一区二区三区1314| 国产精品无码一区二区三区免费 | 9191国产精品| 亚洲自拍一区在线观看| 亚洲国产精品久久一线不卡| 啪啪一区二区三区| 国产人成一区二区三区影院| 国产精品九九视频| 国产成人精品免费一区二区| 欧美成年人视频在线观看| 久久久噜噜噜久久狠狠50岁| 阿v天堂2017| 亚洲手机视频| 女同性恋一区二区| 日韩激情图片| 四虎永久在线精品免费一区二区| 亚洲第一福利专区| 精品国产一区二区三区免费| 91精品久久久久久综合五月天| 亚洲精品免费一区二区三区| 久久精品国产福利| 国产精自产拍久久久久久| 精品国模一区二区三区| 日av在线播放中文不卡| 亚洲人体影院| 浅井舞香一区二区| 国产精品伦理| 青青久久av北条麻妃海外网| 成人观看网址| 欧美亚洲另类视频| 裤袜国产欧美精品一区| 日韩美女免费线视频| 国产伦精品一区二区三区视频金莲| 韩国三级日本三级少妇99| zzzwww在线看片免费| 97激碰免费视频| 678在线观看视频| 欧美性视频精品| jk漫画禁漫成人入口| 国产999精品久久久| 欧美xxxx做受欧美护士| 国产精品第10页| 欧美性www| 成人欧美一区二区三区在线湿哒哒 | 黄色片在线看| 在线观看91久久久久久| 亚洲s色大片| 按摩亚洲人久久| 伊人手机在线| 久久久久久久亚洲精品| 女人高潮被爽到呻吟在线观看| 91av视频在线播放| 日韩成人高清| 91久久嫩草影院一区二区| 亚洲图色一区二区三区| 国产精品大全| 伊人久久大香线蕉综合网蜜芽| 日本一区二区三区www| 欧美激情777| 美女av免费观看| 美女被久久久| 97超碰人人爽| 成人精品鲁一区一区二区| 蜜桃传媒一区二区亚洲av| 欧美高清一级片在线观看| 中文字幕五月天| 天天爽夜夜爽夜夜爽精品视频| 国产免费一区二区三区四区五区| 欧美日韩国产成人在线91| 好吊视频一区二区三区| 亚洲欧美日韩一区二区三区在线| 3d成人动漫在线| 久久久久久久久久久国产| 欧美日韩精品免费观看视完整| 成人黄色av免费在线观看| 免费萌白酱国产一区二区三区| 色播亚洲视频在线观看| 国产精品国码视频| 国产视频在线视频| 福利一区二区在线| www久久久久久久| 亚洲一区二区在线观看视频| 自拍偷拍18p| 精品动漫一区二区三区在线观看| 成人影院免费观看| 欧美激情国内偷拍| 中韩乱幕日产无线码一区| 国产伦精品一区二区| 91日韩视频| 久久精品.com| 成人亚洲精品久久久久软件| 黄色三级生活片| 婷婷开心久久网| 国产麻豆一精品一男同| 国产午夜精品一区二区三区| av资源在线看片| 91免费看片在线| 欧美理论视频| 欧美一区二区三区爽大粗免费| 国产在线视频精品一区| 美女av免费看| 欧美色道久久88综合亚洲精品| 亚洲精品成av人片天堂无码| 最近2019年手机中文字幕| 中文字幕在线高清| 99在线观看视频网站| 99久久夜色精品国产亚洲96| 日韩a在线播放| 成人sese在线| 欧美国产精品一二三| 欧美乱妇15p| lutube成人福利在线观看| 热久久免费国产视频| 欧美尿孔扩张虐视频| 国产天堂视频在线观看| 国产美女精品一区二区三区| 91精品国自产在线| 色先锋资源久久综合| 亚洲色欧美另类| 97婷婷涩涩精品一区| 成人性生交大片免费看96| 大陆极品少妇内射aaaaaa| 极品少妇xxxx精品少妇偷拍 | 姝姝窝人体www聚色窝| 欧美大片免费观看在线观看网站推荐| 日韩毛片免费看| 精品久久免费观看| 精品一区二区三区香蕉蜜桃| 91麻豆制片厂| 欧美日韩精品专区| 午夜在线视频播放| 国产美女主播一区| 国产精品88久久久久久| 日本不卡一区二区在线观看| 中文字幕一区二区三区四区不卡 | 天天综合中文字幕| 久久精品理论片| 中文字幕美女视频| 在线播放国产精品二区一二区四区| 米奇精品一区二区三区| 国产欧美日韩91| 伊人久久大香线蕉综合四虎小说 | 亚洲高清在线观看视频| 欧美精品久久一区二区| 欧美日韩看看2015永久免费| 国产xxxxx在线观看| 久久久久久一二三区| 小泽玛利亚一区二区三区视频| 一区二区三区精品99久久| 精品亚洲a∨| 成人性做爰片免费视频| 国产成人午夜高潮毛片| 青青草成人av| 伊人一区二区三区久久精品| 久久精品国产福利| 草草草视频在线观看| 波多野结衣在线一区| 波多野结衣av无码| xxxx性欧美| 福利在线一区| 亚洲狼人综合干| 亚洲欧美成人一区二区三区| 亚洲风情第一页| 欧美在线视频一二三| 日韩欧美不卡| 美女露出粉嫩尿囗让男人桶| 日韩欧美中文字幕在线观看| 天堂地址在线www| av一区二区在线看| 久久不射中文字幕| 国产成人久久久久| 国产午夜精品理论片a级探花| 日本一区二区三区中文字幕| www.av片| 国产精品久久久久久久久免费樱桃 | 4444在线观看| 26uuu久久综合| 一区二区国产欧美| 538国产精品视频一区二区| 日韩精品久久| 亚洲av无码一区二区三区观看| 欧美三级在线视频| av电影免费在线看| 亚洲在线视频一区二区| www.亚洲人| 国产精品久久久久精| 日本久久久久亚洲中字幕| 综合天堂av久久久久久久| 毛茸茸多毛bbb毛多视频| 91精品一区二区三区久久久久久| 在线能看的av网址| 日韩精品一区二区在线视频|