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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

jax-rs jax-ws_如何以大数据的JAX-RS响应的形式将JPA结果流化/序列化

發布時間:2023/12/3 编程问答 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 jax-rs jax-ws_如何以大数据的JAX-RS响应的形式将JPA结果流化/序列化 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

jax-rs jax-ws

有時,有必要通過JPA檢索大型數據集(例如,超過1,000,000條記錄),并將它們填充到java.util.List的單個實例中是有風險的(內存障礙)。 因此,這是一個快速的解決方案,它可以解決JAX-RS REST資源端點如何仍能通過“頁面”對JPA實體進行流式處理或序列化而在不破壞內存約束的情況下及時提供響應。

示例數據庫表和JPA實體

數據庫表

為了演示如何實現大數據輸出,這是我們可以使用的示例MySQL數據庫表。

create database large_data_test_db; use large_data_test_db;create table generated_uuids (record_no bigint not null auto_increment,uuid varchar(100) not null,datetime_generated datetime not null,primary key(record_no),unique(uuid) );

JPA實體

接下來,定義代表上述表結構的JPA實體類。

GeneratedUuidEntity.java的代碼

package com.developerscrappad;import java.io.Serializable; import java.util.Date; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.NamedQueries; import javax.persistence.NamedQuery; import javax.persistence.Table; import javax.persistence.Temporal; import javax.persistence.TemporalType;@Entity @Table( name = "generated_uuids" ) @NamedQueries( {@NamedQuery( name = "GeneratedUuidEntity.listAll", query = "SELECT u FROM GeneratedUuidEntity u" ),@NamedQuery( name = "GeneratedUuidEntity.queryRecordsSize", query = "SELECT count(u) FROM GeneratedUuidEntity u" ) } ) public class GeneratedUuidEntity implements Serializable {private static final long serialVersionUID = 12312312234234123L;@Id@GeneratedValue( strategy = GenerationType.IDENTITY )@Column( name = "record_no" )private Long recordNo;@Column( name = "uuid" )private String uuid;@Column( name = "datetime_generated" )@Temporal( TemporalType.TIMESTAMP )private Date datetimeGenerated;public GeneratedUuidEntity() {}public GeneratedUuidEntity( Long recordNo ) {this.recordNo = recordNo;}public GeneratedUuidEntity( Long recordNo, String uuid, Date datetimeGenerated ) {this.recordNo = recordNo;this.uuid = uuid;this.datetimeGenerated = datetimeGenerated;}public Long getRecordNo() {return recordNo;}public void setRecordNo( Long recordNo ) {this.recordNo = recordNo;}public String getUuid() {return uuid;}public void setUuid( String uuid ) {this.uuid = uuid;}public Date getDatetimeGenerated() {return datetimeGenerated;}public void setDatetimeGenerated( Date datetimeGenerated ) {this.datetimeGenerated = datetimeGenerated;}@Overridepublic int hashCode() {int hash = 0;hash += ( recordNo != null ? recordNo.hashCode() : 0 );return hash;}@Overridepublic boolean equals( Object object ) {// TODO: Warning - this method won't work in the case the id fields are not setif ( !( object instanceof GeneratedUuidEntity ) ) {return false;}GeneratedUuidEntity other = ( GeneratedUuidEntity ) object;if ( ( this.recordNo == null && other.recordNo != null ) || ( this.recordNo != null && !this.recordNo.equals( other.recordNo ) ) ) {return false;}return true;}@Overridepublic String toString() {return "com.developerscrappad.GeneratedUuidEntity[ recordNo=" + recordNo + " ]";} }

GeneratedUuidEntity中定義了兩個命名查詢。 GeneratedUuidEntity.queryRecordsSize用于查詢表的總記錄數,而GeneratedUuidEntity.listAll用于檢索表中的所有記錄。

實施JAX-RS REST資源(Java EE方式)

讓我們有一個名稱為JPAStreamingRESTResource的JAX-RS REST資源類,其中有一個可用的JPA EntityManager(持久性名稱: JPAStreamingPU )要注入,并通過受保護的方法getEntityManager()獲得

@Path( "generated-uuids" ) @Stateless( name = "JPAStreamingRESTResource", mappedName = "ejb/JPAStreamingRESTResource" ) public class JPAStreamingRESTResource {@PersistenceContext( unitName = "JPAStreamingPU" )private EntityManager entityManager;protected EntityManager getEntityManager() {return entityManager;}/*** Say "NO" to response caching*/protected Response.ResponseBuilder getNoCacheResponseBuilder( Response.Status status ) {CacheControl cc = new CacheControl();cc.setNoCache( true );cc.setMaxAge( -1 );cc.setMustRevalidate( true );return Response.status( status ).cacheControl( cc );} }

此外,我們有一個名為getNoCacheResponseBuilder()的方法,該方法將獲得一個非緩存的javax.ws.rs.core.Response.ResponseBuilder ,這樣以后就不會再得到奇怪的緩存結果了。

JPA調用方法

接下來,讓我們在資源類中定義兩個方法,即:

queryGeneratedUuidRecordsSize() –檢索表中的記錄總數

private int queryGeneratedUuidRecordsSize() {return getEntityManager().createNamedQuery( "GeneratedUuidEntity.queryRecordsSize", Long.class ).getSingleResult().intValue(); }

listAllGeneratedUuidEntities() –從表中檢索所有數據,但具有某些限制條件,例如記錄的開始位置(recordPosition)和每次往返數據庫的最大記錄數(recordsPerRoundTrip)。 目的是“分頁”結果,以使結果列表不會過分膨脹。 我們稍后會看到它的作用。

private List<GeneratedUuidEntity> listAllGeneratedUuidEntities( int recordPosition, int recordsPerRoundTrip ) {return getEntityManager().createNamedQuery( "GeneratedUuidEntity.listAll" ).setFirstResult( recordPosition ).setMaxResults( recordsPerRoundTrip ).getResultList(); }

讓流開始

現在,讓我們實現資源端點方法,至少從理論上講,該方法可以在不損害大小的情況下檢索數據。 此方法將返回JSON響應,其數據格式為:

{"result": [{"record_no": 1,"uuid": "34d99089-3e36-4f00-ab93-846b61771eb3","datetime_generated": "2015-06-28 21:02:23"},…] }@GET@Path( "list-all" )@Produces( "application/json" )@TransactionAttribute( TransactionAttributeType.NEVER )public Response streamGeneratedUuids() {// Define the format of timestamp outputSimpleDateFormat df = new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss" );return getNoCacheResponseBuilder( Response.Status.OK ).entity( new StreamingOutput() {// Instruct how StreamingOutput's write method is to stream the data@Overridepublic void write( OutputStream os ) throws IOException, WebApplicationException {int recordsPerRoundTrip = 100; // Number of records for every round trip to the databaseint recordPosition = 0; // Initial record position indexint recordSize = queryGeneratedUuidRecordsSize(); // Total records found for the query// Start streaming the datatry ( PrintWriter writer = new PrintWriter( new BufferedWriter( new OutputStreamWriter( os ) ) ) ) {writer.print( "{\"result\": [" );while ( recordSize > 0 ) {// Get the paged data set from the DBList<GeneratedUuidEntity> generatedUuidEntities = listAllGeneratedUuidEntities( recordPosition, recordsPerRoundTrip );for ( GeneratedUuidEntity generatedUuidEntity : generatedUuidEntities ) {if ( recordPosition > 0 ) {writer.print( "," );}// Stream the data in Json object formatwriter.print( Json.createObjectBuilder().add( "record_no", generatedUuidEntity.getRecordNo() ).add( "uuid", generatedUuidEntity.getUuid() ).add( "datetime_generated", df.format( generatedUuidEntity.getDatetimeGenerated() ) ).build().toString() );// Increase the recordPosition for every record streamedrecordPosition++;}// update the recordSize (remaining no. of records)recordSize -= recordsPerRoundTrip;}// Done!writer.print( "]}" );}}} ).build();}

電源線說明:

實際上,這很簡單。 訣竅是通過重寫write()方法來定義匿名類StreamingOutput的表達式,該方法首先通過queryGeneratedUuidRecordsSize()查詢總記錄大小,然后通過listAllGeneratedUuidEntities()逐頁檢索記錄。 此方法將多次訪問數據庫,具體取決于定義的recordsPerRoundTrip值。

JPAStreamingRESTResource.java的完整源代碼:

package com.developerscrappad;import java.io.BufferedWriter; import java.io.IOException; import java.io.OutputStream; import java.io.OutputStreamWriter; import java.io.PrintWriter; import java.text.SimpleDateFormat; import java.util.List; import javax.ejb.Stateless; import javax.ejb.TransactionAttribute; import javax.ejb.TransactionAttributeType; import javax.json.Json; import javax.persistence.EntityManager; import javax.persistence.PersistenceContext; import javax.ws.rs.GET; import javax.ws.rs.Path; import javax.ws.rs.Produces; import javax.ws.rs.WebApplicationException; import javax.ws.rs.core.CacheControl; import javax.ws.rs.core.Response; import javax.ws.rs.core.StreamingOutput;@Path( "generated-uuids" ) @Stateless( name = "JPAStreamingRESTResource", mappedName = "ejb/JPAStreamingRESTResource" ) public class JPAStreamingRESTResource {@PersistenceContext( unitName = "JPAStreamingPU" )private EntityManager entityManager;private List<GeneratedUuidEntity> listAllGeneratedUuidEntities( int recordPosition, int recordsPerRoundTrip ) {return getEntityManager().createNamedQuery( "GeneratedUuidEntity.listAll" ).setFirstResult( recordPosition ).setMaxResults( recordsPerRoundTrip ).getResultList();}private int queryGeneratedUuidRecordsSize() {return getEntityManager().createNamedQuery( "GeneratedUuidEntity.queryRecordsSize", Long.class ).getSingleResult().intValue();}protected EntityManager getEntityManager() {return entityManager;}/*** Say "NO" to response caching*/protected Response.ResponseBuilder getNoCacheResponseBuilder( Response.Status status ) {CacheControl cc = new CacheControl();cc.setNoCache( true );cc.setMaxAge( -1 );cc.setMustRevalidate( true );return Response.status( status ).cacheControl( cc );}@GET@Path( "list-all" )@Produces( "application/json" )@TransactionAttribute( TransactionAttributeType.NEVER )public Response streamGeneratedUuids() {// Define the format of timestamp outputSimpleDateFormat df = new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss" );return getNoCacheResponseBuilder( Response.Status.OK ).entity( new StreamingOutput() {// Instruct how StreamingOutput's write method is to stream the data@Overridepublic void write( OutputStream os ) throws IOException, WebApplicationException {int recordsPerRoundTrip = 100; // Number of records for every round trip to the databaseint recordPosition = 0; // Initial record position indexint recordSize = queryGeneratedUuidRecordsSize(); // Total records found for the query// Start streaming the datatry ( PrintWriter writer = new PrintWriter( new BufferedWriter( new OutputStreamWriter( os ) ) ) ) {writer.print( "{\"result\": [" );while ( recordSize > 0 ) {// Get the paged data set from the DBList<GeneratedUuidEntity> generatedUuidEntities = listAllGeneratedUuidEntities( recordPosition, recordsPerRoundTrip );for ( GeneratedUuidEntity generatedUuidEntity : generatedUuidEntities ) {if ( recordPosition > 0 ) {writer.print( "," );}// Stream the data in Json object formatwriter.print( Json.createObjectBuilder().add( "record_no", generatedUuidEntity.getRecordNo() ).add( "uuid", generatedUuidEntity.getUuid() ).add( "datetime_generated", df.format( generatedUuidEntity.getDatetimeGenerated() ) ).build().toString() );// Increase the recordPosition for every record streamedrecordPosition++;}// update the recordSize (remaining no. of records)recordSize -= recordsPerRoundTrip;}// Done!writer.print( "]}" );}}} ).build();} }

小心

請記住要調整應用程序服務器的響應連接超時值,以防止REST或Http Client拋出java.io.IOException過早的EOF異常。

測試它

要測試它是否有效,只需在表中加載567條記錄即可。 然后,讓單元測試調用端點URL,并使用以下單元測試代碼將檢索到的JSON數據保存到文件中(使用Apache HttpClient):

JPAStreamingUnitTest.java的代碼:

package com.developerscrappad;import java.io.File; import java.io.FileInputStream; import static org.junit.Assert.*;import java.nio.file.FileSystems; import java.nio.file.Files; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.UUID; import javax.json.Json; import javax.json.JsonArray; import javax.json.JsonObject; import javax.json.JsonReader; import org.apache.http.HttpEntity; import org.apache.http.client.methods.CloseableHttpResponse; import org.apache.http.client.methods.HttpGet; import org.apache.http.impl.client.CloseableHttpClient; import org.apache.http.impl.client.HttpClients; import org.junit.AfterClass; import org.junit.BeforeClass; import org.junit.Test;public class JPAStreamingUnitTest {private static final String dbDriverClassname = "com.mysql.jdbc.Driver";private static final String dbUrl = "jdbc:mysql://localhost:3306/large_data_test_db";private static final String username = "username";private static final String password = "password";private static final int numberOfRecords = 567;private static final String jsonResultOutputFilename = "testing123.json";@BeforeClasspublic static void setUpClass() {try {Class.forName( dbDriverClassname );try ( Connection conn = DriverManager.getConnection( dbUrl, username, password ) ) {String insertSQL = "insert into generated_uuids (uuid, datetime_generated) values (?, now())";try ( PreparedStatement stmt = conn.prepareStatement( insertSQL ) ) {for ( int i = 0; i < numberOfRecords; i++ ) {System.out.println( "Inserting row: " + i );stmt.setString( 1, UUID.randomUUID().toString() );stmt.executeUpdate();}}}} catch ( final Exception ex ) {ex.printStackTrace();fail( ex.getMessage() );}}@AfterClasspublic static void tearDownClass() {try {Class.forName( dbDriverClassname );try ( Connection conn = DriverManager.getConnection( dbUrl, username, password ) ) {String truncateSQL = "truncate generated_uuids";conn.createStatement().executeUpdate( truncateSQL );}new File( System.getProperty( "java.io.tmpdir" ), jsonResultOutputFilename ).delete();} catch ( final Exception ex ) {ex.printStackTrace();fail( ex.getMessage() );}}@Testpublic void testJPAStreaming() {String url = "http://localhost:8080/JPAStreaming/rest-api/generated-uuids/list-all/";try {CloseableHttpClient httpclient = HttpClients.createDefault();HttpGet httpGet = new HttpGet( url );try ( CloseableHttpResponse response1 = httpclient.execute( httpGet ) ) {System.out.println( response1.getStatusLine() );HttpEntity entity1 = response1.getEntity();Files.copy( entity1.getContent(), FileSystems.getDefault().getPath( System.getProperty( "java.io.tmpdir" ), jsonResultOutputFilename ) );}// Validatetry ( JsonReader jsonReader = Json.createReader( new FileInputStream( new File( System.getProperty( "java.io.tmpdir" ), jsonResultOutputFilename ) ) ) ) {JsonObject jsonObj = jsonReader.readObject();assertTrue( jsonObj.containsKey( "result" ) );JsonArray jsonArray = jsonObj.getJsonArray( "result" );assertEquals( numberOfRecords, jsonArray.size() );SimpleDateFormat validationDF = new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss" );for ( int i = 0; i < jsonArray.size(); i++ ) {JsonObject generatedUuidJsonObj = jsonArray.getJsonObject( i );int recordNumber = generatedUuidJsonObj.getInt( "record_no" );assertTrue( recordNumber > 0 );try {UUID.fromString( generatedUuidJsonObj.getString( "uuid" ) );} catch ( IllegalArgumentException ex ) {fail( "Invalid UUID format at record number: " + recordNumber );}try {validationDF.parse( generatedUuidJsonObj.getString( "datetime_generated" ) );} catch ( final NullPointerException | ParseException ex ) {fail( "datetime_generated field must not be null and must be of format yyyy-MM-dd HH:mm:ss" );}}}} catch ( final Exception ex ) {ex.printStackTrace();fail( ex.getMessage() );}} }

我們完成了。 感謝您的閱讀,希望對您有所幫助。

翻譯自: https://www.javacodegeeks.com/2015/07/how-to-streamserialize-jpa-result-as-jax-rs-response-for-large-data.html

jax-rs jax-ws

總結

以上是生活随笔為你收集整理的jax-rs jax-ws_如何以大数据的JAX-RS响应的形式将JPA结果流化/序列化的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

精品在线观看一区二区三区 | 视频国产在线 | 黄色高清视频在线观看 | 国产精品女人网站 | 成人资源在线 | 国产一区二区在线免费 | 日韩精品视频在线免费观看 | 欧美小视频在线观看 | 午夜av免费看 | 日韩美女一级片 | 久久精品中文字幕少妇 | 婷婷色伊人 | 国产精品毛片一区二区三区 | 中文字幕在线看视频国产中文版 | 五月婷婷丁香激情 | 最新日韩视频在线观看 | 91日韩精品视频 | 国产精品mm| jizz欧美性9 国产一区高清在线观看 | 97人人视频| 精品久久网| adc在线观看 | 精品99久久久久久 | 深爱激情五月综合 | 国产成人777777 | 黄色大全免费网站 | 五月综合激情 | 婷婷精品国产欧美精品亚洲人人爽 | 丁香婷婷深情五月亚洲 | 国产永久免费高清在线观看视频 | 韩国精品一区二区三区六区色诱 | 日韩欧美网站 | 亚洲美女在线国产 | 久久呀 | 久久久www成人免费毛片 | www成人av | 久久男人中文字幕资源站 | 国产精品欧美 | 九九热只有精品 | 欧美午夜a | 人人干在线观看 | 美女网站视频久久 | 成人黄色小说在线观看 | 婷婷综合伊人 | 国产18精品乱码免费看 | 亚洲 欧美 日韩 综合 | 色婷婷在线视频 | av黄色一级片 | 精品久久国产精品 | 久草精品视频在线看网站免费 | 午夜手机看片 | 激情网站网址 | 久久免费看av | 中文字幕国产精品 | 中文字幕在线视频一区二区三区 | 玖玖在线精品 | 欧美激情第28页 | 波多野结衣一区 | 日本精品中文字幕在线观看 | 欧美日韩在线视频一区二区 | 亚洲伊人婷婷 | 特级西西444www大胆高清无视频 | 国产成人精品一区二区三区福利 | 成年人看片网站 | 91粉色视频 | 免费成人在线观看视频 | 亚洲极色 | 深爱激情站 | 超碰免费成人 | 亚洲精品视频大全 | 四虎5151久久欧美毛片 | 91精品视频观看 | 91精品视频观看 | 日韩手机在线观看 | 天天操天天玩 | 日韩在线中文字幕 | 97成人资源站 | 精品一区久久 | 操处女逼 | 欧美精品久久久久久久 | 国产精品高清一区二区三区 | 波多在线视频 | www.激情五月.com | 91热爆在线观看 | 欧美一级淫片videoshd | 99精品免费久久久久久久久日本 | 国内精品视频免费 | 91精品在线免费观看 | 欧美网站黄色 | 99精品视频在线免费观看 | 国产五月色婷婷六月丁香视频 | 日本久久成人 | 欧美专区国产专区 | 999ZYZ玖玖资源站永久 | 精品欧美一区二区三区久久久 | 中文字幕第一页av | 99精品久久精品一区二区 | 久久综合色播五月 | 天天爽综合网 | 探花视频网站 | 在线一区av | 亚洲一二三在线 | 日韩最新中文字幕 | 精品在线一区二区三区 | av电影av在线 | 99精品视频免费观看视频 | 97香蕉久久超级碰碰高清版 | 久久免费的视频 | 午夜电影中文字幕 | 欧美韩日在线 | 探花视频免费观看 | 开心激情五月网 | 人人爽人人香蕉 | 成人黄色中文字幕 | 日韩激情小视频 | 欧美日韩在线观看视频 | 成人影片在线播放 | www夜夜操| 欧美午夜a | www.激情五月.com | 亚洲第一区精品 | 日韩高清二区 | 国产九九精品视频 | 欧美另类xxxx| 国产精品一区在线 | 啪啪肉肉污av国网站 | 日韩最新中文字幕 | 91看片淫黄大片一级在线观看 | 亚洲欧美国产日韩在线观看 | 美女视频永久黄网站免费观看国产 | 999久久国产精品免费观看网站 | 国内精品美女在线观看 | 天天色成人 | 亚洲午夜久久久久久久久 | 日本精品久久久久中文字幕5 | 久久久久国产免费免费 | 日日夜夜狠狠操 | 亚洲综合激情 | 特黄特黄的视频 | 久久精品视频网址 | aaa免费毛片 | 国产精品日韩在线 | 亚洲视频网站在线观看 | 日韩91在线 | 久久99亚洲精品久久 | 国产 亚洲 欧美 在线 | 国产精品久久99综合免费观看尤物 | 日韩国产精品久久久久久亚洲 | 美女久久久久久久久久 | 免费在线观看国产精品 | 色com网| 日韩三级视频在线观看 | 狠狠色丁香婷婷 | 伊人天天 | 韩国精品一区二区三区六区色诱 | 欧美一二区视频 | 黄色中文字幕在线 | 欧美精品资源 | www日韩在线| 国产成人免费精品 | 亚洲精品免费在线观看 | 久久99精品国产 | 久久综合久久综合久久综合 | 在线成人一区 | 婷婷精品进入 | 久久久99国产精品免费 | 香蕉视频网站在线观看 | 亚洲精品视频偷拍 | 在线黄色免费 | 六月天色婷婷 | 婷婷99| 97精品久久人人爽人人爽 | 日韩在线观看影院 | 91九色porn在线资源 | 久久不射电影院 | 久久久视频在线 | 久久久美女 | 国产日韩欧美在线影视 | 国产成人精品免高潮在线观看 | 久久艹久久| 欧美日韩免费在线观看视频 | a精品视频 | 天天弄天天操 | 欧美另类高潮 | 久久一视频 | 欧美一区二区三区在线播放 | 99r在线观看| 欧美性猛片 | 麻豆国产在线播放 | 久久久69 | 色av资源网| 国产高清成人在线 | 日韩欧美在线一区二区 | 91视频高清完整版 | 天天激情综合 | 91丨九色丨高潮 | 91免费网址 | 韩国av一区二区三区 | 国产精品免费在线播放 | 日本狠狠干 | 免费下载高清毛片 | 片黄色毛片黄色毛片 | 91精品免费 | 色资源二区在线视频 | www色com| www好男人 | 91九色porny在线 | 亚洲无吗视频在线 | 国产成人高清在线 | av福利网址导航大全 | 国产精品毛片久久 | www.狠狠色.com| 国产91小视频 | av免费在线观看1 | 久久免费av电影 | 国产成人高清av | 久久看片网 | 亚洲综合色视频在线观看 | 日韩免费电影一区二区三区 | www.xxxx变态.com | 99在线观看免费视频精品观看 | 在线观看成人福利 | 国产最新精品视频 | 91精品小视频 | 久久激情久久 | 六月激情婷婷 | 99久久99久久精品国产片 | 日韩美一区二区三区 | 日日干天天爽 | 日韩和的一区二在线 | 手机av在线网站 | 在线看片91 | 精品福利视频在线 | 亚洲视频999| 国产精品永久久久久久久久久 | 国产免费又爽又刺激在线观看 | 国产精品99久久久久久久久 | 日日夜夜网站 | 日韩xxxbbb | 男女精品久久 | 亚洲第一av在线 | 亚洲无在线 | 婷婷久久亚洲 | 99热在线网站 | 精品国产欧美一区二区 | 中文资源在线官网 | www免费黄色 | 麻豆成人网 | 日操操 | 激情网站 | 久久有精品 | 国产精品国产亚洲精品看不卡 | 亚洲精品tv久久久久久久久久 | 久久av不卡| 国产日韩在线观看一区 | 亚洲少妇天堂 | 高清不卡毛片 | 欧美一级视频在线观看 | 国产伦理一区二区三区 | 天天草天天干天天 | 久久久久久久久网站 | 国产人成一区二区三区影院 | 偷拍福利视频一区二区三区 | 中文在线免费观看 | 免费黄色在线网站 | 婷婷丁香久久五月婷婷 | 91色在线观看 | 久久久91精品国产一区二区精品 | 日韩av午夜| 久久免费的视频 | 99热亚洲精品 | 久久任你操 | 欧美黑人巨大xxxxx | 亚洲视频 一区 | 免费av网址在线观看 | 国产精品免费在线播放 | 精品国产亚洲日本 | 女女av在线 | 国产亚洲欧美一区 | 悠悠av资源片 | 狠狠狠狠狠狠干 | 亚洲精品国产精品久久99热 | 国产淫片免费看 | 国产精品久久久区三区天天噜 | 韩国av电影在线观看 | 国产手机av | 精品亚洲欧美无人区乱码 | 91网在线看 | 天堂av官网 | 久久国色夜色精品国产 | 亚洲成人黄色在线 | 人九九精品 | 天天爱天天操 | 欧美一区二区在线看 | 精品一区二区三区四区在线 | 在线观看91精品国产网站 | 国产又粗又猛又色又黄网站 | 久久99精品久久只有精品 | 麻花豆传媒一二三产区 | 久久中文欧美 | 欧美日韩国产精品一区 | av+在线播放在线播放 | 日本电影久久 | 欧美日韩不卡在线视频 | 一级性视频 | 久久久亚洲麻豆日韩精品一区三区 | 国产91免费观看 | 黄网站免费大全入口 | 亚洲第二色 | 亚洲区视频在线观看 | 天天干夜夜夜 | 中文字幕有码在线 | 久久涩涩网站 | 亚洲精品乱码久久久久久按摩 | 天天爽天天爽天天爽 | 国内精品久久久久影院日本资源 | 五月婷婷久 | 视频一区在线免费观看 | 国产精品对白一区二区三区 | 成人久久视频 | 狠狠干综合 | 久久久久国产精品视频 | 人人干网站 | 高清视频一区 | 视频国产一区二区三区 | 99精品在线观看 | 国产美女视频网站 | 久久久久久久99精品免费观看 | 国产视频一二区 | 国产精品久久久久久久久毛片 | 中文字幕在线看视频国产 | 午夜精品久久久久久久久久久久久久 | 久久最新视频 | 欧美亚洲一区二区在线 | 色噜噜日韩精品一区二区三区视频 | 国产不卡一区二区视频 | 成人影片在线播放 | 一级黄色a视频 | 毛片永久免费 | 在线观看日本高清mv视频 | 国产精品久久婷婷六月丁香 | 中文字幕av全部资源www中文字幕在线观看 | 天天干天天在线 | 国产成人在线免费观看 | 91麻豆看国产在线紧急地址 | 国产午夜精品一区二区三区在线观看 | 国产高清免费观看 | 亚洲h在线播放在线观看h | 日韩aⅴ视频 | 日本在线观看中文字幕无线观看 | 人人舔人人插 | 国产精品女人久久久久久 | 国产不卡免费视频 | 成人午夜电影在线观看 | 亚洲男人天堂2018 | av免费在线网站 | 亚洲日韩中文字幕在线播放 | 国产黄色网| 久久久久久久久久电影 | 黄色a在线观看 | 中文字幕久久网 | 成av在线 | 久久久久这里只有精品 | 99久e精品热线免费 99国产精品久久久久久久久久 | 五月婷婷激情六月 | 久草精品视频在线看网站免费 | 久久视频在线免费观看 | 久久午夜网 | 日韩一区二区三区在线观看 | 96在线| 人人爽人人爽人人 | 久久看看 | 在线观看日韩中文字幕 | 久久免费试看 | 91免费观看视频网站 | 欧美精品在线一区 | 亚洲精品美女久久 | 欧产日产国产69 | 日韩欧美视频一区二区 | 亚洲精品在线视频观看 | 久久人人爽人人爽人人 | 日韩精品一区二区三区免费观看视频 | 中文字幕资源站 | 精品国产一区二区三区男人吃奶 | 黄色国产高清 | 911国产 | 女人18毛片90分钟 | 在线观看视频在线 | 色999视频| 欧美一区在线看 | 全久久久久久久久久久电影 | 欧美99久久| 国产69精品久久久久久久久久 | 日本韩国精品一区二区在线观看 | 伊人久久电影网 | 免费看av片网站 | 毛片3 | 丁香花中文字幕 | 久久久999 | 国产91精品一区二区绿帽 | 成人国产网址 | 国产91在线免费视频 | 综合网五月天 | 麻豆一区在线观看 | 黄色亚洲在线 | 亚洲三级视频 | 99视频免费看 | 久久97久久 | 色99视频| 国产麻豆精品一区 | 亚洲一二三区精品 | 五月婷av| 手机av永久免费 | 不卡的av中文字幕 | 色婷婷综合久久久久中文字幕1 | 国产99久久久国产精品免费二区 | 探花在线观看 | 久久伊人免费视频 | 日韩理论片在线观看 | 一级黄视频 | 69视频永久免费观看 | 欧美午夜性生活 | 国产一二区视频 | 中文字幕欧美三区 | 啪啪免费观看网站 | 久久亚洲福利视频 | 日韩丝袜在线观看 | 国产 精品 资源 | 欧美福利视频一区 | 国产玖玖精品视频 | 在线日韩视频 | 天天爽网站 | 中文字幕色综合网 | 91爱爱网址 | 精品美女在线观看 | 亚洲国内在线 | 欧美福利视频 | 特黄特黄的视频 | 激情小说 五月 | 天天干天天操天天射 | 五月婷婷中文字幕 | 天天射天天干天天 | 婷婷精品在线视频 | 成年人在线免费视频观看 | 高潮久久久 | 国产999视频在线观看 | 欧美国产日韩久久 | 亚洲伊人第一页 | 在线观看色网 | 激情欧美丁香 | 免费视频黄 | 免费三级影片 | 天天艹天天爽 | 91精品国产99久久久久久红楼 | 精品国产精品一区二区夜夜嗨 | 久久精品99久久 | 亚洲日本国产 | 午夜婷婷综合 | 黄色三级久久 | 9999激情| 99在线看 | 亚洲精品在线免费看 | 亚洲高清视频在线观看免费 | 国产午夜三级 | 亚洲1级片 | 人人射人人插 | 国产精品6999成人免费视频 | 欧美日韩高清不卡 | 久久久影院 | 在线免费观看黄色 | 久久精品成人热国产成 | 亚洲欧美日韩精品久久奇米一区 | 最近中文字幕在线中文高清版 | 亚洲美女在线国产 | 国产一区视频在线 | 亚洲区另类春色综合小说校园片 | 精品久久久久久亚洲综合网站 | 9在线观看免费高清完整版 玖玖爱免费视频 | 国产一级性生活 | 国产又粗又猛又黄又爽视频 | 日日干夜夜骑 | 国产色拍 | 亚一亚二国产专区 | www.夜夜爱 | 日韩免费在线观看视频 | 国产又粗又硬又爽视频 | a在线v| 午夜精品久久久久久中宇69 | 亚洲欧洲成人精品av97 | 免费观看9x视频网站在线观看 | 成人精品视频久久久久 | 日韩欧美一区二区三区免费观看 | 91久久偷偷做嫩草影院 | 亚洲自拍偷拍色图 | 91天堂素人约啪 | 久久国产精品久久w女人spa | 久久99精品久久久久久三级 | 免费看的视频 | 91久久在线观看 | 久久久精品影视 | 人人看人人爱 | 久久精品91久久久久久再现 | 九九九热精品 | 中文字幕电影网 | 日韩精品一区二区免费 | 久久国产午夜精品理论片最新版本 | 色吊丝在线永久观看最新版本 | 一级黄色片在线播放 | 中文字幕 国产视频 | 国产偷v国产偷∨精品视频 在线草 | 国产成人61精品免费看片 | 色资源网免费观看视频 | 国产在线观看中文字幕 | 日本韩国精品在线 | 中文字幕一区二区三区久久蜜桃 | 欧美a√在线 | 99性视频| 免费毛片一区二区三区久久久 | 一级片视频免费观看 | 在线日本看片免费人成视久网 | 亚洲激情av | 性色av一区二区三区在线观看 | 狠狠色丁香婷婷综合久小说久 | 日韩在线观看中文 | 美女精品在线 | 9999毛片 | 91精品视频网站 | 在线中文字幕视频 | 毛片一区二区 | 91插插影库| 黄色成人在线观看 | 久久久久久久久久久高潮一区二区 | 国产福利小视频在线 | 亚洲日日夜夜 | 久久美女高清视频 | 国产中文在线视频 | 成人久久精品 | 人人爽人人澡人人添人人人人 | 超碰在线97观看 | 在线免费91 | 国产色爽| 国产美女无遮挡永久免费 | 91在线视频播放 | 日韩精选在线观看 | 天天操比 | 国产精品一区二区免费视频 | 成人午夜影院 | 日韩电影在线观看中文字幕 | 成人小电影在线看 | 久久一视频 | 日本性生活一级片 | 久久精品视频一 | 婷婷视频| 婷婷六月天在线 | 久热av| 玖玖在线精品 | 精品国产乱码久久久久久浪潮 | 久久99久久99精品中文字幕 | 怡红院久久 | 深爱激情av | 国产91精品一区二区麻豆网站 | 97超碰超碰久久福利超碰 | 波多野结衣小视频 | 久久6精品 | 亚洲精品在线网站 | 国产精品精| 99精品在线视频观看 | 永久免费av在线播放 | 激情五月婷婷综合 | 9在线观看免费高清完整版在线观看明 | 天天色天天艹 | 成人毛片在线观看 | 欧美一区,二区 | 亚洲电影一级黄 | 精品视频一区在线 | www.色就是色 | 国产亚洲精品女人久久久久久 | 女人久久久久 | 激情视频一区二区 | 国产九九九视频 | 亚洲综合成人专区片 | 久久免费国产电影 | 最近中文字幕在线中文高清版 | 国产v视频 | 亚洲码国产日韩欧美高潮在线播放 | 91精品国产九九九久久久亚洲 | 国产人免费人成免费视频 | 美女免费黄视频网站 | 99视频国产在线 | 婷婷干五月 | 国产一级二级av | 91porny九色91啦中文 | 国产成人在线精品 | 超碰日韩| 日韩欧美99 | 精品福利片 | 国产成人精品久久久久 | 亚洲九九| 黄色网www | 亚洲一区二区三区精品在线观看 | 九九九热精品免费视频观看 | 久久成人高清 | 人人射人人插 | 99成人免费视频 | 99爱国产精品 | 中文永久免费观看 | 免费久久片 | 91九色成人蝌蚪首页 | 国产精品一区二区三区视频免费 | 成全免费观看视频 | 天天爽天天爽夜夜爽 | 在线看成人av | 中文乱幕日产无线码1区 | 日韩国产精品毛片 | 亚洲成人动漫在线观看 | 久久激情视频 久久 | 亚洲女同ⅹxx女同tv | 黄色国产区 | 欧美精品中文字幕亚洲专区 | 日韩特黄av | 狠狠色综合网站久久久久久久 | 欧美一二在线 | 亚州精品一二三区 | 久久爽久久爽久久av东京爽 | 日韩高清精品一区二区 | 日韩美女一级片 | 亚洲一区天堂 | 日韩国产欧美视频 | 啪啪免费试看 | 中文字幕在线不卡国产视频 | 色丁香久久 | av中文字幕免费在线观看 | 91成人精品一区在线播放69 | 综合久久久久久久 | 免费福利在线播放 | 国产欧美日韩一区 | 色黄www小说| 欧美肥妇free| av资源免费看 | 国产视频一区精品 | 国产色中涩 | 亚洲成人精品影院 | 丁香网五月天 | 狠狠狠狠狠操 | 91看片淫黄大片一级在线观看 | 日韩欧美99| 欧美一级日韩三级 | 久久久噜噜噜久久久 | 精品一二区 | 国产在线不卡视频 | 亚洲视频免费在线看 | 99精品在这里 | 国产精品网红福利 | 成人国产精品av | 五月婷婷丁香激情 | 国产精品永久久久久久久久久 | 伊人婷婷久久 | 在线日韩av | 久草在线一免费新视频 | 四虎影视成人永久免费观看视频 | www.久久久精品 | 久久a v电影 | 黄a网站| 99视频这里只有 | 97电影在线看视频 | 91在线免费观看网站 | 国产成人亚洲在线观看 | 中文字幕精品三区 | 中文字幕欧美日韩va免费视频 | 日韩久久激情 | 在线免费黄色av | 日韩在线观看你懂的 | 黄色免费观看网址 | 麻豆久久精品 | 天天搞天天干天天色 | 国产在线国偷精品产拍免费yy | 亚洲一二区精品 | 久久精品视频播放 | 96av视频 | 九九99| 天天爽天天爽天天爽 | 国产欧美日韩一区 | 九九九视频在线 | 激情六月婷婷久久 | 免费av小说| 亚洲黄色网络 | 亚洲va天堂va欧美ⅴa在线 | 久久精品视频免费 | 日韩精品一区在线观看 | 黄色免费大全 | 国产首页| 日本精品视频在线 | 亚洲国产精品久久久久久 | 国产一区二区在线观看视频 | 天天操夜夜爱 | 91亚洲精 | 丁香六月婷婷综合 | 五月婷婷六月综合 | 国产成人不卡 | 日日色综合 | 日韩videos| 国产日韩三级 | 亚洲理论片 | 久久久久久久久久网 | 激情综合啪啪 | 亚洲精品高清一区二区三区四区 | 国产精品中文 | 欧美日韩精品在线免费观看 | 超碰个人在线 | 91麻豆精品国产91久久久无需广告 | 久久久午夜剧场 | 亚洲国产成人在线观看 | 日韩手机视频 | 久久国产精品偷 | 国产又粗又猛又爽又黄的视频免费 | 麻豆视频免费在线播放 | 欧美激情精品久久久久久 | 欧美精品免费在线 | 国产香蕉97碰碰碰视频在线观看 | 91高清视频在线 | 国产一区二区三区高清播放 | 91黄站| 日韩激情第一页 | 婷婷六月色 | 免费av 在线 | 伊人久久影视 | 午夜久久久久久久久久久 | 成人av免费在线观看 | 91久久精品一区二区二区 | 亚洲人成在线电影 | www.xxx.性狂虐 | 免费能看的黄色片 | 五月天婷婷免费视频 | 国产黄色精品网站 | 中文字幕在线网 | 免费看污污视频的网站 | 特级xxxxx欧美 | 免费色黄 | 日韩理论电影在线观看 | 成人免费观看完整版电影 | 在线观看香蕉视频 | 伊人夜夜 | 97av在线视频免费播放 | 欧美最爽乱淫视频播放 | 精品中文字幕在线 | 美女久久精品 | www黄免费 | 夜夜爽天天爽 | 91探花国产综合在线精品 | 国产精品久久久久久久久久久久午夜 | www.91av在线 | 香蕉在线播放 | 欧美男男激情videos | 狠狠躁日日躁狂躁夜夜躁av | 91成熟丰满女人少妇 | 99久久精品国产亚洲 | 国产精品av电影 | 精品久久久网 | 午夜精品久久久久久久99水蜜桃 | 国产精品久久久久久久久软件 | 色综合www | 国产高清成人av | 成 人 黄 色视频免费播放 | 午夜视频福利 | 亚洲美女精品区人人人人 | 中文字幕成人 | 天天操天天干天天爽 | 波多野结衣视频网址 | 91av欧美 | av国产在线观看 | 免费国产在线观看 | 国产精品 美女 | 国产黄视频在线观看 | 制服丝袜一区二区 | 国产欧美中文字幕 | 亚洲精品在线免费观看视频 | 国产精品麻豆91 | 亚洲成人影音 | 亚洲精品午夜一区人人爽 | 免费在线观看黄 | 在线观看视频一区二区三区 | 亚洲综合在线一区二区三区 | 国产精品欧美一区二区三区不卡 | 国产亚洲成av人片在线观看桃 | 亚洲另类视频在线 | 超碰在线最新网址 | 日韩国产精品一区 | 免费亚洲精品视频 | 狠狠操综合 | 蜜臀久久99精品久久久久久网站 | 欧美日韩国产综合网 | 岛国av在线不卡 | 久久欧洲视频 | 国产成人精品一区二区三区在线观看 | 免费在线观看av | 久久久黄色免费网站 | 天天干天天射天天插 | 婷婷六月久久 | 激情欧美一区二区三区 | 亚洲黄a| 久草在线播放视频 | 国产免费黄色 | 三级在线视频观看 | 亚洲永久精品国产 | 九九免费在线观看视频 | 国内精品久久久久久久97牛牛 | 中文字幕电影在线 | 九色最新网址 | 亚洲精品美女久久 | 狠狠干狠狠艹 | 色偷偷97 | 国产亚洲精品美女 | 日韩精品免费一线在线观看 | 亚洲免费高清视频 | 国产视频精品久久 | 日韩有码专区 | 色一色在线 | 欧美日韩观看 | 久久呀 | 黄色在线小网站 | 丁香五月网久久综合 | 97天堂| 久草视频免费在线播放 | 97精品伊人 | 色鬼综合网 | av黄色免费看 | 国产精品久久久久永久免费观看 | 在线精品观看国产 | 一区三区在线欧 | 我爱av激情网 | 婷婷丁香激情五月 | 久久黄视频 | 91国内在线| 天天操天天干天天操天天干 | 国内精品中文字幕 | 999久久久久| 在线看污网站 | 中文字幕乱码电影 | 97精品国自产拍在线观看 | 国产九色91 | 欧美日韩国产成人 | 丁香五月亚洲综合在线 | 蜜臀av夜夜澡人人爽人人 | 国产精品久久久久久久免费大片 | 欧美精品少妇xxxxx喷水 | 国内精品久久久久影院男同志 | 美女久久网站 | 欧美日韩xxx | 91色亚洲| 欧美一区二区三区激情视频 | 2024国产精品视频 | 九九热99视频 | 中文字幕观看视频 | 91九色蝌蚪视频在线 | 国产日韩在线观看一区 | 美州a亚洲一视本频v色道 | 丁香花五月 | 日本h在线播放 | 激情五月视频 | 日本午夜在线观看 | 999久久久久| 色婷婷久久久 | 色婷婷综合久久久 | 日韩中午字幕 | 久久久国产精品一区二区三区 | 天天爽人人爽夜夜爽 | 天天激情综合网 | 欧美日韩不卡在线 | 久久精品99久久久久久2456 | 久久国产精品免费观看 | 免费看一级特黄a大片 | 免费看日韩 | 国产成人免费在线观看 | 99re国产视频 | 精品自拍sae8—视频 | 丝袜av一区 | 日韩午夜视频在线观看 | 粉嫩av一区二区三区四区五区 | 国产成人精品一区二区三区免费 | 国产精品九九九九九九 | 黄污视频网站 | 成人h在线观看 | 成 人 a v天堂| 国产精品久久99综合免费观看尤物 | 在线观看中文字幕 | 欧美亚洲一区二区在线 | 视频国产在线 | 四虎在线免费观看 | 91在线免费播放视频 | 99国产一区二区三精品乱码 | 国产精品第一页在线观看 | 极品久久久久 | 久久免费a | 欧美成人va | 日本久久综合视频 | 日韩免费小视频 | 粉嫩aⅴ一区二区三区 | 夜夜高潮夜夜爽国产伦精品 | 国产精品久久久久一区 | 一级免费黄视频 | 精品极品在线 | 免费午夜网站 | 亚洲国产成人av网 | 国产精品美女久久久免费 | 天天色天天干天天色 | zzijzzij日本成熟少妇 | 在线成人国产 | 国产精品男女视频 | 午夜国产一区二区 | 特黄色大片 | av网站在线观看播放 | 粉嫩av一区二区三区入口 | 一区二区三区不卡在线 | 国产福利午夜 | 亚洲综合欧美精品电影 | 精品国产乱码久久久久久1区2匹 | a视频在线观看免费 | 黄色一级在线观看 | 欧美久久久久久久久久久 | 97精品在线 | 久草在线视频首页 | 操操操人人人 | 国产一区二区在线视频观看 | 国产小视频在线播放 | 久久婷五月| 婷婷色婷婷 | 免费在线激情电影 | 九九热免费在线视频 | 亚洲精区二区三区四区麻豆 | 日韩三级久久 | 在线观看一级视频 | 日韩视频免费播放 | 亚洲草视频 | 亚洲韩国一区二区三区 | 欧美aa在线 | 91在线视频免费91 | 亚洲91中文字幕无线码三区 | 天天操天天操天天干 | 亚洲 精品在线视频 | 国产小视频你懂的 | 色视频网址 | 日韩最新中文字幕 | 中文字幕乱码在线播放 | 免费 在线 中文 日本 | 久草久热| 日韩 在线 | 国产精品99免费看 | 欧美一二三区在线观看 | 国内精品久久久 | 国产视频在线观看一区 | 黄色av播放 | 亚洲专区一二三 | 二区三区av | 国产精品一区免费在线观看 | 精品久久久99 | 999久久久免费视频 午夜国产在线观看 | 香蕉视频日本 | 三三级黄色片之日韩 | 亚洲视频在线观看免费 | 国产精品爽爽爽 | 免费热情视频 | 中文字幕美女免费在线 | 日本99热| 在线免费观看国产视频 | wwwwww国产| 国产一级一级国产 | 麻豆精品在线 | 狠狠狠色丁香综合久久天下网 | 99久久精品免费看国产免费软件 | 99热都是精品| 精品久久久久久久久久久久 | 深夜视频久久 | 亚洲精品国产精品久久99 | 久久国产精品二国产精品中国洋人 | 超碰公开在线 | 女人18毛片a级毛片一区二区 | 色综合激情久久 | av导航福利| 天天艹 | 久久久99国产精品免费 | 在线成人av | 激情xxxx| 韩日精品在线观看 | 久久手机免费观看 | 国产精品一区在线观看你懂的 | 狠狠色伊人亚洲综合网站色 | 美女黄视频免费看 | 日韩在线观 | 久久精品永久免费 | 天天爱天天射 | 麻豆视频在线观看免费 | 日韩一区二区三区观看 | 色婷婷狠狠五月综合天色拍 | 黄p在线播放 | 国产精品嫩草69影院 | 综合在线亚洲 | 亚洲国产精品小视频 | 日韩午夜小视频 |