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

Flex數據庫連接的方法集錦

開發 后端
本文向大家介紹一下Flex連接數據庫三種方法,Flex是不能直接連接數據庫的,這一點大家需要知道,它只能間接地連接數據庫。

本文和大家重點討論一下連接Flex數據庫三種方法,Flex是不能直接連接數據庫的,這一點大家需要知道,它只能間接地連接數據庫。Flex中提供了三種方式:HttpService,WebService和RemoteObject。

連接Flex數據庫三種方法

首先,做一點說明。Flex是不能直接連接數據庫的,這一點大家需要知道,它只能間接地進行連接Flex數據庫。Flex中提供了三種方式:HttpService,WebService和RemoteObject。其中HttpService可以直接獲取XML中的數據,還可以通過JSP,ASP以及PHP讀取數據庫中的數據,這個比較簡單,而且網上也有很多例子,我就不多說了。WebService我不懂,請自己查資料。我一直用的是JAVA對象連接數據庫,感覺這個挺方便,而且J2EE的技術已經很成熟。今天的教程就是以Flex+JAVA+SQLServer獲取數據庫公告信息為例簡單說一下RemoteObject的用法。

前提

1.確保你安裝了FlexDataService。這個對于單個CUP無限APP是免費的,可以去Adobe下載。如果只是讀取XML文件是不需要這個的,連接數據庫就需要它了。
2.安裝了FlexBuilder或者有FlexSDK。我這里使用的是FlexBuilder(IDE就是方便啊^_^)。
3.安裝了SQLServer數據庫。
4.安裝了JRUN或者tomcat或其它的J2EE容器,因為發布的時候我們的程序要運行在J2EE平臺上。
5.安裝了JDK。

第一步:創建Flex數據庫

這里我們有一個公告表,表名為Bulletin。結構如下:

字段名稱字段類型說明
ID自動編號自動編號
titleNvarchar(100)題目
datedatatime日期
authorNvarchar(20)作者
contentntext內容
在數據庫中創建這個表。保存之后進入下一步。#p#

第二步:在JAVA中編寫獲取公告的代碼

首先,我們要創建一個公告類來專門保存獲取的公告信息,代碼如下。

  1. NoticeInfo.java  
  2. packagenet.zhuoqun.connectDB;  
  3. importjava.util.Date;  
  4. publicclassNoticeInfo{  
  5. privateStringtitle;//標題  
  6. privateStringauthor;//作者  
  7. privateStringcontent;//內容  
  8. privateDatedates;//時間  
  9. publicStringgetAuthor(){  
  10. returnauthor;  
  11. }  
  12. publicvoidsetAuthor(Stringauthor){  
  13. this.author=author;  
  14. }  
  15. ………………//其它get和set方法。  
  16. }  

創建好這個之后我們要創建一個數據查詢類:DataServiceImpl.java來查詢Flex數據庫,并將查詢結果傳給將要創建的Flex程序。由于我們不清楚有多少條記錄,所以就借助一下JAVA中的ArrayList這個類,它位于java.util包中。先創建一個ArrayList:
ArrayListnoticeList=newArrayList();
查詢數據庫之后,每讀取一條記錄就添加到noticeList。
 

  1. while(rs.next()){  
  2. NoticeInfotemp=newNoticeInfo();  
  3. temp.setAuthor(rs.getString("author"));  
  4. temp.setContent(rs.getString("content"));  
  5. temp.setDates(rs.getDate("date"));  
  6. temp.setTitle(rs.getString("title"));  
  7. noticeList.add(temp);  
  8. }  

查詢完畢之后你就可以把這個noticeList傳回去,你也可以傳回去一個NoticeInfo數組:
 

  1. NoticeInfo[]notices=newNoticeInfo[noticeList.size()];  
  2. for(inti=0;i<noticeList.size();i++){  
  3. notices=(NoticeInfo)noticeList.get(i);  
  4. }  
  5. returnnotices; 


我這里用的是后一種方法。如果你直接把noticeList傳回去的話,記住一點,JAVA的ArrayList類型的對象到了Flex中會變成ArrayCollection類型的。
現在JAVA部分的代碼就寫好了。
DataServiceImpl.java的全部代碼如下:
 

  1. packagenet.zhuoqun.connectDB;  
  2. importjava.sql.*;  
  3. importjava.util.ArrayList;  
  4. importjava.util.Date;  
  5. publicclassDataServiceImpl{  
  6. privateConnectionconn=null;  
  7. privateStatementstmt=null;  
  8. //以下是數據庫以及驅動信息  
  9. publicfinalstaticStringDRIVER="com.microsoft.jdbc.sqlserver.SQLServerDriver";  
  10. publicfinalstaticStringCONN_STR_PRE="jdbc:microsoft:sqlserver://";  
  11. publicfinalstaticStringHOST_NAME="localhost:1433;";  
  12. publicfinalstaticStringDATABASE_NAME="DatabaseName=mydata";  
  13. publicfinalstaticStringUSERNAME="aaa";  
  14. publicfinalstaticStringPASSWORD="aaa";  
  15. publicDataServiceImpl(){  
  16.  
  17. }  
  18. //查詢數據庫  
  19. privateResultSetexecuteQuery(StringsqlText){  
  20. try{  
  21. Class.forName(DRIVER);  
  22. }catch(ClassNotFoundExceptione){  
  23. e.printStackTrace();  
  24. }  
  25. try{  
  26. conn=DriverManager.getConnection(CONN_STR_PRE+HOST_NAME+DATABASE_NAME,USERNAME,PASSWORD);  
  27. stmt=conn.createStatement();  
  28. ResultSetrs=stmt.executeQuery(sqlText);  
  29. returnrs;  
  30. }catch(SQLExceptione){  
  31. e.printStackTrace();  
  32. }  
  33. returnnull;  
  34. }  
  35. //查詢公告.這個是本程序的關鍵代碼  
  36. publicNoticeInfo[]getNotices(){  
  37. ArrayListnoticeList=newArrayList();  
  38. StringsqlText="selectauthor,content,date,titlefromBulletin";  
  39. ResultSetrs=executeQuery(sqlText);  
  40. try{  
  41. while(rs.next()){  
  42. NoticeInfotemp=newNoticeInfo();  
  43. temp.setAuthor(rs.getString("author"));  
  44. temp.setContent(rs.getString("content"));  
  45. temp.setDates(rs.getDate("date"));  
  46. temp.setTitle(rs.getString("title"));  
  47. noticeList.add(temp);  
  48. }  
  49. NoticeInfo[]notices=newNoticeInfo[noticeList.size()];  
  50. for(inti=0;i<noticeList.size();i++){  
  51. notices=(NoticeInfo)noticeList.get(i);  
  52. }  
  53. returnnotices;  
  54. }catch(SQLExceptione){  
  55. e.printStackTrace();  
  56. returnnull;  
  57. }  
  58. }  
  59. }  
  60.  

 

#p#第三步:配置FlexDataService

1,把剛才寫的JAVA文件編譯。打開FDS的安裝文件夾,將編譯的文件拷貝到\jrun4\servers\default\flex\WEB-INF\classes文件夾中,進行下面的配置。
2.打開FDS的安裝文件夾。進入jrun4\servers\default\flex\WEB-INF\flex目錄。里面是關于FlexDataService的配置文件,我們這里只看RemoteObject如何配置,其它配置信息請自己看幫助。現在我們打開里面的remoting-config.xml文件。向里面添加如下信息,作為<service>的子標簽:
程序代碼
 

  1. <destinationiddestinationid="dataService"> 
  2. <properties> 
  3. <source>net.zhuoqun.connectDB.DataServiceImpl</source> 
  4. </properties> 
  5. </destination> 

當你設定了destination的時候,你就引用了了可以用來連接相應類的信息通道(messagingchannel)。它的id必須在文件中是獨一無二的。source屬性是指你編譯的JAVA類在classes文件夾中的路徑。由于我的DataServiceImpl類在classes\net\zhuoqun\connectDB中,所以source的值為net.zhuoqun.connectDB.DataServiceImpl。記住,不要寫.class后綴。<properties>標簽還可以有一個<scope>子標簽,其作用我在這里就不說了,大家自己看相關文檔(關于FDS的配置其實有很多東西,這些在幫助文檔里都有,我這里不多說了,也說不過來,自己看吧)。
現在我們已經配置好了后臺的FDS,做完了整個程序的大部分工作,接下來就是前臺Flex程序調用的事情了。

第四步:創建Flex程序

打開FlexBuilder,新建一個工程ConnectDB。菜單欄中File->New->FlexProject,這時會彈出一個對話框,選擇FlexDataService,創建了一個Flex工程。

#p#第五步:通過RemoteObject訪問Flex數據庫

打開工程中生成的主文件ConnectDB.mxml,聲明一個RemoteObject:

程序代碼
 

  1. <mx:RemoteObjectidmx:RemoteObjectid="getData"destination="dataService"  
  2.  
  3. result="proccessResult(event.result)"fault="Alert.show(event.fault.faultString,'Error')"/> 


其中destination的值是剛才我們在配置FDS的時候設定的destination。result表示在這個RemoteObject成功返回之后所要做的動作,這里我們調用一個方法proccessResult()來處理返回的數據,它的參數event.result就是從服務器段獲得的數據,數據是作為一個對象傳過來的。fault表示在這個RemoteObject請求失敗時要做的處理,這里我們會彈出一個顯示錯誤信息的對話框。

接下來我們要聲明一個DataGrid控件來顯示公告的標題和發布日期:

程序代碼
 

  1. <mxataGrididmxataGridid="myDG"> 
  2. <mx:columns> 
  3. <mxataGridColumnheaderTextmxataGridColumnheaderText="標題"dataField="title"/> 
  4. <mxataGridColumnheaderTextmxataGridColumnheaderText="發布日期"dataField="dates"labelFunction="formatDate"/> 
  5. </mx:columns> 
  6. </mx:DataGrid> 

其中headerText是顯示在上方的表頭,dataField表示要顯示的數據域,為什么數據域是title和dates呢?因為我們傳回的是一個NoticeInfo對象數組,雖然它是作為一個對象傳回來的,但是其中的數據結構并沒有變,那些數據域的名字也沒有變,所以我們可以根據NoticeInfo中的變量設定dataField。labelFunction屬性是用來格式化顯示的,因為傳回來的是格林威治時間,所以我們需要將其格式化然后顯示出來。注意,這里只是顯示兩個數據域,并不代表其它的數據都沒有了,它們仍然存在,只是沒有顯示出來。

接下來,在<mx:Script>標簽中編寫proccessResult()方法和格式化日期的formatDate方法:
程序代碼
 

  1. privatefunctionproccessResult(result:Object):void  
  2. {  
  3. myDG.dataProvider=ArrayUtil.toArray(result);  
  4. }  
  5. privatefunctionformatDate(item:Object,column:DataGridColumn):String  
  6. {  
  7. returndf.format(item.dates);  
  8. }// 

df是一個DateFormatter,在下面會給出。關于如何格式化DataGrid的顯示
//以及DateFormatter這里就不討論了,幫助里寫得很清楚
這個函數只是簡單地將獲得的數據傳給myDG的dataProvider。result的類型是Object,因為數據是作為一個對象傳過來的。之所以調用ArrayUtil.toArray()這個方法,是因為返回的記錄可能只有一條,而myDG的dataProvider顯示單個對象的時候可能會出錯,所以安全起見先將其轉換成數組。
最后,我們編寫調用RemoteObject的方法,使其在程序啟動時就調用。

程序代碼
 

  1. privatefunctioninitApp():void  
  2. {  
  3. getData.getNotices();  


其中getData是RemoteObject的id,getNotices()是DataServiceImpl.java中的方法。在這里可以直接調用它。當然,如果DataServiceImpl.java有其它方法,也可以通過這種方式直接調用。

接下來設定組件創建完畢時調用initApp()方法,在<mx:Application>中添加一個creationComplete屬性:
程序代碼
 

  1. <mx:Applicationxmlns:mxmx:Applicationxmlns:mx="http://www.adobe.com/2006/mxml" 
  2.  
  3. fontSize="12"creationComplete="initApp()"> 

ConnectDB.mxml的全部代碼:
程序代碼
 

  1. <?xmlversionxmlversion="1.0"encoding="utf-8"?> 
  2. <mx:Applicationxmlns:mxmx:Applicationxmlns:mx="http://www.adobe.com/2006/mxml" 
  3.  
  4. fontSize="12"creationComplete="initApp()"> 
  5. <mx:Script> 
  6. <![CDATA[  
  7. importmx.controls.Alert;  
  8. importmx.utils.ArrayUtil;  
  9. privatefunctioninitApp():void  
  10. {  
  11. getData.getNotices();  
  12. }  
  13. privatefunctionproccessResult(result:Object):void  
  14. {  
  15. myDG.dataProvider=ArrayUtil.toArray(result);  
  16. }  
  17. privatefunctionformatDate(item:Object,column:DataGridColumn):String  
  18. {  
  19. returndf.format(item.dates);  
  20. }//df是一個DateFormatter,在下面會給出。  
  21. 關于如何格式化DataGrid的顯示  
  22. //以及DateFormatter這里就不討論了,幫助里寫得很清楚  
  23. ]]> 
  24. </mx:Script> 
  25. <mx:DateFormatteridmx:DateFormatterid="df"formatString="YYYY-MM-DD"/> 
  26. <mx:RemoteObjectidmx:RemoteObjectid="getData"destination="dataService"  
  27. result="proccessResult(event.result)"fault="Alert.show(event.fault.faultString,'Error')"/> 
  28. <mx:DataGrididmx:DataGridid="myDG"> 
  29. <mx:columns> 
  30. <mx:DataGridColumnheaderTextmx:DataGridColumnheaderText="標題"dataField="title"/> 
  31. <mx:DataGridColumnheaderTextmx:DataGridColumnheaderText="發布日期"dataField="dates"labelFunction="formatDate"/> 
  32. </mx:columns> 
  33. </mx:DataGrid> 
  34. </mx:Application> 


整個工程終于完成,啟動JRUN,然后運行程序,查看程序結果。如果是其他數據庫,只需要改一下數據庫驅動信息就可以了

【編輯推薦】

  1. 連接Flex數據庫行之有效的辦法
  2. 連接Flex數據庫三種方法
  3. Flex及FlexBuilder2.0開發環境詳解
  4. FlexBuilder3.0與Eclipse3.4的完美結合
  5. 學習筆記 FlexBuilder2.0中如何使用基于Lists的控件 


 

責任編輯:佚名 來源: javaeye.com
相關推薦

2010-08-04 10:32:56

Flex連接數據庫

2010-07-29 09:56:45

Flex數據庫

2010-08-03 09:27:29

設置Flex樣式

2010-07-29 10:09:09

Flex數據庫

2010-10-26 15:54:02

連接oracle數據庫

2010-08-05 14:03:32

Flex框架

2009-08-12 14:23:01

C#連接MySql數據

2009-06-10 22:11:28

javascript連

2009-11-30 17:54:56

PHP連接Sql數據庫

2009-07-31 17:07:40

ASP.NET數據庫連

2011-05-26 09:27:59

JDBC連接數據庫

2010-09-13 15:55:17

SQL Server數

2011-04-18 09:29:40

數據庫連接數

2010-09-08 13:53:10

.NET連接Sybas

2009-08-18 11:23:11

2010-11-08 16:04:06

SQL SERVER連

2010-08-27 14:39:46

db2連接數據庫

2019-03-27 14:41:41

Python數據庫Windows

2011-08-22 13:04:47

SQL Server數函數

2010-08-13 13:14:09

Flex圖表
點贊
收藏

51CTO技術棧公眾號

欧美magnet| 亚洲 国产 欧美 日韩| 欧美成人milf| 日韩三级av在线播放| 人人干视频在线| av在线之家电影网站| 国产一区999| 7777精品视频| 四虎永久免费地址| 国产区精品视频在线观看豆花| 欧美性生活大片免费观看网址| 一区二区三区四区五区精品| 色婷婷视频在线| 久久国产精品99久久久久久老狼| 高清视频欧美一级| 免费黄色激情视频| 一区二区美女| 精品国产精品网麻豆系列| 国产一级片黄色| 大香伊人久久| 亚洲日穴在线视频| 久久久综合亚洲91久久98| 国产又爽又黄免费软件| 精品动漫3d一区二区三区免费| 中文字幕欧美日韩在线| 性色av蜜臀av色欲av| 天堂综合在线播放| 欧美亚洲一区二区在线| 亚洲午夜无码av毛片久久| 日韩激情美女| 最新中文字幕一区二区三区| 日韩久久在线| 日本韩国精品一区二区| 成人高清在线视频| 成人毛片网站| 日韩av片网站| 精精国产xxxx视频在线野外| 亚洲欧美一区二区三区极速播放 | 国产精品国产自产拍高清av | 天天干天天做天天操| 国产一区二区三区免费播放| 国产精品第一视频| 亚洲午夜18毛片在线看| 一本综合久久| 2019av中文字幕| 日韩xxx高潮hd| 亚洲国产高清一区| 97碰碰碰免费色视频| 久草视频中文在线| 欧美日韩一卡| 欧美极品美女电影一区| 精品少妇一二三区| 国模吧视频一区| 欧美国产日韩在线| 国产亚洲成人av| 在线观看的日韩av| 韩国三级电影久久久久久| 日本少妇久久久| 亚洲精品日本| 青青精品视频播放| 少妇无套内谢久久久久| 蜜臀久久99精品久久久画质超高清| 国产精品精品视频| 亚洲天堂网视频| 韩国精品久久久| 亚洲影院在线看| 丰满人妻熟女aⅴ一区| 成人短视频下载| 久久艳妇乳肉豪妇荡乳av| 黄色片在线免费看| 国产精品美女久久福利网站| 91免费网站视频| 婷婷在线播放| 欧美视频国产精品| 五月婷婷狠狠操| 麻豆精品久久| 日韩高清免费在线| 美国美女黄色片| 自拍偷拍欧美| 欧美一区二区三区……| 久草热在线观看| 国产乱码精品一区二区三区av | www.色就是色.com| 日韩高清二区| 亚洲欧美精品一区二区| 亚洲一区二区久久久久久| 久久精品女同亚洲女同13| 日韩大胆成人| 中文字幕一区日韩电影| 麻豆亚洲av成人无码久久精品| 影音先锋亚洲电影| 国产精品爽黄69天堂a| 一区二区三区免费观看视频| 成人福利视频在线| 亚洲国产精品一区二区第四页av| 日本大胆在线观看| 色综合久久久久综合体| www.午夜av| 日韩精品免费一区二区夜夜嗨| 色综合伊人色综合网| 久久精品视频6| 美女网站在线免费欧美精品| 国产麻豆日韩| 日本在线天堂| 欧美日韩国产麻豆| 亚洲热在线视频| 国产最新精品| 欧美激情精品久久久久久大尺度| 天天射天天干天天| 成人黄色av网站在线| 亚洲在线视频一区二区| 三级中文字幕在线观看| 欧美一区二区在线视频| 极品人妻videosss人妻| 亚洲精品专区| www.成人av.com| 午夜伦理在线| 在线观看日韩一区| 免费看黄色aaaaaa 片| 欧美欧美天天天天操| 国产精品久久久久久久美男| 日韩美女一级视频| 亚洲高清免费在线| 国模大尺度视频| 91亚洲国产高清| 国产精品欧美在线| 蜜桃视频在线免费| 欧美午夜激情在线| 一区二区视频观看| 亚洲激情成人| 国产精品免费区二区三区观看| 国产一二区在线| 精品视频在线免费| 性欧美一区二区| 久久久青草婷婷精品综合日韩| 国产亚洲一区二区三区在线播放 | 亚洲综合婷婷久久| 精品理论电影| 国产精品久久久久久久app| 欧美日韩国产综合视频| 欧美日韩另类在线| 久久久久无码国产精品一区李宗瑞| 亚洲天堂免费| 亚洲一区精品电影| 日本在线视频www鲁啊鲁| 欧美一区二区三区免费大片| 成人免费毛片xxx| 韩日av一区二区| japanese在线播放| 97视频一区| 孩xxxx性bbbb欧美| 亚欧在线观看视频| 91福利区一区二区三区| www.99热| 捆绑调教一区二区三区| 青春草在线视频免费观看| 亚洲欧美专区| 欧美激情精品久久久| 天堂av一区二区三区| 一本高清dvd不卡在线观看| 亚洲综合色一区| 轻轻草成人在线| 综合色婷婷一区二区亚洲欧美国产| vam成人资源在线观看| 插插插亚洲综合网| 成人午夜视频一区二区播放| 精品久久久久久久久久| 精品国产成人亚洲午夜福利| 久久99精品一区二区三区| 黑人巨大国产9丨视频| 91精品导航| 欧美亚洲另类视频| 天堂中文8资源在线8| 日韩视频在线一区二区| 在线观看中文字幕视频| 国产精品欧美极品| 色哟哟在线观看视频| 亚洲免费激情| 色综合影院在线观看| 日韩av综合| 欧美一区第一页| 黄a在线观看| 亚洲精品美女在线观看播放| 在线观看国产成人| 亚洲一线二线三线久久久| 久久亚洲AV成人无码国产野外| 麻豆久久久久久久| 欧美中文字幕在线观看视频| 久久综合亚洲| 99re国产在线播放| 亚洲精品一区三区三区在线观看| 乱亲女秽乱长久久久| 天堂a√在线| 3d成人h动漫网站入口| 日韩成人一区二区三区| 国产精品毛片高清在线完整版| 亚洲国产精品第一页| 久久精品99国产精品| 精品无码一区二区三区在线| 999久久久免费精品国产| 狠狠色狠狠色综合人人| 综合欧美精品| 国产精品99久久久久久久久久久久 | 夜夜爽99久久国产综合精品女不卡| 99亚洲乱人伦aⅴ精品| 国产精品一区二区久久久| av有码在线观看| 久久香蕉国产线看观看网| 男人的天堂在线| 欧美成人vr18sexvr| 中文字幕在线播放av| 精品女同一区二区三区在线播放| 日本中文在线视频| 亚洲国产精品t66y| 蜜桃精品成人影片| 不卡一区二区在线| 中文字幕55页| 激情综合网av| 超碰超碰在线观看| 视频一区欧美日韩| 国产精品宾馆在线精品酒店| 欧美体内she精视频在线观看| 亚洲综合欧美日韩| 俺要去色综合狠狠| 欧美精品一区二区三区四区五区| 国产精品网站在线看| 91久久久一线二线三线品牌| 成人国产在线| 国产精品xxx视频| 亚洲最大网站| 日本aⅴ大伊香蕉精品视频| 久草免费在线视频| 久久久久久久999| 国产理论电影在线| 欧美—级高清免费播放| 91探花在线观看| 欧美激情中文网| 不卡专区在线| 欧美性视频在线| 电影网一区二区| 国产成人精品最新| 日本不卡一二三| 国产精品久久中文| 免费成人高清在线视频| 国产精品视频内| 亚洲三级电影| 亚洲一区二区三区香蕉| 亚洲伊人影院| 精品无码久久久久国产| 网友自拍一区| 欧美少妇一区| 成人在线视频免费观看| 在线观看欧美激情| 自拍视频亚洲| 男人的天堂狠狠干| 久久av一区| 精品999在线| 国产综合色产在线精品| 亚洲妇女无套内射精| 成人动漫中文字幕| 色哟哟精品观看| 国产精品青草久久| 麻豆精品一区二区三区视频| 洋洋av久久久久久久一区| 中文字幕一区二区三区手机版| 午夜国产精品一区| 午夜精品久久久久久久蜜桃| 欧美日韩免费高清一区色橹橹| 国产欧美综合视频| 精品播放一区二区| 欧洲视频在线免费观看| 深夜成人在线观看| 波多一区二区| 国产成人精品一区二区| 麻豆一区在线| 久久久福利视频| 999精品视频| 人妻少妇精品无码专区二区| 日日摸夜夜添夜夜添国产精品| 日本中文字幕观看| 91网站在线观看视频| 人妻无码一区二区三区免费| 一区二区三区免费在线观看| 欧美特黄aaaaaa| 欧美精品黑人性xxxx| 天天操天天射天天| 最近2019年中文视频免费在线观看| wwwav在线| 人人做人人澡人人爽欧美| 国产精品视频一区视频二区| 久久综合色一本| 91精品一区二区三区综合| 欧美日韩一道本| 国产综合色精品一区二区三区| 无码人妻aⅴ一区二区三区| 亚洲欧洲日韩在线| 福利网址在线观看| 精品久久久久久无| 日本高清中文字幕在线| 欧美一区二区三区四区在线| 日韩欧美中文字幕一区二区三区| 欧美成人一区二区在线| 国产精品v欧美精品v日本精品动漫| 国产视频在线视频| hitomi一区二区三区精品| 五月综合色婷婷| 在线看一区二区| 无码国产伦一区二区三区视频| 日韩中文字幕欧美| 欧美日韩免费观看视频| 国产一区免费在线| 自拍偷拍欧美专区| 一区二区三区欧美精品| 久久久久久一级片| 亚洲精品男人天堂| 欧美精品一区二区精品网| 精品国产99久久久久久| 国产精品日韩欧美大师| 在线观看欧美理论a影院| 日韩网站在线免费观看| 国产伦精一区二区三区| 四虎永久免费地址| 欧美日韩高清影院| 国产乱理伦片a级在线观看| 欧美亚洲第一页| 久久狠狠久久| 欧美人成在线观看| 国产风韵犹存在线视精品| 特一级黄色录像| 51精品秘密在线观看| 瑟瑟视频在线| 国产美女精品视频| 日韩毛片视频| 日本中文字幕高清| 中文子幕无线码一区tr| 伊人成年综合网| 国产亚洲精品激情久久| 国产成人精品123区免费视频| 久久伦理网站| 久久裸体视频| 影音先锋男人在线| 欧美日韩中文国产| 一区二区高清不卡| 国产精自产拍久久久久久| 日韩大片在线| 一本一道久久a久久综合蜜桃| 国产精品日韩成人| 一卡二卡三卡在线观看| 精品久久久999| 国产精品**亚洲精品| 日韩精品手机在线观看| 国产成人精品免费网站| 国产在线成人精品午夜| 亚洲精品久久久久久下一站| 深夜成人在线| 日韩福利二区| 久久国产生活片100| 欧美在线视频第一页| 欧美一区二区三区视频在线观看| 直接在线观看的三级网址| 国产精品免费看一区二区三区| 亚洲久久一区| 精品无码人妻一区二区免费蜜桃| 欧美视频第二页| 污片在线免费观看| 免费成人av网站| 麻豆精品一区二区av白丝在线| 男人操女人的视频网站| 亚洲第一偷拍网| 欧美暴力调教| www国产免费| 91丨porny丨国产入口| 伊人网免费视频| 久久99精品久久久久久噜噜| 欧美性生活一级片| 五月激情婷婷在线| 亚洲一区二区三区影院| 美国成人毛片| 亚洲综合小说区| 午夜亚洲性色视频| 日韩一区二区不卡视频| 亚洲成色777777女色窝| 电影一区电影二区| 国产美女在线一区| 亚洲欧洲日产国码二区| 色呦呦视频在线| 成人黄色av网站| 亚洲综合精品| 欧美黑人一级片| 中文字幕亚洲二区| 精品五月天堂| www.污污视频| 狠狠综合久久av一区二区小说| 久久久久久国产精品免费无遮挡| 国内精品久久国产| 久久99精品久久久久久| 欧美 日韩 精品| 欧美成人精品在线| 日韩精品影视| 醉酒壮男gay强迫野外xx|