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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

SharePoint 2013开发入门探索(二)- 列表操作

發(fā)布時間:2023/12/10 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SharePoint 2013开发入门探索(二)- 列表操作 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

?? 我們?nèi)绾斡么a對SharePoint列表做些例如增刪改查的操作呢?如果您的程序可以部署到服務(wù)器上,就可以使用?服務(wù)器對象模型,因為服務(wù)器對象模型提供的功能最多,限制最少;否則可能要選擇客戶對象模型等其他方式,這可能會遇到一些功能限制;另外還有一些其他的訪問方式,例如Web服務(wù)等。如何在 SharePoint 2013 中選擇正確的 API 集請參考鏈接?http://msdn.microsoft.com/zh-cn/library/jj164060.aspx。

?????我們首先研究下服務(wù)器對象模型。使用服務(wù)器對象模型需要到服務(wù)器端部署,所以沒有服務(wù)器部署權(quán)限的話就不能使用了。使用服務(wù)對象模型要引用程序集Microsoft.SharePoint —— 如果您創(chuàng)建的是SharePoint項目,這個引用默認(rèn)就會有的。

?????? 在服務(wù)器對象模型中我經(jīng)常使用的幾個.NET類是SPSite、SPWeb、SPList還有SPListItem,下面簡單介紹下這幾個類。

???????網(wǎng)站集(由一個首要網(wǎng)站以及該網(wǎng)站下的所有網(wǎng)站組成,參考:http://technet.microsoft.com/zh-cn/library/cc262410.aspx)對應(yīng)的類是SPSite,可以傳參網(wǎng)站集URL給SPSite的構(gòu)造方法創(chuàng)建對象。一般您可以這樣用。

using (SPSite spSite = new SPSite("http://SharePointServer/")) {//TODO...... }

????? 有時候你可能要提升一下權(quán)限以場管理員身份執(zhí)行,則可以用下面的寫法——這是服務(wù)器對象模型的優(yōu)勢,但是如果項目選擇為“部署為沙盒解決方案”則不能提升到場管理員權(quán)限。

?

SPSecurity.RunWithElevatedPrivileges(() =>{using (SPSite spSite = new SPSite("http://SharePointServer/")){//TODO......} });

?

????? SharePoint里的用戶對應(yīng)的是SPUser類,也可以使用SPUserToken構(gòu)造網(wǎng)站集對象實現(xiàn)模擬用戶身份執(zhí)行代碼。

?

SPSecurity.RunWithElevatedPrivileges(() =>{using (SPSite spSite = new SPSite("http://SharePointServer/")){SPUser imitatedUser = spSite.RootWeb.EnsureUser(@"contoso\sanzhang");SPUserToken token = imitatedUser.UserToken;using (SPSite siteWithUser = new SPSite("SharePointServerUrl", token)){//TODO......}}});

?

??????網(wǎng)站對應(yīng)的類是SPWeb,SPSite有一個RootWeb屬性,是網(wǎng)站集的根網(wǎng)站;SPSite還有個AllWebs屬性,是它的所有網(wǎng)站集合(可以用索引訪問),要得到SPWeb對象還可以調(diào)用SPSite對象的OpenWeb方法,傳給一個URL參數(shù)(根網(wǎng)站的URL和網(wǎng)站集是相同的,所以下面的代碼傳空字符串,其他子網(wǎng)站要傳標(biāo)識網(wǎng)站的URL部分)。每個SPWeb對象也有個Webs屬性,是這個網(wǎng)站的子網(wǎng)站(也可以用索引訪問)。

?

using (SPSite spSite = new SPSite("http://SharePointServer/")) {//獲取網(wǎng)站集根網(wǎng)站對象SPWeb spRootWeb = spSite.RootWeb;Console.WriteLine("網(wǎng)站集的根網(wǎng)站是{0}", spRootWeb.Title);//用網(wǎng)站ID獲取子網(wǎng)站對象Guid webId = new Guid("{4a106421-ae78-40fd-ad62-77fecb67cf27}");SPWeb spWeb = spSite.AllWebs[webId];Console.WriteLine("該網(wǎng)站是{0}", spWeb.Title);spWeb = spRootWeb.Webs[webId];Console.WriteLine("該網(wǎng)站是{0}", spWeb.Title);//用網(wǎng)站名稱獲取子網(wǎng)站對象string name = "mysubweb1";spWeb = spSite.AllWebs[name];Console.WriteLine("該網(wǎng)站是{0}", spWeb.Title);spWeb = spRootWeb.Webs[name];Console.WriteLine("該網(wǎng)站是{0}", spWeb.Title);//用網(wǎng)站URL獲取子網(wǎng)站對象string url = @"/mysubweb1";spWeb = spSite.OpenWeb(url);Console.WriteLine("該網(wǎng)站是{0}", spWeb.Title); }

?

?????獲取對網(wǎng)站和其他關(guān)鍵對象的引用請參考:http://msdn.microsoft.com/zh-cn/library/ms468609(v=office.14).aspx。

???? 列表對應(yīng)的類是SPList,其實SPList類對應(yīng)的不僅僅是狹義的自定義列表,文檔庫、圖片庫、日歷、通知、任務(wù)都可以用它來操作,還有網(wǎng)站資產(chǎn)、用戶信息列表、解決方案庫、列表模版庫、Web部件庫等等。SPWeb對象有個Lists屬性,是SPListCollection類型,遍歷它或者用ID、Title做索引可得到SPList對象。想了解網(wǎng)站中有哪些List可以用下面的代碼查看:

?

//獲取網(wǎng)站所有列表foreach (SPList list in spWeb.Lists){Console.WriteLine("Title:{0} BaseType:{1} BaseTemplate:{2}", list.Title, list.BaseType, list.BaseTemplate);}//用列表標(biāo)題獲取列表對象string title = @"我的客戶列表";SPList spList = spWeb.Lists[title];Console.WriteLine("該列表是{0}。", spList.Title);//用列表ID獲取列表對象Guid id = new Guid(@"{3824b091-c7b8-409c-bcc0-7cce487d6b49}");spList = spWeb.Lists[id];Console.WriteLine("該列表是{0}。", spList.Title);//用列表URL獲取列表對象string listUrl = string.Format(@"{0}/{1}", spWeb.Url, "Lists/MyCustomerList/AllItems.aspx");spList = spWeb.GetList(listUrl);Console.WriteLine("該列表是{0}。", spList.Title);

?

??????您還是否記得這些列表屬性,我們在開發(fā)自定義列表時都設(shè)置過?

????? 列表項對應(yīng)的類是SPListItem,SPList對象的Items屬性是它的項目的集合,是SPListItemCollection類型的,枚舉它的元素就是SPListItem對象了。不過您想訪問列表項的時候一般不要直接通過SPList對象的Items屬性,特別是已經(jīng)存儲了很多項目的大數(shù)據(jù)列表,因為可能會有不必要的數(shù)據(jù)加載影響性能。例如您想知道列表中已存在多少個項目,可以直接訪問SPList對象的ItemCount屬性,而不是SPList對象的Items屬性的Count;如果您想得到列表中的某個項目可以調(diào)用SPList對象的GetItemById、GetItemByUniqueId等方法。

?

//用列表標(biāo)題獲取列表對象SPList spList = spWeb.Lists["我的客戶列表"];//獲取用戶信息列表的項目數(shù)量int userCount = spList.ItemCount;Console.WriteLine("我的客戶列表共有{0}條項目。", userCount.ToString());//用項目ID獲取項目對象int itemId = 18;SPListItem spListItem = spList.GetItemById(itemId);Console.WriteLine("該客戶是{0}。", spListItem.Title);//用項目UniqueID獲取項目對象Guid itemUniqueId = new Guid("{83815a27-6291-416d-8db6-a77bcae4bb86}");spListItem = spList.GetItemByUniqueId(itemUniqueId);Console.WriteLine("該客戶是{0}。", spListItem.Title);

?

????? 列表對象還有一個Fields的屬性,是SPFieldCollection類型,遍歷這個字段集合可以得到SPField對象。這就是列表的字段信息,包括字段內(nèi)部名稱、顯示名稱、類型等等。我們要訪問列表項目的某個屬性時就可以用SPField對象的ID,InternalName或Title。

?

string title = @"我的客戶列表";SPList spList = spWeb.Lists[title];SPFieldCollection spFields = spList.Fields;//獲取列表的字段信息foreach (SPField field in spFields){Console.WriteLine("Title:{0} InternalName:{1} TypeDisplayName:{2} TypeAsString:{3}", field.Title, field.InternalName, field.TypeDisplayName, field.TypeAsString);}Guid fieldId = new Guid("{a943ca8c-a2ad-4a90-8a78-2f6a202f6553}");SPField spField = spFields[fieldId];SPListItem spListItem = spList.Items[0];//用字段的ID訪問列表項目屬性Console.WriteLine("該用戶的消費金額是{0}。", spListItem[spField.Id].ToString());//用字段的InternalName訪問列表項目屬性Console.WriteLine("該用戶的消費金額是{0}。", spListItem[spField.InternalName].ToString());Console.WriteLine("該用戶的消費金額是{0}。", spListItem.GetFormattedValue(spField.InternalName));//用字段的Title訪問列表項目屬性Console.WriteLine("該用戶的消費金額是{0}。", spListItem[spField.Title].ToString());Console.WriteLine("該用戶的消費金額是{0}。", spListItem.GetFormattedValue(spField.Title));

?

????? 您還記得開發(fā)自定義列表欄的時候我們一起設(shè)置的那些字段屬性嗎?

????? SPList對象還有個GetItemByIdAllFields方法和GetItemByIdSelectedFields方法。看來我們可以按需索取項目字段了。

?

//用列表標(biāo)題獲取列表對象string title = @"我的客戶列表";SPList spList = spWeb.Lists[title];int itemId = 1;SPListItem spListItem = spList.GetItemByIdSelectedFields(itemId, new[] { "CustomerName", "Recency", "Frequency", "Monetary" });//用項目的ID和字段的InternalName訪問列表項目Console.WriteLine("客戶{0}的最近消費時間是{1}消費頻率是{2}消費金額是{3}。", spListItem["CustomerName"].ToString(), spListItem["Recency"].ToString(), spListItem["Frequency"].ToString(), spListItem["Monetary"].ToString());

?

????? 不過,我把GetItemByIdSelectedFields方法的數(shù)組參數(shù)減掉了兩個項"Frequency"和"Monetary"再運行,竟然沒有看到我期待的、閃電般美麗的異常!不是說只要兩個字段嗎?而且隨后我把SPListItem對象的Xml屬性也輸出時有看到了好多不是我指定索取的字段信息!

?

string title = @"我的客戶列表";SPList spList = spWeb.Lists[title];int itemId = 1;//刪掉"Frequency"、 "Monetary" SPListItem spListItem = spList.GetItemByIdSelectedFields(itemId, new[] { "CustomerName", "Recency"});//用項目的ID和字段的InternalName訪問列表項目Console.WriteLine("客戶{0}的最近消費時間是{1}消費頻率是{2}消費金額是{3}。", spListItem["CustomerName"].ToString(), spListItem["Recency"].ToString(), spListItem["Frequency"].ToString(), spListItem["Monetary"].ToString());Console.WriteLine(@"XML:{0}",spListItem.Xml);

?

?????? 查看一下GetItemByIdSelectedFields方法的源代碼,發(fā)現(xiàn)在拼接CAML查詢字段時有個對SPField對象MustFetchByDefault的判斷,如果這個屬性是True,沒有指定也會查詢,而且這個SPField對象MustFetchByDefault屬性是internal的。

?

public SPListItem GetItemByIdSelectedFields(int id, params string[] fields) {if (fields == null){throw new ArgumentNullException("fields");}StringBuilder builder = new StringBuilder();foreach (string str in fields){if (str != null){builder.Append("<FieldRef Name=\"" + str + "\"/>");}}foreach (SPField field in this.Fields){bool flag = false;foreach (string str2 in fields){if (str2 == field.InternalName){flag = true;break;}}if (!flag && field.MustFetchByDefault){builder.Append("<FieldRef Name=\"");builder.Append(field.InternalName);builder.Append("\"/>");}}return this.GetItemById(id, null, false, builder.ToString()); }

?

?????? 如何讀取列表項中字段的值請參考:http://msdn.microsoft.com/zh-cn/library/ff521580(v=office.14).aspx。

?????? 在讀取項目屬性時,有些類型是比較特殊的:例如多個用戶或用戶組,它可以轉(zhuǎn)為SPFieldUserValueCollection類型,這是個SPFieldUserValue對象的集合;?用戶或用戶組?、超鏈接或圖片這樣的字段取出來時String類型,您要解析可以用字符串截取方式,也可以對應(yīng)構(gòu)造成SPFieldUserValue、SPFieldUrlValue對象,直接訪問它們的屬性。

?

SPListItem spListItem = spList.GetItemById(itemId);//直接ToString,用戶是[ID]+[;#] + [顯示名];鏈接是[URL] + [,] + [顯示文本]Console.WriteLine("客戶的分享者是{0} 所有者是{1} 業(yè)務(wù)系統(tǒng)鏈接是{2}。", spListItem["Sharers"], spListItem["Owner"].ToString(), spListItem["BusinessPage"].ToString());//截取字符串取屬性Console.WriteLine("客戶的所有者的顯示名是{0} 業(yè)務(wù)系統(tǒng)鏈接的URL是{1}。", spListItem["Owner"].ToString().Split(new[] { @";#" }, StringSplitOptions.None)[1], spListItem["BusinessPage"].ToString().Split(',')[0]);//轉(zhuǎn)為相應(yīng)對象取屬性SPFieldUserValueCollection shares = (SPFieldUserValueCollection)spListItem["Sharers"];foreach (SPFieldUserValue share in shares){if (share.User != null){SPUser user = share.User;Console.WriteLine(@"找到個用戶{0}", user.Name);}else{SPGroup spGroup = spWeb.Groups.GetByID(share.LookupId);Console.WriteLine(@"找到個用戶組{0}", spGroup.Name); }}SPFieldUserValue owner = new SPFieldUserValue(spWeb, spListItem["Owner"].ToString());SPFieldUrlValue businessPage = new SPFieldUrlValue(spListItem["BusinessPage"].ToString());Console.WriteLine("客戶的業(yè)務(wù)系統(tǒng)鏈接的URL是{0} 業(yè)務(wù)系統(tǒng)鏈接的描述是{1}。", businessPage.Url, businessPage.Description);

?

???? ? 如果您想按某些條件得到列表中的幾個項目,則可以使用CAML列表查詢了。上文中我們查看SPList的源代碼,看到了一段XML的拼接,這就是CAML。協(xié)作應(yīng)用程序標(biāo)記語言 (CAML) 簡介請參考:http://msdn.microsoft.com/zh-cn/library/ms426449.aspx。

???????如果要直接使用CAML做查詢可以使用SPList對象的GetItems方法,這個方法的參數(shù)是一個SPQuery對象。SPQuery對象的ViewFields是返回字段(個人理解ViewFieldsOnly要設(shè)置為True時ViewFields才有效,但是我嘗試中發(fā)現(xiàn)不設(shè)置“ViewFieldsOnly=true”返回的結(jié)果是一樣的。另外,ID、Created、Modified等屬性一直會被返回的),Query是查詢條件,這就相當(dāng)于SQL語句里的"SELECT ..."和“WHERE...”了。GetItems方法的返回值是一個SPListItemCollection對象,如果喜歡用DataTable的話,可以調(diào)用它的GetDataTable()對象。舉個簡單的查詢例子,查詢名稱為張三的客戶:

?

SPList spList = spWeb.Lists[title];SPQuery spQuery = new SPQuery();spQuery.ViewFields = @"<FieldRef Name='CustomerName'/><FieldRef Name='Gender'/><FieldRef Name='Monetary'/><FieldRef Name='BusinessPage'/><FieldRef Name='Owner'/><FieldRef Name='Sharers'/>";//spQuery.ViewFieldsOnly = true;spQuery.Query = @"<Where><Eq><FieldRef Name='CustomerName'/><Value Type='Text'>張三</Value></Eq></Where>";SPListItemCollection spListItemCollection = spList.GetItems(spQuery);//將結(jié)果保存到DataTableDataTable dataTable = spListItemCollection.GetDataTable();Console.WriteLine(spQuery.ViewFieldsOnly.ToString());if (spListItemCollection.Count > 0){foreach (SPListItem spListItem in spListItemCollection){Console.WriteLine(spListItem["CustomerName"]);Console.WriteLine(spListItem.Xml);}}

????? CAML查詢條件有很多比較符:Eq(=)、Gt(>)、Lt(<)、Geq(>=)、Leq(<=)、Neq(<>)、Contains(Like)、IsNull(Null)、IsNotNull(NotNull)等,多個查詢條件可以使用關(guān)系運算符And或Or(http://msdn.microsoft.com/zh-cn/library/ms467521(v=office.14).aspx)。再舉一個例子:自定義列表-我的客戶列表有一個Sharers字段(表示分享用戶列表),這個字段可存儲多個用戶和組,現(xiàn)在有一個用戶甲,要查詢分享給這個用戶或這個用戶所在的組的數(shù)據(jù)則使用如下代碼:

string title = @"我的客戶列表";SPList spList = spWeb.Lists[title];SPUser user = spWeb.EnsureUser(loginName);SPGroup[] groups = user.Groups.Cast<SPGroup>().ToArray();SPQuery spQuery = new SPQuery();spQuery.ViewFields = @"<FieldRef Name='CustomerName'/><FieldRef Name='Gender'/><FieldRef Name='Monetary'/><FieldRef Name='BusinessPage'/><FieldRef Name='Owner'/><FieldRef Name='Sharers'/>";spQuery.ViewFieldsOnly = true;if (groups.Length > 0){StringBuilder query = new StringBuilder();query.AppendFormat(@"<Where><Or><Includes><FieldRef Name='Sharers' LookupId=""TRUE"" /><Value Type='User'>{0}</Value></Includes>", user.ID.ToString());Array.ForEach(groups, g => query.AppendFormat(@"<Includes><FieldRef Name='Sharers' LookupId='TRUE' /><Value Type='Group'>{0}</Value></Includes>", g.ID.ToString()));query.Append(@"</Or></Where>");spQuery.Query = query.ToString();}else{spQuery.Query = string.Format(@"<Where><Includes><FieldRef Name='Sharers' LookupId='TRUE' /><Value Type='User'>{0}</Value></Includes></Where>", user.ID.ToString());}DataTable dataTable = spList.GetItems(spQuery).GetDataTable();

????? SPQuery對象的ViewAttributes屬性可以設(shè)置檢索范圍;RowLimit是返回數(shù)量ListItemCollectionPosition是查詢位置,用這兩個屬性可以實現(xiàn)分頁查詢;列表中如果包含文件夾并且查詢要在指定文件夾下執(zhí)行,可以使用Folder屬性。

?????? SPQuery類使用請參考http://technet.microsoft.com/zh-cn/library/microsoft.sharepoint.spquery.aspx?;如果您需要跨網(wǎng)站多列表混合查詢,可以使用SPSiteDataQuery 類,http://msdn.microsoft.com/zh-cn/library/microsoft.sharepoint.spsitedataquery.aspx;查詢列表項請參考http://msdn.microsoft.com/zh-cn/library/ms456030(v=office.14).aspx。如果您覺得拼寫CAML有些麻煩,也可以到網(wǎng)站找一些小工具下載使用,例如:http://sharepointcamlhelper.codeplex.com/。關(guān)于查詢性能,有幾篇個人覺得不錯的文章:http://msdn.microsoft.com/zh-cn/subscriptions/ee557257.aspx,http://www.infoq.com/cn/articles/SharePoint-Andreas-Grabner。

???? ?新增列表項目可以先調(diào)用SPList對象的AddItem方法,獲取一個新的SPListItem對象,在給SPListItem的所需字段賦值后再調(diào)用它的Update方法即可保存新增(SPListItem對象還有個SystemUpdate方法,這個方法在修改時不會影響修改時間和修改者,另外還可以用參數(shù)指定是否創(chuàng)建新版本)。

SPUser user1 = spWeb.EnsureUser(loginName1);SPUser user2 = spWeb.EnsureUser(loginName2);SPGroup group1 = spWeb.Groups[loginName3];string title = @"我的客戶列表";SPList spList = spWeb.Lists[title];SPListItem spListItem = spList.AddItem();spListItem["CustomerName"] = "趙六";spListItem["Gender"] = "女";spListItem["EMail"] = "liuzhao@contoso.com";spListItem["CellPhone"] = "13456435678";spListItem["WorkAddress"] = "西直門";spListItem["Recency"] = DateTime.Now;spListItem["Frequency"] = 0.5;spListItem["Monetary"] = 100000;spListItem["BusinessPage"] = new SPFieldUrlValue() { Url = "http://zhaoliu.com", Description = "趙六的個人主頁" };spListItem["CustomerType"] = "鉆石";spListItem["Owner"] = new SPFieldUserValue(spWeb, user1.ID, user1.Name);spListItem["Sharers"] = new SPFieldUserValueCollection { new SPFieldUserValue(spWeb, user1.ID, user1.Name),new SPFieldUserValue(spWeb, user2.ID, user2.Name), new SPFieldUserValue(spWeb, group1.ID, group1.Name) };spListItem.Update();

????? 在給項目的字段賦值時,對于用戶或用戶組、超鏈接或圖片這樣的字段,也可以直接以字符串賦值。用戶或用戶組的ID和顯示名要以“;#”連接,超鏈接或圖片則以“,”連接URL和描述。

spListItem["BusinessPage"] = string.Format(@"{0},{1}", "http://sunqi.com", "孫七的個人主頁"); spListItem["Owner"] = new SPFieldUserValue(spWeb, string.Format(@"{0};#{1}", user2.ID.ToString(), user2.Name));spListItem["Sharers"] = string.Join(@";#", user1.ID.ToString(), user1.Name, user2.ID.ToString(), user2.Name, group1.ID.ToString(), group1.Name);

?????? 如果項目有個附件文件如何上傳呢?這個還很簡單,只要使用SPListItem對象的Attachments屬性就可以了。這是一個SPAttachmentCollection類型的SPAttachment集合,它有一個Add方法。

spListItem.Attachments.Add(Path.GetFileName(@"C:\1.txt"), File.ReadAllBytes(@"C:\1.txt"));

????? 上文我們提到,對文檔庫的操作也要使用SPList類,可是我看了一下SPListItem對象的File屬性——它是只讀的。 那么如何給文檔庫創(chuàng)建文件夾和上傳文件呢?這次創(chuàng)建文件夾或文件的項目要用到SPList對象的AddItem重載方法,相關(guān)的SPFolder和SPFile也可以通過列表的網(wǎng)站SPWeb對象獲取。

string title = @"我的文檔庫";SPList spList = spWeb.Lists[title];//創(chuàng)建一個文件夾的SPListItem對象SPListItem folderListItem = spList.AddItem(spList.RootFolder.ServerRelativeUrl, SPFileSystemObjectType.Folder, "文件夾2");folderListItem.Update();//找到網(wǎng)站對應(yīng)文件夾SPFolder對象SPFolder spFolder = spList.ParentWeb.GetFolder(folderListItem.UniqueId);bool allowUnsafeUpdates = spWeb.AllowUnsafeUpdates;//如果AllowUnsafeUpdates是False可能下面操作會有異常spWeb.AllowUnsafeUpdates = true;//在指定文件夾下添加文件spFolder.Files.Add(Path.GetFileName(@"C:\1.txt"), File.ReadAllBytes(@"C:\1.txt"));spWeb.AllowUnsafeUpdates = allowUnsafeUpdates;

????? 再看看修改和刪除列表項目就非常簡單了。(參考資料:http://msdn.microsoft.com/zh-cn/library/ms467435(v=office.14).aspx)

string title = @"我的客戶列表";SPList spList = spWeb.Lists[title];//修改:int itemId = 5;SPListItem spListItem = spList.GetItemById(itemId);spListItem["CustomerName"] = "孫七七";spListItem.Update();//刪除://spListItem.Delete();

?????? 不過要高效的批量執(zhí)行增刪改操作還是需要SPWeb對象的ProcessBatchData方法。命令語法請參考:http://msdn.microsoft.com/zh-CN/library/ms455433(v=office.12).aspx、http://msdn.microsoft.com/zh-cn/library/microsoft.sharepoint.spweb.processbatchdata.aspx、http://msdn.microsoft.com/zh-cn/library/cc404818.aspx。下面代碼是插入、修改和刪除的例子,對于多個用戶和組、超鏈接或圖片還是使用的字符串拼接(用戶和組用“;#”連接ID和顯示名稱,超鏈接或圖片用空格+逗號+空格連接URL和描述),還有時間類型字段,要轉(zhuǎn)換為ISO8601格式,可以調(diào)用SPUtility類的CreateISO8601DateTimeFromSystemDateTime方法創(chuàng)建(http://msdn.microsoft.com/zh-cn/library/ms197282(v=office.14).aspx)。

SPUser user1 = spWeb.EnsureUser(loginName1);SPUser user2 = spWeb.EnsureUser(loginName2);SPGroup group1 = spWeb.Groups[loginName3];string listId = @"3824b091-c7b8-409c-bcc0-7cce487d6b49";StringBuilder strBatchData = new StringBuilder(@"<?xml version=""1.0"" encoding=""UTF-8""?><Batch>");//命令頭:string setListText = string.Format(@"<SetList Scope=""Request"">{0}</SetList>", listId);//插入數(shù)據(jù):strBatchData.AppendFormat(@"<Method ID=""Insert,1"">{0}<SetVar Name=""ID"">New</SetVar><SetVar Name=""Cmd"">Save</SetVar>", setListText);strBatchData.AppendFormat(@"<SetVar Name=""urn:schemas-microsoft-com:office:office#{0}"">{1}</SetVar>", "CustomerName", "蔣九");strBatchData.AppendFormat(@"<SetVar Name=""urn:schemas-microsoft-com:office:office#{0}"">{1}</SetVar>", "Gender", "男");strBatchData.AppendFormat(@"<SetVar Name=""urn:schemas-microsoft-com:office:office#{0}"">{1}</SetVar>", "EMail", "jiujiang@contoso.com");strBatchData.AppendFormat(@"<SetVar Name=""urn:schemas-microsoft-com:office:office#{0}"">{1}</SetVar>", "CellPhone", "13656435678");strBatchData.AppendFormat(@"<SetVar Name=""urn:schemas-microsoft-com:office:office#{0}"">{1}</SetVar>", "WorkAddress", "菜市口");strBatchData.AppendFormat(@"<SetVar Name=""urn:schemas-microsoft-com:office:office#{0}"">{1}</SetVar>", "Recency", SPUtility.CreateISO8601DateTimeFromSystemDateTime(DateTime.Now.AddDays(-1)));strBatchData.AppendFormat(@"<SetVar Name=""urn:schemas-microsoft-com:office:office#{0}"">{1}</SetVar>", "Frequency", "0.3");strBatchData.AppendFormat(@"<SetVar Name=""urn:schemas-microsoft-com:office:office#{0}"">{1}</SetVar>", "Monetary", "30000");strBatchData.AppendFormat(@"<SetVar Name=""urn:schemas-microsoft-com:office:office#{0}"">{1}</SetVar>", "BusinessPage", string.Format(@"{0} , {1}", "http://jiangjiu.com", "蔣九的個人主頁"));strBatchData.AppendFormat(@"<SetVar Name=""urn:schemas-microsoft-com:office:office#{0}"">{1}</SetVar>", "CustomerType", "青銅");strBatchData.AppendFormat(@"<SetVar Name=""urn:schemas-microsoft-com:office:office#{0}"">{1}</SetVar>", "Owner", string.Format(@"{0};#{1}", user2.ID.ToString(), user2.Name));strBatchData.AppendFormat(@"<SetVar Name=""urn:schemas-microsoft-com:office:office#{0}"">{1}</SetVar>", "Sharers", string.Join(@";#", user1.ID.ToString(), user1.Name, user2.ID.ToString(), user2.Name, group1.ID.ToString(), group1.Name));strBatchData.Append("</Method>");//修改數(shù)據(jù):string updateItemId = "2";strBatchData.AppendFormat(@"<Method ID=""Update,1"">{0}<SetVar Name=""ID"">{1}</SetVar><SetVar Name=""Cmd"">Save</SetVar><SetVar Name=""urn:schemas-microsoft-com:office:office#{2}"">{3}</SetVar></Method>", setListText, updateItemId, "CustomerName", "李四四");//刪除數(shù)據(jù):string deleteItemId = "3";strBatchData.AppendFormat(@"<Method ID=""Delete,1"">{0}<SetVar Name=""ID"">{1}</SetVar><SetVar Name=""Cmd"">Delete</SetVar></Method>", setListText, deleteItemId);//命令尾:strBatchData.Append(@"</Batch>");//執(zhí)行:Console.WriteLine(spWeb.ProcessBatchData(strBatchData.ToString()));

????? 服務(wù)端對象模型還有一個很重要的上下文對象--SPContext,在開發(fā)Web部件時經(jīng)常會用到。我們可以通過SPContext.Current獲取到當(dāng)前上下文SPContext對象,用該對象可以直接獲取當(dāng)前網(wǎng)站、當(dāng)前列表、當(dāng)前項目......(http://msdn.microsoft.com/zh-cn/library/microsoft.sharepoint.spcontext.aspx)

SPContext spContext = SPContext.Current;//當(dāng)前網(wǎng)站集SPSite spSite = spContext.Site;//當(dāng)前網(wǎng)站SPWeb spWeb = spContext.Web;//當(dāng)前用戶SPUser spUser = spWeb.CurrentUser;//當(dāng)前列表SPList spList = spContext.List;//當(dāng)前列表IDGuid listId = spContext.ListId;//當(dāng)前項目SPItem spItem = spContext.Item;//當(dāng)前項目IDint itemId = spContext.ItemId;//當(dāng)前項目ID(字符串)string itemIdAsString = spContext.ItemIdAsString;//當(dāng)前頁面上下文SPContextPageInfo contextPageInfo = spContext.ContextPageInfo;//......

?


????? 上文花了較大篇幅研究服務(wù)端對象模型,接下來我們研究托管客戶端對象模型(托管客戶端對象模型是用.NET開發(fā)的,另有ECMAScript客戶端對象模型以后會介紹,http://msdn.microsoft.com/zh-cn/library/ee539429(v=office.14).aspx)。客戶端對象模型不需要部署到服務(wù)器端,當(dāng)然功能也會有一定限制。使用客戶端對象模型代碼需要引用Microsoft.SharePoint.Client程序集和Microsoft.SharePoint.Client命名空間。

????? 首先,我們要構(gòu)建一個客戶端上下文對象——ClientContext(相當(dāng)于服務(wù)端對象模型的Microsoft.SharePoint.SPContext)。如果需要顯式以某個用戶的 Windows 憑據(jù)運行,可以給ClientContext對象的Credentials賦值。

ClientContext clientContext = new ClientContext(webFullUrl);//NetworkCredential networkCredential = CredentialCache.DefaultNetworkCredentials;//clientContext.Credentials = networkCredential;NetworkCredential networkCredential = new NetworkCredential(@"contoso\administrator", "password");clientContext.Credentials = networkCredential;

???????使用過了服務(wù)器端對象模型再理解客戶端對象模型比較容易,與Microsoft.SharePoint.SPList對應(yīng)的是Microsoft.SharePoint.Client.List、與Microsoft.SharePoint.SPListItem對應(yīng)的是Microsoft.SharePoint.Client.ListItem,只是客戶端對象模型要寫更多代碼,通過查詢?nèi)〉玫膶ο蟛荒苤苯邮褂?#xff0c;需要調(diào)用ClientContext對象的Load方法,并顯式調(diào)用ExecuteQuery方法。(http://msdn.microsoft.com/zh-cn/library/ee534956(v=office.14).aspx、http://msdn.microsoft.com/zh-cn/library/gg277498.aspx)

string webFullUrl = "http://SharePointServer/";using (ClientContext clientContext = new ClientContext(webFullUrl)){ List list = clientContext.Web.Lists.GetByTitle("我的客戶列表");CamlQuery camlQuery = new CamlQuery();//指定過濾條件camlQuery.ViewXml = @"<View><Query><Where><Eq><FieldRef Name='CustomerName'/><Value Type='Text'>蔣九</Value></Eq></Where></Query></View>";ListItemCollection listItems = list.GetItems(camlQuery);//加載查詢,并指定加載字段:clientContext.Load(listItems,items => items.Include(item => item.Id,item => item["CustomerName"],item => item["Gender"],item => item["EMail"],item => item["CellPhone"],item => item["WorkAddress"],item => item["Recency"],item => item["Frequency"],item => item["Monetary"],item => item["BusinessPage"],item => item["CustomerType"],item => item["Owner"],item => item["Sharers"]));//執(zhí)行查詢clientContext.ExecuteQuery();int count = listItems.Count;foreach (ListItem item in listItems){Console.WriteLine("ID: {0} CustomerName: {1} Gender: {2} EMail: {3} CellPhone: {4} WorkAddress: {5} Recency: {6} Frequency: {7} Monetary: {8} BusinessPage: {9} CustomerType: {10} Owner: {11} Sharers: {12} ",item.Id, item["CustomerName"], item["Gender"], item["EMail"], item["CellPhone"],item["WorkAddress"], item["Recency"], item["Frequency"], item["Monetary"],((FieldUrlValue)item["BusinessPage"]).Url, item["CustomerType"], ((FieldUserValue)item["Owner"]).LookupValue, string.Join(",", ((FieldUserValue[])item["Sharers"]).Select(v => v.LookupValue).ToArray()));}}

????? 新增項目時也多了一個步驟,要先創(chuàng)建一個ListItemCreationInformation對象(添加附件還要創(chuàng)建AttachmentCreationInformation對象),再調(diào)用List的AddItem方法;為ListItem對象的屬性賦值后,要調(diào)用Update和ExecuteQuery方法。

Guid listId = new Guid(@"{3824b091-c7b8-409c-bcc0-7cce487d6b49}");List list = clientContext.Web.Lists.GetById(listId);ListItemCreationInformation listItemCreationInformation = new ListItemCreationInformation();ListItem listItem = list.AddItem(listItemCreationInformation);listItem["CustomerName"] = "李四";listItem["Gender"] = "女";listItem["EMail"] = "sili@contoso.com";listItem["CellPhone"] = "13456435678";listItem["WorkAddress"] = "西直門";listItem["Recency"] = DateTime.Now;listItem["Frequency"] = 0.5;listItem["Monetary"] = 100000;listItem["BusinessPage"] = new FieldUrlValue() { Url = "http://lisi.com", Description = "李四的個人主頁" };listItem["CustomerType"] = "鉆石";listItem["Owner"] = FieldUserValue.FromUser(loginName1);listItem["Sharers"] = new [] { FieldUserValue.FromUser(user1.LoginName),FieldUserValue.FromUser(user2.LoginName), FieldUserValue.FromUser(group1.LoginName)};listItem.Update();AttachmentCreationInformation attachmentCreationInformation = new AttachmentCreationInformation();using (FileStream fileStream = new FileStream(fileFullName, FileMode.Open)){attachmentCreationInformation.ContentStream = fileStream;attachmentCreationInformation.FileName = Path.GetFileName(fileFullName);listItem.AttachmentFiles.Add(attachmentCreationInformation);clientContext.ExecuteQuery();}

????? 如果要上傳一個文檔到文檔庫則需要創(chuàng)建FileCreationInformation對象。

string title = @"我的文檔庫";List list = clientContext.Web.Lists.GetByTitle(title);Folder folder = list.RootFolder.Folders.Add("文件夾1");folder.Update();FileCreationInformation fileCreationInformation = new FileCreationInformation();fileCreationInformation.Content = System.IO.File.ReadAllBytes(fileFullName);fileCreationInformation.Overwrite = true;fileCreationInformation.Url = Path.GetFileName(fileFullName);folder.Files.Add(fileCreationInformation);clientContext.ExecuteQuery();

????? 將項目修改或刪除的代碼很簡單,也是操作后要調(diào)用ListItem對象的Update和ExecuteQuery方法。(http://msdn.microsoft.com/zh-cn/library/ee539976(v=office.14).aspx)

Guid listId = new Guid(@"{3824b091-c7b8-409c-bcc0-7cce487d6b49}");int itemId = 14;List list = clientContext.Web.Lists.GetById(listId);ListItem item = list.GetItemById(itemId);clientContext.Load(item);clientContext.ExecuteQuery();//修改item["CustomerName"] = "蔣九九";item.Update();clientContext.ExecuteQuery();//刪除item.DeleteObject();clientContext.ExecuteQuery();

?


????? 關(guān)于Web Services(http://msdn.microsoft.com/zh-cn/library/dd878586(v=office.12).aspx)的方式操作列表,首先要添加Web引用(解決方案資源管理器-〉引用-〉添加服務(wù)引用-〉高級(左下角)-〉添加Web引用(左下角)-〉URL輸入框輸入?http://<site>/_vti_bin/Lists.asmx.)。

???? ?這里的操作命令語法和服務(wù)器端對象模型、客戶端對象模型里的CAML非常相似,只是Web服務(wù)方法的參數(shù)和返回值多是XmlElement對象,查詢列表項目shiyongLists.GetListItems 方法(請參考:http://msdn.microsoft.com/zh-cn/library/websvclists.lists.updatelistitems(v=office.12).aspx),下面是一個簡單的查詢例子。

string listName = "我的客戶列表";using (Lists listService = new Lists()){listService.Credentials = CredentialCache.DefaultCredentials;//或者://listService.Credentials = new NetworkCredential(@"contoso\administrator", "password");XmlDocument xmlDocument = new XmlDocument();XmlNode queryNode = xmlDocument.CreateNode(XmlNodeType.Element, "Query", string.Empty);XmlNode viewFieldsNode =xmlDocument.CreateNode(XmlNodeType.Element, "ViewFields", string.Empty);viewFieldsNode.InnerXml = @"<FieldRef Name='ID' /><FieldRef Name='CustomerName' /><FieldRef Name='Gender' /><FieldRef Name='EMail' /><FieldRef Name='CellPhone' />";queryNode.InnerXml = string.Format(@"<Where><Eq><FieldRef Name='CustomerName'/><Value Type='Text'>{0}</Value></Eq></Where>", "蔣九");XmlNode resultNode = listService.GetListItems(listName, null, queryNode, viewFieldsNode, null, null, null);Console.WriteLine(resultNode.InnerXml);Console.ReadLine();}

???????? 新增、修改、刪除列表項目使用Lists.UpdateListItems 方法執(zhí)行批量命令(請參考:http://msdn.microsoft.com/zh-cn/library/websvclists.lists.updatelistitems(v=office.12).aspx)。對于多個用戶和組、超鏈接或圖片等特殊的字段類型還是使用的和服務(wù)器端對象模型相同的字符串拼接。

string listName = "我的客戶列表";using (Lists listService = new Lists()){listService.Credentials = CredentialCache.DefaultCredentials;//或者://listService.Credentials = new NetworkCredential(@"contoso\administrator", "password");XmlDocument xmlDocument = new XmlDocument();XmlElement updatesBatch = xmlDocument.CreateElement("Batch");updatesBatch.SetAttribute("OnError", "Continue");StringBuilder methodsText = new StringBuilder();//刪除數(shù)據(jù):methodsText.AppendFormat(@"<Method ID='Delete,1' Cmd='Delete'><Field Name='ID'>{0}</Field></Method>", deleteItemId.ToString());//插入數(shù)據(jù):methodsText.Append(@"<Method ID='Insert,1' Cmd='New'><Field Name='ID'>New</Field>");methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "CustomerName", "蔣九");methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "Gender", "男");methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "EMail", "jiujiang@contoso.com");methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "CellPhone", "13656435678");methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "WorkAddress", "菜市口");DateTime recency = DateTime.Now.AddDays(-1);methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "Recency", string.Format("{0}-{1}-{2}T{3}:{4}:{5}Z", recency.Year.ToString("0000"), recency.Month.ToString("00"), recency.Day.ToString("00"), recency.Hour.ToString("00"), recency.Minute.ToString("00"), recency.Second.ToString("00")));methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "Frequency", "0.4");methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "Monetary", "10000");methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "BusinessPage", string.Format(@"{0} , {1}", "http://jiangjiu.com", "蔣九的個人主頁"));methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "CustomerType", "青銅");methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "Owner", string.Format(@"{0};#{1}", user2.ID.ToString(), user2.Name));methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "Sharers", string.Join(@";#", user1.ID.ToString(), user1.Name, user2.ID.ToString(), user2.Name, group1.ID.ToString(), group1.Name));methodsText.Append("</Method>");methodsText.Append(@"<Method ID='Insert,2' Cmd='New'><Field Name='ID'>New</Field>");methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "CustomerName", "孫七");methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "Gender", "女");methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "EMail", "qisun@contoso.com");methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "CellPhone", "13656437456");methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "WorkAddress", "恭王府");DateTime recency2 = DateTime.Now.AddDays(-3);methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "Recency", string.Format("{0}-{1}-{2}T{3}:{4}:{5}Z", recency2.Year.ToString("0000"), recency2.Month.ToString("00"), recency2.Day.ToString("00"), recency2.Hour.ToString("00"), recency2.Minute.ToString("00"), recency2.Second.ToString("00")));methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "Frequency", "0.6");methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "Monetary", "10000");methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "BusinessPage", string.Format(@"{0} , {1}", "http://sunqi.com", "孫七的個人主頁"));methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "CustomerType", "黃金");methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "Owner", string.Format(@"{0};#{1}", user2.ID.ToString(), user2.Name));methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "Sharers", string.Join(@";#", user1.ID.ToString(), user1.Name, user2.ID.ToString(), user2.Name, group1.ID.ToString(), group1.Name));methodsText.Append("</Method>");//修改數(shù)據(jù):methodsText.AppendFormat(@"<Method ID='Update,1' Cmd='Update'><Field Name='ID'>{0}</Field>", updateItemId.ToString());methodsText.AppendFormat(@"<Field Name='{0}'>{1}</Field>", "CustomerName", "趙六六");methodsText.Append("</Method>");updatesBatch.InnerXml = methodsText.ToString();XmlNode returnNode = listService.UpdateListItems(listName, updatesBatch);Console.WriteLine(returnNode.InnerXml);}

?


???? 如果您覺得Web Services+XmlElement不夠先進(jìn),還可以使用WCF+LINQ TO XML的方式,使用WCF直接添加服務(wù)引用就可以了。

????? 使用WCF訪問SharePoint列表和使用Web Services訪問的SharePoint的方法應(yīng)該是同出一轍的,只是這里把參數(shù)XmlElement對象換成了XElement對象。可是開始的時候我還是遇到了一點小異常。

?????? 對于這個MessageSecurityException類型的異常——“HTTP 請求未經(jīng)客戶端身份驗證方案'Anonymous'授權(quán)。從服務(wù)器收到的身份驗證標(biāo)頭為‘NTLM’。”,我們可以用添加兩句代碼,設(shè)置BasicHttpBinding.Security.Mode和BasicHttpBinding.Security.Transport.ClientCredentialType解決。

BasicHttpBinding basicHttpBinding = (BasicHttpBinding)listsSoapClient.Endpoint.Binding;basicHttpBinding.Security.Mode = BasicHttpSecurityMode.TransportCredentialOnly;basicHttpBinding.Security.Transport.ClientCredentialType = HttpClientCredentialType.Ntlm;listsSoapClient.ClientCredentials.Windows.ClientCredential = new NetworkCredential(@"username", "password", "domain");XElement queryXElement = XElement.Parse(string.Format(@"<Query><Where><Eq><FieldRef Name='CustomerName'/><Value Type='Text'>{0}</Value></Eq></Where></Query>", "趙六六"));XElement viewFieldsXElement = XElement.Parse(@"<ViewFields><FieldRef Name='CustomerName'/><FieldRef Name='Gender'/><FieldRef Name='Monetary'/><FieldRef Name='BusinessPage'/><FieldRef Name='Owner'/><FieldRef Name='Sharers'/></ViewFields>");XElement resultXElement = listsSoapClient.GetListItems(listName, null, queryXElement, viewFieldsXElement, null, null, null);Console.WriteLine(resultXElement.ToString());

?

????? 如果您不喜歡加代碼,還可以修改應(yīng)用程序配置文件(.config)中的binding節(jié)點。?

?

<system.serviceModel><bindings><basicHttpBinding><binding name="ListsSoap" ><security mode="TransportCredentialOnly"><transport clientCredentialType="Ntlm" /></security></binding></basicHttpBinding></bindings><client><endpoint address="http://SharePointServer/_vti_bin/Lists.asmx" binding="basicHttpBinding"bindingConfiguration="ListsSoap" contract="WebsvcLists.ListsSoap"name="ListsSoap" /></client></system.serviceModel>

?

?

?

?

總結(jié)

以上是生活随笔為你收集整理的SharePoint 2013开发入门探索(二)- 列表操作的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

亚洲精品字幕 | 色综合久久久久久久 | 国产二区电影 | 亚洲国产中文字幕在线视频综合 | 天天av资源| 日本超碰在线 | 色黄视频免费观看 | 伊人影院得得 | 国产免费作爱视频 | 午夜视频99 | 久久超级碰视频 | 四虎影视成人永久免费观看亚洲欧美 | 欧美在线视频二区 | 午夜91视频| 国产精品久久9 | 亚洲视频1区2区 | 免费精品国产va自在自线 | sm免费xx网站 | 在线观看中文字幕dvd播放 | 亚洲va欧美va人人爽春色影视 | a在线播放| 四虎伊人 | 五月天狠狠操 | 久久调教视频 | 欧美性极品xxxx做受 | 色免费在线 | 九九免费视频 | 一区二区三区在线免费 | 黄色免费网站 | 中文字幕在线高清 | 免费高清在线观看电视网站 | 日日干夜夜爱 | 西西444www大胆高清视频 | 天天人人综合 | 波多野结衣在线中文字幕 | 午夜男人影院 | 天天夜操 | 黄色的视频网站 | 日韩精品视频在线观看免费 | 国产精品一区二区av | 久久夜视频 | 久久国产热视频 | 蜜臀av免费一区二区三区 | 天堂网一区二区 | 色视频在线免费 | 91精品视屏 | 蜜臀av一区二区 | 国内精品视频在线播放 | 久久午夜电影院 | 日韩电影中文 | 国产福利一区二区三区视频 | 色婷婷激情| 在线免费视频一区 | 日本久久久影视 | 狠狠的操你| 久久精品99久久久久久 | 久久一本综合 | 99热国产在线中文 | 亚洲国产午夜 | 国产精品青草综合久久久久99 | 狠狠狠操 | 国产色影院 | 深爱婷婷 | 久草在在线视频 | 三级黄免费看 | 成年人免费在线观看 | 99久久国产免费,99久久国产免费大片 | 国产精品成人在线 | 欧美日韩高清 | 国产视频日韩视频欧美视频 | 正在播放 久久 | 国产成人精品av久久 | 日韩字幕 | 在线你懂| 欧美日韩免费在线观看视频 | 亚洲伊人第一页 | 9热精品 | 91九色免费视频 | 久久久精品久久日韩一区综合 | 中文字幕在线观看一区二区三区 | 日韩激情av在线 | 在线观看视频在线观看 | 亚洲国产精品推荐 | 色婷婷综合久久久久中文字幕1 | 欧美韩国在线 | 精产嫩模国品一二三区 | 狠狠操综合网 | 色com网 | 99视频在线免费播放 | 免费观看久久 | 欧美精品日韩 | 黄色特级毛片 | 国产精品理论视频 | 欧美性生爱 | 国产99久久99热这里精品5 | 狠狠干狠狠插 | 欧美综合在线视频 | 草久久精品| 中文字幕乱码日本亚洲一区二区 | 欧美成人一二区 | 国产在线精品福利 | 91亚洲国产成人久久精品网站 | 亚洲精品视频免费在线观看 | 国产亚洲婷婷免费 | 成人免费视频播放 | 国产精品免费av | 亚洲精品tv | 在线韩国电影免费观影完整版 | 免费能看的av | 婷婷丁香激情综合 | 中文字幕在线视频第一页 | 九九热精品视频在线播放 | 国产色视频网站 | 五月婷婷中文字幕 | 在线免费黄色av | 久久人人爽人人爽 | 久久经典视频 | 啪啪小视频网站 | 国产精品久久二区 | 手机av在线免费观看 | 久久午夜鲁丝片 | 黄色免费在线视频 | www久久 | 亚洲精品久久久久久中文传媒 | 91九色视频网站 | bbb搡bbb爽爽爽 | 亚洲日本韩国一区二区 | 免费久久久久久 | 国产成人av一区二区三区在线观看 | 字幕网资源站中文字幕 | 中文字幕中文字幕在线中文字幕三区 | 亚洲 欧洲av | 国产片免费在线观看视频 | 黄色在线免费观看网址 | 亚洲欧洲精品一区二区精品久久久 | 玖玖爱免费视频 | 国产精品国产亚洲精品看不卡15 | av免费在线免费观看 | 精品久久99| 免费成人在线电影 | 亚洲高清激情 | 国产精品资源 | 成人动漫精品一区二区 | 久久综合五月 | 亚洲精品在线观看视频 | 国产在线中文字幕 | 成人h在线观看 | 国产高清视频免费在线观看 | 中文字幕a∨在线乱码免费看 | 在线黄网站 | 久久九九国产精品 | 国内成人精品2018免费看 | 97精品伊人 | 色综合久久久久 | 天天爱天天操天天干 | 99国产成+人+综合+亚洲 欧美 | 狠狠地操 | 日韩在线免费电影 | 在线黄色国产电影 | 日本精品久久久久中文字幕 | 国产精品一区二区在线免费观看 | 欧美人体xx| 99高清视频有精品视频 | 日韩v欧美v日本v亚洲v国产v | 日韩av偷拍| 久久久久久久久久影视 | 爱情影院aqdy鲁丝片二区 | 激情校园亚洲 | 色久网 | 中文字幕在线观看日本 | 在线天堂中文在线资源网 | 96香蕉视频 | 色精品视频 | 一区二区三区四区免费视频 | wwwwww黄| 久久久久久免费毛片精品 | 亚洲 欧美变态 另类 综合 | 激情开心站 | 免费观看国产成人 | 久久黄网站 | 99精品网站 | 丁香一区二区 | 天天做天天爱夜夜爽 | 蜜桃视频在线观看一区 | 另类老妇性bbwbbw高清 | 片网站 | 一区在线播放 | 国产精品电影一区 | 国产一区二区视频在线 | 免费看污黄网站 | 天天干天天拍天天操天天拍 | 在线观看国产成人av片 | 999精品| 色吊丝在线永久观看最新版本 | 中文字幕亚洲欧美日韩 | 天堂av在线免费观看 | 久久久在线免费观看 | 国产免费资源 | 国产日产精品一区二区三区四区的观看方式 | 亚洲自拍偷拍色图 | 黄色三级久久 | 99久久精品久久久久久动态片 | 久久久久久久久久久久久影院 | 国产一区二区三区久久久 | 天天爽天天碰狠狠添 | 成人久久18免费网站麻豆 | 天天操天天干天天综合网 | 草免费视频| 久久成人黄色 | 国产精品一区二区三区久久 | 五月天婷婷狠狠 | 四虎国产精品免费 | 日日摸日日爽 | 一区二区中文字幕在线观看 | 五月天开心 | 天天干天天天 | 激情综合色综合久久 | 亚洲少妇激情 | 日韩av一区二区在线影视 | 欧美日韩不卡一区 | 五月色综合 | 麻豆 91 在线| 超碰电影在线观看 | 免费国产一区二区视频 | 欧美日韩中文在线视频 | 色资源二区在线视频 | 午夜影视剧场 | 欧美日韩在线观看一区二区 | 欧美三级在线播放 | 天堂av免费观看 | 人人舔人人舔 | 国产精品久久99综合免费观看尤物 | 亚洲激情视频在线 | 日日夜夜人人精品 | 在线观看午夜av | 亚洲国产欧美一区二区三区丁香婷 | 久草视频在线资源站 | 97精品视频在线 | 三级黄免费看 | 91亚洲精品久久久蜜桃网站 | 国产亚洲精品久久久久5区 成人h电影在线观看 | 天天操天天操天天操天天操天天操天天操 | 国产精品自产拍在线观看网站 | 国产亚洲成人网 | 色片网站在线观看 | 色婷婷av国产精品 | 国产精品都在这里 | 免费成人av在线看 | 国产成人精品久久久久 | 国产免费视频一区二区裸体 | 成人久久18免费网站 | 久久这里精品视频 | 中文字幕网站视频在线 | 久久精品毛片 | 婷婷伊人综合 | 成人欧美一区二区三区黑人麻豆 | 久久综合九色综合欧美就去吻 | 一区二区不卡在线观看 | 99久久99久国产黄毛片 | 在线观看国产www | 综合色综合色 | 四虎www | 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 婷婷丁香色 | 国产一区二区三区久久久 | 精品国产诱惑 | 国产精品免费看久久久8精臀av | 国产精品日韩欧美 | 亚洲精品视频网 | 久久久久久久久久免费 | 波多野结衣在线观看一区二区三区 | 网址你懂的在线观看 | 在线观看日本韩国电影 | 免费特级黄色片 | 亚洲闷骚少妇在线观看网站 | 午夜精品久久久久久久久久 | 九九在线免费视频 | 一二三区av| 国产美女精品视频免费观看 | 久久这里只有精品视频首页 | 国产精品不卡一区 | 亚洲美女精品区人人人人 | 免费精品国产va自在自线 | 91亚洲网站 | 欧美在线观看小视频 | 在线观看岛国片 | 永久免费在线 | 久久99精品国产麻豆宅宅 | 91麻豆精品91久久久久同性 | av在线一 | 在线播放第一页 | 国产亚洲视频在线观看 | 最近2019好看的中文字幕免费 | 安徽妇搡bbbb搡bbbb | 欧美最猛性xxxxx亚洲精品 | 久久国产露脸精品国产 | 97av视频| 国产黄色片在线 | 在线免费观看黄 | 日韩精品中文字幕在线播放 | 91成人免费在线 | 免费视频在线观看网站 | 亚洲日本国产精品 | 91激情视频在线 | 亚洲国产精品999 | 免费h在线观看 | 精品夜夜嗨av一区二区三区 | 福利视频午夜 | av黄色免费看 | 欧美性色黄 | 久草视频99 | 97品白浆高清久久久久久 | 99免费精品 | 午夜视频在线网站 | 亚洲国产精品久久久久婷婷884 | 成人av免费 | 少妇av片 | 亚洲码国产日韩欧美高潮在线播放 | 国产精品系列在线 | 久久在线观看 | 精品毛片一区二区免费看 | 午夜 在线| 色婷婷播放 | 婷婷六月天天 | 波多野结衣一区二区 | 在线黄网站 | 中文字幕在线第一页 | 四虎在线永久免费观看 | 亚洲欧洲在线视频 | 免费观看午夜视频 | 三级在线国产 | 色综合小说 | 国产在线色视频 | 中文乱码视频在线观看 | 亚洲国产大片 | 色综合咪咪久久网 | 久久久久电影 | 国产成人亚洲精品自产在线 | 五月天激情在线 | 四虎在线观看精品视频 | 99精品视频在线观看播放 | 麻豆国产视频 | 日本在线视频网址 | 亚洲 欧美 91 | 日本视频久久久 | 欧美一级在线观看视频 | 日本动漫做毛片一区二区 | 亚洲视频电影在线 | 99热这里只有精品免费 | 久久99热精品 | 激情伊人五月天久久综合 | 丁香综合网 | 日韩av影视在线 | 免费视频久久久 | 一二区精品 | 综合网成人 | 欧美激情精品久久久久久 | 天天综合操 | 狠狠色丁香久久婷婷综合五月 | 日本爱爱免费视频 | 久久99精品久久久久久三级 | 久久深爱网 | 亚州人成在线播放 | 九色激情网 | 少妇bbbb揉bbbb日本 | 久久视频这里有精品 | 久草在线观看视频免费 | 波多野结衣理论片 | 中文字幕国产亚洲 | 久久综合天天 | 狠狠躁夜夜躁人人爽超碰91 | 一区二区三区在线免费 | 国产精品久久久久国产精品日日 | 综合婷婷久久 | 国内毛片毛片 | 国产成人久久精品亚洲 | 91av中文| 日韩综合视频在线观看 | 怡红院av久久久久久久 | 成年人免费观看在线视频 | 欧美成a人片在线观看久 | av在线直接看 | 国产小视频在线观看免费 | 美女网站视频一区 | 98超碰在线 | 丝袜一区在线 | 精品欧美日韩 | 在线国产视频一区 | www国产一区| 成 人 黄 色 视频免费播放 | 免费av大全 | 成人中文字幕在线 | 最新av网站在线观看 | 一区精品久久 | 久久国产精品免费观看 | 91久久精品日日躁夜夜躁国产 | 欧美日韩亚洲在线观看 | 521色香蕉网站在线观看 | 日韩色视频在线观看 | 国产精品视频大全 | 久久网站免费 | 日韩欧美国产视频 | 国内精品久久久久影院一蜜桃 | 高潮毛片无遮挡高清免费 | 国内视频在线观看 | 欧美日产在线观看 | 国产免费小视频 | 欧美日韩高清在线观看 | 最新中文字幕视频 | 手机av永久免费 | 国产一区二区三区高清播放 | 亚洲最新av在线网址 | 在线 视频 一区二区 | 午夜视频在线观看一区二区三区 | 精品国产精品一区二区夜夜嗨 | 国产特黄色片 | 香蕉视频4aa | 日本精品久久久久影院 | 久久永久视频 | 国产精品资源在线 | 麻豆国产网站入口 | 日韩免费在线观看 | 三级黄色网址 | 激情自拍av| 日韩一级片大全 | 精品久久久久久久久久 | 久久久福利| a级成人毛片 | 亚洲国产一区在线观看 | 午夜视频免费 | 国产视频久久久久 | 精品国产伦一区二区三区观看方式 | 人人干网站 | 91九色在线播放 | 日韩在线观看高清 | 欧美一级日韩免费不卡 | 日本黄色大片免费 | 97在线影院| 韩国av免费在线观看 | 欧美日韩免费一区二区三区 | 色哟哟国产精品 | 伊人狠狠色丁香婷婷综合 | 欧美日韩中文字幕在线视频 | 国产黄在线 | 五月激情电影 | 中文字幕丰满人伦在线 | 国产精品国产三级国产aⅴ入口 | 亚洲午夜久久久久久久久久久 | 久青草视频 | 欧美成人按摩 | 色久av| 免费看的毛片 | 五月婷婷丁香色 | 亚洲午夜久久久久久久久 | 一区二区在线影院 | www.夜夜干.com | 在线国产视频一区 | 国内精品久久久久久久久久 | 福利视频导航网址 | 草久在线观看 | 亚洲一区二区三区四区在线视频 | 国产福利91精品 | 色播五月激情综合网 | 美女视频黄免费的久久 | 狠狠色狠狠色 | 亚洲天堂视频在线 | 久久视频免费在线观看 | 青青草国产成人99久久 | 不卡的av电影在线观看 | 亚洲一区欧美激情 | 日日夜夜中文字幕 | 成人日批视频 | 日韩在线免费高清视频 | 国产精品美女免费视频 | 国产国产人免费人成免费视频 | 日韩av中文字幕在线 | 亚洲自拍偷拍色图 | 日本精品视频在线观看 | 亚洲欧美日韩国产一区二区三区 | av福利网址导航大全 | 国产一级精品绿帽视频 | 国产蜜臀av | 久久久影视 | 亚洲www天堂com | 亚洲国内精品在线 | 五月婷婷狠狠 | 成人一级影视 | 在线观看一区二区精品 | 久久久久久久久久久久国产精品 | 久久黄色免费视频 | 国内精品久久久久久久久久久 | 日韩精品一区二区三区丰满 | 日韩精品一区二区三区免费观看 | 久久久久久亚洲精品 | 激情综合啪 | 成人97视频 | 精品国产人成亚洲区 | 六月丁香在线视频 | 激情网站 | 五月天九九| 91麻豆高清视频 | 国产精品一区二区三区免费看 | 三级黄色免费 | 国产日韩精品在线观看 | 欧美先锋影音 | 天天综合日日夜夜 | 欧美国产精品一区二区 | 国产视频亚洲精品 | 人人干人人超 | 日韩欧美综合精品 | 在线免费观看黄网站 | 精品国产一区二区久久 | 日日干日日色 | 五月天久久婷 | 国产精品白浆视频 | 麻豆精品在线视频 | 免费电影一区二区三区 | 久久婷婷网 | 中文字幕在线播出 | 亚洲激情中文 | 一区二区三区日韩视频在线观看 | 最近字幕在线观看第一季 | 国产成人免费观看 | 国产精品9区 | 亚洲成人av一区二区 | 国产99久久九九精品免费 | 国产视频 亚洲精品 | 最新日韩视频在线观看 | 久久久久亚洲国产精品 | 久久久网站 | 人人射网站 | 久草在线高清视频 | 国产精品久久久一区二区 | 久久99久久99精品免观看软件 | 国产精品视频全国免费观看 | 国产精品高清免费在线观看 | 欧美性黑人| 中文字幕国产在线 | 国产xxxx性hd极品 | japanesexxxxfreehd乱熟 | 亚洲激情影院 | 国产一线在线 | 日本精品久久久久影院 | av中文在线观看 | 日韩欧美在线影院 | 黄色三级在线看 | 欧美aaaxxxx做受视频 | 在线视频 亚洲 | 色国产视频 | 欧美激情综合色综合啪啪五月 | 国产亚洲精品免费 | 精品久久在线 | 黄色大片日本 | 中文字幕在线看片 | 97超碰超碰久久福利超碰 | 亚洲激情 | www.看片网站| 久久99热久久99精品 | 精品视频免费播放 | 五月婷婷久 | 精品久久久久国产免费第一页 | 国产精品久久久久久久久久直播 | 狠狠综合网 | 精品久久久免费 | 干干夜夜| 亚洲小视频在线观看 | 视频在线观看日韩 | 狠狠操夜夜| 中日韩男男gay无套 日韩精品一区二区三区高清免费 | 亚洲视频h | 日韩在线激情 | 久久区二区 | 99热这里只有精品国产首页 | 国产精品日韩 | 久久久久黄色 | 天天射天天干天天操 | 日韩欧美在线影院 | 成人全视频免费观看在线看 | 国产精品 亚洲精品 | 亚洲欧美乱综合图片区小说区 | 亚洲电影毛片 | 婷婷激情5月天 | 日韩欧美精品在线视频 | 国产无遮挡又黄又爽在线观看 | 99精品视频免费 | 亚洲国产中文字幕 | 精品一区二区电影 | av一级在线观看 | 国产专区在线播放 | 色在线视频网 | 六月色婷婷 | 亚洲国产成人在线观看 | 又黄又爽又湿又无遮挡的在线视频 | 精品主播网红福利资源观看 | 91插插影库 | 成人禁用看黄a在线 | 色婷婷五 | 亚洲精品视频一二三 | 丁香激情五月婷婷 | 五月婷婷国产 | 91.精品高清在线观看 | 久久久久久97三级 | 久久久久久99精品 | 久久精品国产成人精品 | av免费在线网 | 久久69精品久久久久久久电影好 | 色久综合 | 久久久综合九色合综国产精品 | 免费观看一区二区三区视频 | av 一区二区三区四区 | 久草视频在线免费 | 国产97在线播放 | 日本高清久久久 | 免费看麻豆 | 国产精品美女久久久久久久 | 国产高清在线一区 | 日本成址在线观看 | a久久免费视频 | 久久久成人精品 | 在线黄色国产 | 亚洲理论电影 | 在线观看视频免费大全 | 在线观看一级视频 | 日本性动态图 | 日韩av成人在线观看 | 亚洲免费在线播放视频 | 国产日韩欧美在线免费观看 | 久久激情视频网 | 色综合久久久久久久久五月 | www久久国产 | 亚洲成人中文在线 | 精品一区电影 | 激情丁香久久 | 亚洲视频999| 日日日操 | 国产美女视频免费观看的网站 | 夜夜躁日日躁 | 在线播放精品一区二区三区 | 99久高清在线观看视频99精品热在线观看视频 | 男女精品久久 | 国外成人在线视频网站 | 97超碰精品 | www.夜夜草| 91久久国产露脸精品国产闺蜜 | 天天天干天天天操 | 日本老少交 | 国产在线观看网站 | 国产一区二三区好的 | 韩日精品中文字幕 | 涩涩网站在线播放 | a久久久久久| 久久电影中文字幕视频 | 天天插天天操天天干 | av免费看在线 | 日韩免费视频线观看 | 亚洲免费国产视频 | 国产精品普通话 | 婷婷六月网 | 在线免费观看黄色 | 亚洲欧美怡红院 | 黄色午夜网站 | 国产精品久久久久久久7电影 | 最近中文字幕第一页 | 成人免费在线网 | 日日碰狠狠添天天爽超碰97久久 | 91麻豆视频 | 黄色国产在线观看 | 国产在线免费 | 丁香五月亚洲综合在线 | 正在播放五月婷婷狠狠干 | а中文在线天堂 | 国产精品久久久久aaaa九色 | 九九视频网 | 九色91福利 | 色综合久久88色综合天天人守婷 | 国产日韩欧美在线影视 | 久精品视频 | avhd高清在线谜片 | 激情综合狠狠 | 视频三区在线 | av电影免费在线 | 五月亚洲综合 | 精品久久久久久久 | 国产精品18久久久久久不卡孕妇 | 成人在线免费视频 | 一区二区精品视频 | 天堂av最新网址 | 国产精品普通话 | 日韩精品一区二区在线视频 | 日韩欧美综合精品 | 99亚洲国产精品 | 99久久99久久免费精品蜜臀 | 最近中文字幕免费 | 国产又粗又长又硬免费视频 | 中文字幕在线观看免费观看 | 久久五月婷婷丁香社区 | 国产高清在线精品 | 99精品色| 中文字幕视频三区 | 国产偷v国产偷∨精品视频 在线草 | 狠狠色丁香九九婷婷综合五月 | 成人羞羞视频在线观看免费 | 久久久久久久久久久福利 | 97在线观看免费视频 | av在线免费播放网站 | 久久综合色婷婷 | 五月色丁香 | 国产成人1区 | 丁香视频全集免费观看 | 97人人模人人爽人人喊网 | 日韩精品在线观看av | 国产日产精品一区二区三区四区 | 精品久久1 | 美女黄视频免费看 | 久久久久免费精品国产小说色大师 | 欧美福利在线播放 | 综合色天天 | 亚洲综合欧美日韩狠狠色 | 久久激情片| 亚洲免费观看在线视频 | 色狠狠综合 | 日韩电影在线看 | 亚洲精品乱码久久久久久蜜桃91 | 久久综合成人 | 五月天激情综合网 | 激情综合一区 | 少妇啪啪av入口 | 欧美性色综合网站 | 黄色中文字幕 | 中文字幕免费国产精品 | 日韩一区二区三区在线观看 | 久久精品人人做人人综合老师 | 国产一及片 | 日韩在线观看的 | 亚洲丝袜中文 | 日本精品久久久久中文字幕5 | 粉嫩高清一区二区三区 | 日韩在线免费不卡 | 成人a在线观看高清电影 | 黄色片视频在线观看 | 久久免费在线视频 | 中文免费| 最近日本中文字幕a | 91尤物国产尤物福利在线播放 | 婷婷综合久久 | 免费网站v | 日韩91av | 国产在线2020 | 国产中文视 | 亚洲成人av电影 | 久久久久成人免费 | 国产手机视频在线 | 午夜精品一区二区三区在线播放 | 午夜在线观看一区 | 韩国一区二区在线观看 | 91在线入口 | 日日夜夜精品 | 国产精品2区 | 五月婷婷av| 久久国产精品成人免费浪潮 | 亚洲黄色av一区 | 午夜精品久久久久久久久久久久 | 91久久国产综合精品女同国语 | 久草在线最新视频 | 蜜臀精品久久久久久蜜臀 | 一本大道久久精品懂色aⅴ 五月婷社区 | 国产一区二区免费看 | 中文字幕 91 | 亚洲精品无 | 国产人成在线视频 | 毛片网站在线看 | 久久精品国产精品亚洲 | 国产精品久久久久久久久久久久 | 精品 激情| 国产精品少妇 | 久久国产精品99久久久久 | 亚洲精品小视频在线观看 | 午夜久久 | 91久久奴性调教 | 中文视频在线看 | 亚洲在线视频免费 | 欧美日韩一二三四区 | 久久免费公开视频 | 成人免费一区二区三区在线观看 | 国产一级电影网 | 又色又爽的网站 | 国产成人精品免高潮在线观看 | 69视频永久免费观看 | 99精品国产视频 | 亚洲精品视频在线观看免费视频 | 国产精品夜夜夜一区二区三区尤 | 国产精品粉嫩 | 麻豆超碰| 黄色av三级在线 | 伊人久操 | 欧美三级高清 | 久久黄色小说视频 | 国产成人av片 | 2019中文 | 亚洲日本在线一区 | 色香蕉视频 | 九草在线视频 | 欧美激情综合网 | 美女免费黄网站 | 日韩特级黄色片 | 激情网五月 | 亚洲三级精品 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 一区二区激情视频 | av+在线播放在线播放 | 国产精品久久久久久久久久不蜜月 | 在线小视频 | 日本性xxx | 久草视频免费在线观看 | 激情婷婷在线 | 日本99热| www.久艹 | 亚洲精品国产精品国自产 | 亚洲理论在线观看电影 | 日本精品久久久久中文字幕 | 99精品国产视频 | 97超碰精品 | 欧美性成人| 久久成人免费视频 | 亚洲手机av | 精品国产aⅴ麻豆 | 日韩中文免费视频 | 波多野结衣久久精品 | 在线看v片成人 | 免费高清在线观看成人 | 波多在线视频 | zzijzzij亚洲成熟少妇 | 97av在线视频免费播放 | 日本h视频在线观看 | 日韩理论片在线观看 | 久久久国产99久久国产一 | 视频一区二区在线 | 在线观看免费观看在线91 | 六月丁香色婷婷 | 99爱在线观看 | av资源在线看 | 日韩中文在线播放 | 国产精品久久久久久一区二区 | 午夜12点| 伊人永久在线 | 成人黄在线 | 黄色大片av | 欧美夫妻性生活电影 | 中文字幕av最新更新 | 久久久久久久久网站 | 国产 一区二区三区 在线 | 日韩欧美在线观看一区 | 国产美女视频免费观看的网站 | 超碰在线亚洲 | 蜜臀久久99精品久久久久久网站 | 亚洲精品久久久久www | 丁香国产视频 | 国色天香在线观看 | 右手影院亚洲欧美 | 久久精品国产精品 | 国产成人av综合色 | 探花视频在线观看免费 | 免费在线观看日韩欧美 | 免费在线成人av | 狠狠色噜噜狠狠狠狠2022 | 亚州av网站| www免费视频com| 九九精品久久 | 日韩精品在线视频 | 91网页版免费观看 | 成人av在线观 | 国产日产精品一区二区三区四区的观看方式 | 狠狠狠综合 | 午夜视频播放 | 精品一区精品二区 | 国产资源在线视频 | 成年人免费在线观看网站 | 青草视频在线播放 | 中文字幕在线不卡国产视频 | 在线观看日本韩国电影 | 天天草天天干天天 | 国内精品一区二区 | 久久色网站 | 99av国产精品欲麻豆 | 久久亚洲影视 | 青青草国产精品视频 | 中文字幕av专区 | 五月天综合在线 | 狠狠色狠狠色综合日日小说 | 在线观看黄 | 天天干天天干天天色 | 国产清纯在线 | 国产黑丝一区二区三区 | 天天av资源 | av久久久 | 91视频免费 | 亚洲精品h | 丝袜美女视频网站 | 日日爱网址 | 欧美日高清视频 | 伊人电影在线观看 | 国产99久久久国产精品 | 亚洲国产资源 | 中文字幕乱码视频 | 97精品国产97久久久久久免费 | 国产精彩视频一区二区 | 日韩欧美一区二区在线观看 | 黄色91在线 | 中文字幕乱码亚洲精品一区 | 干干夜夜 | 亚洲成aⅴ人在线观看 | 女人18片 | 91av视频免费观看 | 特及黄色片 | 日日夜夜免费精品视频 | 亚洲国内在线 | 91视频国产高清 | 丁香六月在线观看 | 国产色一区 | 天天插天天色 | 国产男女无遮挡猛进猛出在线观看 | 天堂av在线网 | 国产一区二区三区免费在线 | 精品视频网站 | 国产精品一区二区 91 | 久久手机免费观看 | 国产在线中文字幕 | 亚洲精品乱码久久久久久久久久 | 午夜久久福利 | 欧美高清视频不卡网 | 在线观看91av | 国产电影黄色av | 在线观看免费国产小视频 | 91精品国产成人www | 91在线小视频 | 成年人在线电影 | 在线观看视频国产 | 天天爽夜夜爽人人爽曰av | 国产精品久久在线观看 | 国产福利不卡视频 | 一级淫片在线观看 | 91久久国产露脸精品国产闺蜜 | 免费国产黄线在线观看视频 | 狠狠色伊人亚洲综合成人 | 97成人精品视频在线观看 | 国产成人三级三级三级97 | 中文亚洲欧美日韩 | 国产原创91 | 亚洲性xxxx| 久久福利综合 | 奇米四色影狠狠爱7777 | 婷婷中文字幕综合 | 99热这里只有精品1 av中文字幕日韩 | 中文字幕在线免费看线人 | 2022中文字幕在线观看 | 人人添人人澡人人澡人人人爽 | 香蕉一区 | 91秒拍国产福利一区 | 欧美大片mv免费 | 亚洲专区欧美专区 | 天天干com| 亚洲精品国产精品乱码不99热 | 国产精品视频不卡 | 久久综合久色欧美综合狠狠 | 国产成人av电影 | 六月丁香社区 | 免费成人短视频 | 亚洲尺码电影av久久 | 精品国产精品国产偷麻豆 | 精品在线观看视频 | 色婷婷激婷婷情综天天 | 天堂入口网站 | 精品国产免费看 | 久久伊人八月婷婷综合激情 | 日韩三级免费观看 | 国产美女永久免费 | 久草热视频 | av福利在线 | 免费精品在线观看 | 国产精品久久久久影院日本 | 96看片| 少妇按摩av| 五月天激情开心 | 日本公乱妇视频 | 国产精品嫩草69影院 | 久久久精品视频成人 | 日韩免费在线观看视频 | 在线观看日韩av | 成人在线观看免费视频 | 欧美成a人片在线观看久 | 免费黄色av.| 青青草国产成人99久久 | 成人久久久久久久久久 | 久热香蕉视频 | 国产黄免费在线观看 | 91精品国产自产在线观看 | 国产免费看 | 国产真实在线 |