黄a在线观看-黄a在线-黄a大片-黄色片在线看-黄色毛片免费-黄色大片网站

您的位置:首頁技術文章
文章詳情頁

解析Android框架之OkHttp3源碼

瀏覽:16日期:2022-09-18 10:56:39
目錄OkHttp流程圖OkHttp基本使用OkHttp源碼分析OkHttp流程圖

解析Android框架之OkHttp3源碼

OkHttp基本使用

gradle依賴

implementation ’com.squareup.okhttp3:okhttp:3.11.0’

implementation ’com.squareup.okio:okio:1.15.0’

/** *這里拿get請求來 * 異步的get請求 */ public void okhttpAsyn() {//設置超時的時間OkHttpClient.Builder builder = new OkHttpClient.Builder().connectTimeout(15, TimeUnit.SECONDS).writeTimeout(20, TimeUnit.SECONDS).readTimeout(20, TimeUnit.SECONDS);OkHttpClient okHttpClient = builder.build();Request request = new Request.Builder().get() //設置請求模式.url('https://www.baidu.com/').build();Call call = okHttpClient.newCall(request);call.enqueue(new Callback() { @Override public void onFailure(Call call, IOException e) {Log.d('MainActivity', '-----------onFailure-----------'); } @Override public void onResponse(Call call, Response response) throws IOException {Log.d('MainActivity', '----onResponse----' + response.body().toString());runOnUiThread(new Runnable() { @Override public void run() {Toast.makeText(MainActivity.this, '請求成功', Toast.LENGTH_LONG).show(); }}); }}); }OkHttp源碼分析

從OkHttp的基本使用中,我們看到,通過okHttpClient.newCall()方法,拿到這個call對象,我們看看newCall是怎么走的

/** * Prepares the {@code request} to be executed at some point in the future. */ @Override public Call newCall(Request request) { return RealCall.newRealCall(this, request, false /* for web socket */); } static RealCall newRealCall(OkHttpClient client, Request originalRequest, boolean forWebSocket) { // Safely publish the Call instance to the EventListener. RealCall call = new RealCall(client, originalRequest, forWebSocket); call.eventListener = client.eventListenerFactory().create(call); return call; }

從這里的源碼知道,okHttpClient.newCall()實際上返回的是RealCall對象,而call.enqueue(),實際上是調用的了RealCall中的enqueue()方法,我們看看enqueue()方法方法怎么走。

@Override public void enqueue(Callback responseCallback) { synchronized (this) { if (executed) throw new IllegalStateException('Already Executed'); executed = true; } captureCallStackTrace(); eventListener.callStart(this); client.dispatcher().enqueue(new AsyncCall(responseCallback)); }

可以看到client.dispatcher().enqueue(new AsyncCall(responseCallback));這句代碼,也就是說,最終是有的請求是有dispatcher來完成,我們看看dispatcher。

/* * Copyright (C) 2013 Square, Inc. * * Licensed under the Apache License, Version 2.0 (the 'License'); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an 'AS IS' BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */package okhttp3;import java.util.ArrayDeque;import java.util.ArrayList;import java.util.Collections;import java.util.Deque;import java.util.Iterator;import java.util.List;import java.util.concurrent.ExecutorService;import java.util.concurrent.SynchronousQueue;import java.util.concurrent.ThreadPoolExecutor;import java.util.concurrent.TimeUnit;import javax.annotation.Nullable;import okhttp3.RealCall.AsyncCall;import okhttp3.internal.Util;/** * Policy on when async requests are executed. * * <p>Each dispatcher uses an {@link ExecutorService} to run calls internally. If you supply your * own executor, it should be able to run {@linkplain #getMaxRequests the configured maximum} number * of calls concurrently. */public final class Dispatcher { //最大請求的并發數 private int maxRequests = 64; //每個主機最大請求數 private int maxRequestsPerHost = 5; private @Nullable Runnable idleCallback; /** 消費線程池 */ private @Nullable ExecutorService executorService; /** 準備運行的異步請求隊列 */ private final Deque<AsyncCall> readyAsyncCalls = new ArrayDeque<>(); /** 正在運行的異步請求隊列 */ private final Deque<AsyncCall> runningAsyncCalls = new ArrayDeque<>(); /** 正在運行的同步請求隊列 */ private final Deque<RealCall> runningSyncCalls = new ArrayDeque<>(); /** 構造方法 */ public Dispatcher(ExecutorService executorService) { this.executorService = executorService; } public Dispatcher() { } public synchronized ExecutorService executorService() { if (executorService == null) { executorService = new ThreadPoolExecutor(0, Integer.MAX_VALUE, 60, TimeUnit.SECONDS, new SynchronousQueue<Runnable>(), Util.threadFactory('OkHttp Dispatcher', false)); } return executorService; } /** * *設置并發執行最大的請求數量 * <p>If more than {@code maxRequests} requests are in flight when this is invoked, those requests * will remain in flight. */ public synchronized void setMaxRequests(int maxRequests) { if (maxRequests < 1) { throw new IllegalArgumentException('max < 1: ' + maxRequests); } this.maxRequests = maxRequests; promoteCalls(); } //獲取到最大請求的數量 public synchronized int getMaxRequests() { return maxRequests; } /** * 設置每個主機并發執行的請求的最大數量 * <p>If more than {@code maxRequestsPerHost} requests are in flight when this is invoked, those * requests will remain in flight. * * <p>WebSocket connections to hosts <b>do not</b> count against this limit. */ public synchronized void setMaxRequestsPerHost(int maxRequestsPerHost) { if (maxRequestsPerHost < 1) { throw new IllegalArgumentException('max < 1: ' + maxRequestsPerHost); } this.maxRequestsPerHost = maxRequestsPerHost; promoteCalls(); } //獲取每個主機最大并發數量 public synchronized int getMaxRequestsPerHost() { return maxRequestsPerHost; } /** * Set a callback to be invoked each time the dispatcher becomes idle (when the number of running * calls returns to zero). * * <p>Note: The time at which a {@linkplain Call call} is considered idle is different depending * on whether it was run {@linkplain Call#enqueue(Callback) asynchronously} or * {@linkplain Call#execute() synchronously}. Asynchronous calls become idle after the * {@link Callback#onResponse onResponse} or {@link Callback#onFailure onFailure} callback has * returned. Synchronous calls become idle once {@link Call#execute() execute()} returns. This * means that if you are doing synchronous calls the network layer will not truly be idle until * every returned {@link Response} has been closed. */ public synchronized void setIdleCallback(@Nullable Runnable idleCallback) { this.idleCallback = idleCallback; } synchronized void enqueue(AsyncCall call) { if (runningAsyncCalls.size() < maxRequests && runningCallsForHost(call) < maxRequestsPerHost) { runningAsyncCalls.add(call); executorService().execute(call); } else { readyAsyncCalls.add(call); } } /** * Cancel all calls currently enqueued or executing. Includes calls executed both {@linkplain * Call#execute() synchronously} and {@linkplain Call#enqueue asynchronously}. */ public synchronized void cancelAll() { for (AsyncCall call : readyAsyncCalls) { call.get().cancel(); } for (AsyncCall call : runningAsyncCalls) { call.get().cancel(); } for (RealCall call : runningSyncCalls) { call.cancel(); } } private void promoteCalls() { if (runningAsyncCalls.size() >= maxRequests) return; // Already running max capacity. if (readyAsyncCalls.isEmpty()) return; // No ready calls to promote. for (Iterator<AsyncCall> i = readyAsyncCalls.iterator(); i.hasNext(); ) { AsyncCall call = i.next(); if (runningCallsForHost(call) < maxRequestsPerHost) {i.remove();runningAsyncCalls.add(call);executorService().execute(call); } if (runningAsyncCalls.size() >= maxRequests) return; // Reached max capacity. } } //----------------省略若干代碼-----------------------}

我們來找到這段代碼

synchronized void enqueue(AsyncCall call) { if (runningAsyncCalls.size() < maxRequests && runningCallsForHost(call) < maxRequestsPerHost) { runningAsyncCalls.add(call); executorService().execute(call); } else { readyAsyncCalls.add(call); } }

當正在運行的異步請求隊列中的數量小于64并且正在運行的請求主機數小于5時則把請求加載到runningAsyncCalls中并在線程池中執行,否則就再入到readyAsyncCalls中進行緩存等待。而runningAsyncCalls這個請求隊列存放的就是AsyncCall對象,而這個AsyncCall就是RealCall的內部類,也就是說executorService().execute(call);實際上走的是RealCall類中的execute()方法.

@Override protected void execute() { boolean signalledCallback = false; try {Response response = getResponseWithInterceptorChain();if (retryAndFollowUpInterceptor.isCanceled()) { signalledCallback = true; responseCallback.onFailure(RealCall.this, new IOException('Canceled'));} else { signalledCallback = true; responseCallback.onResponse(RealCall.this, response);} } catch (IOException e) {if (signalledCallback) { // Do not signal the callback twice! Platform.get().log(INFO, 'Callback failure for ' + toLoggableString(), e);} else { eventListener.callFailed(RealCall.this, e); responseCallback.onFailure(RealCall.this, e);} } finally {client.dispatcher().finished(this); } }

這部分的代碼,相信很多人都能夠看的明白,無非就是一些成功,失敗的回調,這段代碼,最重要的是esponse response = getResponseWithInterceptorChain();和client.dispatcher().finished(this);我們先來看看client.dispatcher().finished(this);這句代碼是怎么執行的。

/** Used by {@code AsyncCall#run} to signal completion. */ void finished(AsyncCall call) { finished(runningAsyncCalls, call, true); } /** Used by {@code Call#execute} to signal completion. */ void finished(RealCall call) { finished(runningSyncCalls, call, false); } private <T> void finished(Deque<T> calls, T call, boolean promoteCalls) { int runningCallsCount; Runnable idleCallback; synchronized (this) { if (!calls.remove(call)) throw new AssertionError('Call wasn’t in-flight!'); if (promoteCalls) promoteCalls(); runningCallsCount = runningCallsCount(); idleCallback = this.idleCallback; } if (runningCallsCount == 0 && idleCallback != null) { idleCallback.run(); } }private void promoteCalls() { if (runningAsyncCalls.size() >= maxRequests) return; // Already running max capacity. if (readyAsyncCalls.isEmpty()) return; // No ready calls to promote. for (Iterator<AsyncCall> i = readyAsyncCalls.iterator(); i.hasNext(); ) { AsyncCall call = i.next(); if (runningCallsForHost(call) < maxRequestsPerHost) {i.remove();runningAsyncCalls.add(call);executorService().execute(call); } if (runningAsyncCalls.size() >= maxRequests) return; // Reached max capacity. } }

由于client.dispatcher().finished(this);這句代碼是放到finally中執行的,所以無論什么情況,都會執行上面的promoteCalls()方法,而從promoteCalls()方法中可以看出通過遍歷來獲取到下一個請求從而執行下一個網絡請求。

回過頭來,我們看看這一句代碼Response response = getResponseWithInterceptorChain(); 通過getResponseWithInterceptorChain();來獲取到response,然后回調返回。很明顯getResponseWithInterceptorChain()這句代碼里面進行了網絡請求。我們看看是怎么執行的。

Response getResponseWithInterceptorChain() throws IOException { // Build a full stack of interceptors. List<Interceptor> interceptors = new ArrayList<>(); interceptors.addAll(client.interceptors()); interceptors.add(retryAndFollowUpInterceptor); interceptors.add(new BridgeInterceptor(client.cookieJar())); interceptors.add(new CacheInterceptor(client.internalCache())); interceptors.add(new ConnectInterceptor(client)); if (!forWebSocket) { interceptors.addAll(client.networkInterceptors()); } interceptors.add(new CallServerInterceptor(forWebSocket)); Interceptor.Chain chain = new RealInterceptorChain(interceptors, null, null, null, 0,originalRequest, this, eventListener, client.connectTimeoutMillis(),client.readTimeoutMillis(), client.writeTimeoutMillis()); return chain.proceed(originalRequest); }}

從上面代碼可以知道,緩存,網絡請求,都封裝成攔截器的形式。攔截器主要用來觀察,修改以及可能短路的請求輸出和響應的回來。最后return chain.proceed,而chain是通過new RealInterceptorChain來獲取到的,我們來看看RealInterceptorChain對象,然后找到proceed()方法。

public Response proceed(Request request, StreamAllocation streamAllocation, HttpCodec httpCodec, RealConnection connection) throws IOException { if (index >= interceptors.size()) throw new AssertionError(); calls++; // If we already have a stream, confirm that the incoming request will use it. if (this.httpCodec != null && !this.connection.supportsUrl(request.url())) { throw new IllegalStateException('network interceptor ' + interceptors.get(index - 1) + ' must retain the same host and port'); } // If we already have a stream, confirm that this is the only call to chain.proceed(). if (this.httpCodec != null && calls > 1) { throw new IllegalStateException('network interceptor ' + interceptors.get(index - 1) + ' must call proceed() exactly once'); } // 調用下一個攔截器 RealInterceptorChain next = new RealInterceptorChain(interceptors, streamAllocation, httpCodec,connection, index + 1, request, call, eventListener, connectTimeout, readTimeout,writeTimeout); Interceptor interceptor = interceptors.get(index); Response response = interceptor.intercept(next); //調用攔截器中的intercept()方法 // Confirm that the next interceptor made its required call to chain.proceed(). if (httpCodec != null && index + 1 < interceptors.size() && next.calls != 1) { throw new IllegalStateException('network interceptor ' + interceptor + ' must call proceed() exactly once'); } // Confirm that the intercepted response isn’t null. if (response == null) { throw new NullPointerException('interceptor ' + interceptor + ' returned null'); } if (response.body() == null) { throw new IllegalStateException( 'interceptor ' + interceptor + ' returned a response with no body'); } return response; }

從上面的代碼可以看出來,chain.proceed主要是講集合中的攔截器遍歷出來,然后通過調用每一個攔截器中的intercept()方法,然后獲取到response結果,返回。

我們看看CacheInterceptor這個類,找到intercept()方法。

@Override public Response intercept(Chain chain) throws IOException { Response cacheCandidate = cache != null? cache.get(chain.request()): null; long now = System.currentTimeMillis(); //創建CacheStrategy.Factory對象,進行緩存配置 CacheStrategy strategy = new CacheStrategy.Factory(now, chain.request(), cacheCandidate).get(); //網絡請求 Request networkRequest = strategy.networkRequest; //緩存響應 Response cacheResponse = strategy.cacheResponse; if (cache != null) { //記錄當前請求是網絡發起還是緩存發起 cache.trackResponse(strategy); } if (cacheCandidate != null && cacheResponse == null) { closeQuietly(cacheCandidate.body()); // The cache candidate wasn’t applicable. Close it. } // 不進行網絡請求并且緩存不存在或者過期則返回504錯誤 if (networkRequest == null && cacheResponse == null) { return new Response.Builder() .request(chain.request()) .protocol(Protocol.HTTP_1_1) .code(504) .message('Unsatisfiable Request (only-if-cached)') .body(Util.EMPTY_RESPONSE) .sentRequestAtMillis(-1L) .receivedResponseAtMillis(System.currentTimeMillis()) .build(); } // 不進行網絡請求,而且緩存可以使用,直接返回緩存 if (networkRequest == null) { return cacheResponse.newBuilder() .cacheResponse(stripBody(cacheResponse)) .build(); } //進行網絡請求 Response networkResponse = null; try { networkResponse = chain.proceed(networkRequest); } finally { // If we’re crashing on I/O or otherwise, don’t leak the cache body. if (networkResponse == null && cacheCandidate != null) {closeQuietly(cacheCandidate.body()); } } //---------省略若干代碼------------- return response; }

上面我做了很多注釋,基本的流程是有緩存就取緩存里面的,沒有緩存就請求網絡。我們來看看網絡請求的類CallServerInterceptor

/* * Copyright (C) 2016 Square, Inc. * * Licensed under the Apache License, Version 2.0 (the 'License'); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an 'AS IS' BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */package okhttp3.internal.http;import java.io.IOException;import java.net.ProtocolException;import okhttp3.Interceptor;import okhttp3.Request;import okhttp3.Response;import okhttp3.internal.Util;import okhttp3.internal.connection.RealConnection;import okhttp3.internal.connection.StreamAllocation;import okio.Buffer;import okio.BufferedSink;import okio.ForwardingSink;import okio.Okio;import okio.Sink;/** This is the last interceptor in the chain. It makes a network call to the server. */public final class CallServerInterceptor implements Interceptor { private final boolean forWebSocket; public CallServerInterceptor(boolean forWebSocket) { this.forWebSocket = forWebSocket; } @Override public Response intercept(Chain chain) throws IOException { RealInterceptorChain realChain = (RealInterceptorChain) chain; HttpCodec httpCodec = realChain.httpStream(); StreamAllocation streamAllocation = realChain.streamAllocation(); RealConnection connection = (RealConnection) realChain.connection(); Request request = realChain.request(); long sentRequestMillis = System.currentTimeMillis(); realChain.eventListener().requestHeadersStart(realChain.call()); httpCodec.writeRequestHeaders(request); realChain.eventListener().requestHeadersEnd(realChain.call(), request); Response.Builder responseBuilder = null; if (HttpMethod.permitsRequestBody(request.method()) && request.body() != null) { // If there’s a 'Expect: 100-continue' header on the request, wait for a 'HTTP/1.1 100 // Continue' response before transmitting the request body. If we don’t get that, return // what we did get (such as a 4xx response) without ever transmitting the request body. if ('100-continue'.equalsIgnoreCase(request.header('Expect'))) {httpCodec.flushRequest();realChain.eventListener().responseHeadersStart(realChain.call());responseBuilder = httpCodec.readResponseHeaders(true); } if (responseBuilder == null) {// Write the request body if the 'Expect: 100-continue' expectation was met.realChain.eventListener().requestBodyStart(realChain.call());long contentLength = request.body().contentLength();CountingSink requestBodyOut = new CountingSink(httpCodec.createRequestBody(request, contentLength));BufferedSink bufferedRequestBody = Okio.buffer(requestBodyOut);request.body().writeTo(bufferedRequestBody);bufferedRequestBody.close();realChain.eventListener() .requestBodyEnd(realChain.call(), requestBodyOut.successfulCount); } else if (!connection.isMultiplexed()) {// If the 'Expect: 100-continue' expectation wasn’t met, prevent the HTTP/1 connection// from being reused. Otherwise we’re still obligated to transmit the request body to// leave the connection in a consistent state.streamAllocation.noNewStreams(); } } httpCodec.finishRequest(); if (responseBuilder == null) { realChain.eventListener().responseHeadersStart(realChain.call()); responseBuilder = httpCodec.readResponseHeaders(false); } Response response = responseBuilder.request(request).handshake(streamAllocation.connection().handshake()).sentRequestAtMillis(sentRequestMillis).receivedResponseAtMillis(System.currentTimeMillis()).build(); int code = response.code(); if (code == 100) { // server sent a 100-continue even though we did not request one. // try again to read the actual response responseBuilder = httpCodec.readResponseHeaders(false); response = responseBuilder .request(request) .handshake(streamAllocation.connection().handshake()) .sentRequestAtMillis(sentRequestMillis) .receivedResponseAtMillis(System.currentTimeMillis()) .build(); code = response.code(); } realChain.eventListener() .responseHeadersEnd(realChain.call(), response); if (forWebSocket && code == 101) { // Connection is upgrading, but we need to ensure interceptors see a non-null response body. response = response.newBuilder() .body(Util.EMPTY_RESPONSE) .build(); } else { response = response.newBuilder() .body(httpCodec.openResponseBody(response)) .build(); } if ('close'.equalsIgnoreCase(response.request().header('Connection'))|| 'close'.equalsIgnoreCase(response.header('Connection'))) { streamAllocation.noNewStreams(); } if ((code == 204 || code == 205) && response.body().contentLength() > 0) { throw new ProtocolException( 'HTTP ' + code + ' had non-zero Content-Length: ' + response.body().contentLength()); } return response; }}

到這里,基本上okhttp的整個流程就出來了,當然,這里只是一個整體的大概流程,如果要摳的很細,那就不是一篇文章能夠說明的了了。現在回過頭來再看一眼流程圖,是不是感覺特別明朗了。

以上就是解析Android框架之OkHttp3源碼的詳細內容,更多關于Android框架之OkHttp3源碼的資料請關注好吧啦網其它相關文章!

標簽: Android
相關文章:
主站蜘蛛池模板: 深夜在线视频 | 天堂国产精品 | 成年人黄色av | 亚洲黄色录像片 | 国产成人专区 | 色诱久久久久综合网ywww | 蜜臀一区 | 中文字幕视频网站 | 红杏aⅴ成人免费视频 | 国产亚洲精久久久久久无码苍井空 | 77777五月色婷婷丁香视频 | 国产东北淫语对白粗口video | 波多野结衣一本 | 无码人妻丰满熟妇区bbbbxxxx | 四虎成人精品永久免费av | a级黄色片网站 | 毛片网止 | 国产特级毛片aaaaaa高清 | 亚洲中文字幕久久精品蜜桃 | 国产日本视频 | 亚洲人成色7777在线观看 | 亚洲伊人久久久 | 中文在线а√在线 | 天天躁夜夜踩很很踩2022 | 天堂а√在线中文在线新版 | 日韩va在线观看 | 国产成人av免费观看 | aⅴ一区二区三区无卡无码 aⅴ在线免费观看 | 18无码粉嫩小泬无套在线观看 | 免费黄在线 | 日韩精品无码免费一区二区三区 | 国产精品福利小视频 | 在线欧美成人 | 国产又黄又硬又湿又黄的网站免费 | 综合网在线视频 | 亚洲国产欧美精品 | 国产偷抇久久精品a片69 | 野外偷拍做爰全过程 | 日本公妇乱淫免费 | 亚洲精品久久久久中文字幕m男 | 亚洲色图制服丝袜 | 奇米视频888战线精品播放 | 国语对白做受69 | 精品福利在线视频 | 欧美乱妇高清无乱码 | 国产黄色视屏 | 亚洲欧美又粗又长久久久 | 日韩欧美手机在线 | 亚洲精品乱码久久久久v最新版 | 中国壮男强迫野外china | 国产黄网站 | av动漫免费看 | 色欲久久久天天天综合网 | 亚洲91在线视频 | 8x8ⅹ国产精品8x红人影库 | 3d动漫精品啪啪一区二区 | 免费一级做a爰片久久毛片潮喷 | va亚洲va欧美va国产综合 | 中文字幕91视频 | 国产目拍亚洲精品99久久精品 | 成人乱人乱一区二区三区 | 国产午夜精品一区二区三区四区 | 日本一级大黄毛片基地 | 能免费看av的网站 | 欧洲av无码放荡人妇网站 | 伊人久久大香线蕉无码 | 国产精品久久一区二区三区 | 欧美一区二区三区免费播放视频了 | 亚洲一久久久久久久久 | 五月婷婷免费视频 | 超碰最新网址 | 国产无套粉嫩白浆内谢在a 国产无套粉嫩白浆内谢在线 | 亚洲免费一二三区 | 污污免费在线观看 | 蜜臀久久精品久久久久久酒店 | 亚洲自拍偷拍一区二区三区 | 好吊日精品视频 | 国产亚洲精品自在久久 | 中文字幕日本六区小电影 | 色情一区二区三区免费看 | 免费看男女做爰爽爽 | 手机av免费在线 | 日韩精品字幕 | 九九婷婷 | 聚色av| 国产com| 天堂久久久久久久 | 一个色亚洲 | 激烈的性高湖波多野结衣 | 蜜桃av成人 | 99性视频 | 日本欧美一级aaaaa毛片 | 69影院少妇在线观看 | 国产乱视频 | 日本xxxx高清 | 亚洲黄色小视频在线观看 | 1024精品久久久久久久久 | 污片免费在线观看 | 女人夜夜春高潮爽a∨片传媒 | 色无极影院亚洲 | 久久亚洲免费 | 国产毛片一区二区 | 日本国产一区二区三区在线观看 | 国产精品婷婷久久久久久 | 一级三级毛片 | 国产精品多久久久久久情趣酒店 | 中文久久乱码一区二区 | 日韩在线观看视频一区二区 | 国产女人高潮抽搐叫床涩爱小说 | 亚洲国产天堂久久综合226114 | 午夜九九| 国产最新进精品视频 | 韩国三级一区 | 国产又色又爽又黄又免费文章 | 国产精品一品二区三区的使用体验 | 人人看人人做 | 在线观看视频免费入口 | 91亚洲精华国产精华 | 日韩欧美亚洲国产精品字幕久久久 | 蜜臀久久精品 | 狠狠色噜噜狠狠狠狠黑人 | 大香焦久久 | 在线有码视频 | 色八区| 国产精品一区二区久久精品爱微奶 | 色视频在线观看网站 | 亚洲码国产精品高潮在线 | 四虎永久在线精品免费一区二区 | 欧美精品自拍视频 | 天天躁日日躁狠狠躁av麻豆 | 久久亚洲精品中文字幕冲田杏梨 | 97精品视频在线观看 | 国产乱xxxxx987国语对白 | 久久精品国产精品国产一区 | 成人做爰高潮片免费视频九九九 | 久久riav | 国产无遮挡又黄又爽免费视频 | 欧美区在线 | 91精品国产视频 | 922tv免费观看在线 | 欧美成年人视频在线观看 | 99精品免费久久久久久久久日本 | 91视频免费在观看 | 国产精品第9页 | 韩国一级黄色毛片 | 欧美性猛交xxx嘿人猛交 | 捆绑紧缚一区二区三区在线观看 | 老司机午夜精品视频资源 | 人妻丰满熟妇岳av无码区hd | 天天澡天天狠天干天 | 暴力调教一区二区三区 | 日本做爰高潮视频 | 一性一交一口添一摸视频 | 高清国产午夜精品久久久久久 | 日本妞xxxxxxxxx68| 国产精品成人一区二区网站软件 | 一区精品二区国产 | 在线观看三级视频 | 国产精品推荐天天看天天爽 | 伊人永久 | 91国内精品野花午夜精品 | 中文字幕无码不卡一区二区三区 | 国产在线精品国自产拍影院同性 | 三级网站| 91蝌蚪91密月 | 黄色美女大片 | 国产天堂亚洲国产碰碰 | 2020av视频| 国产女同疯狂互摸系列3 | 国产精品亚洲精品一区二区三区 | 色中文字幕在线观看 | 美女黄频视频大全免费的国内 | 午夜肉伦伦影院九七影网 | 日韩高清专区 | 中文字幕亚洲欧美日韩 | 永久在线 | 欧美乱妇无乱码大黄a片 | 国产人与zoxxxx另类 | 日本69视频 | 免费又色又爽又黄的成人用品 | 青青草一区 | 国产日韩一区二区在线 | 亚洲高清视频在线观看 | 国产精品免费一区二区 | 国产激情网 | 成人做爰www免费看视频网站 | 五月丁香综合缴情六月小说 | 欧美成人精品 | 国产成人无码区免费内射一片色欲 | 少妇全光淫片bbw | 天天躁日日躁mmmmxxxx | 伊人色综合久久天天 | 久久久久国产精品无码免费看 | 九色视频在线播放 | 日本一级大毛片a一 | 日韩久久精品 | 色射网 | 国产在线国偷精品产拍 | 色呦色呦色精品 | 鲁夜天天末成午 | 国产一级做a爱片久久毛片a | 蜜桃视频插满18在线观看 | 一级特黄少妇高清毛片 | www国产精品内射老熟女 | 国产精品成人一区二区艾草 | 超碰老司机| 亚洲综合在线第一页 | 国产精品久久久久久久久 | 欧美一区二区三区喷汁尤物 | 俄罗斯兽交黑人又大又粗水汪汪 | 亚洲你懂得 | 日本十八少妇毛片视频 | 无码无套少妇毛多18p | 少妇公车张开腿迎合巨大视频 | 亚洲摸丰满大乳奶水 | 精品一卡二卡三卡四卡 | av不卡免费看 | 久国产精品| 久久99久久99精品免视看婷婷 | 亚洲小说网 | 美女高潮黄又色高清视频免费 | 国产在热线精品视频 | 亚洲日韩中文字幕在线播放 | 无码无套少妇毛多69xxx | 国产三级高清 | av免费网址在线观看 | 欧美人与牲动交xxxx | 久久久久久久久久久国产 | 日本丰满少妇裸体自慰 | 亚洲天堂高清 | 亚洲区免费中文字幕影片|高清在线观看 | 一级黄色免费视频 | 中文字幕伊人 | 久久精品蜜芽亚洲国产av | 色噜噜色综合 | 丝袜人妻一区二区三区 | 午夜影视体验区 | 国产成人精品一区二三区在线观看 | 成人爱爱aa啪啪看片 | 国产精品成人av片免费看最爱 | 日本丰满大乳免费xxxx | 一区二区在线免费观看视频 | 在线草| 香港三日本三级少妇少99 | 中文有码在线观看 | 国产精品成人无码免费 | 久久老女人 | 中文精品一区 | 国产又黄又爽 | 99国产超薄丝袜足j在线播放 | 中文无码日韩欧 | 久久久久久一区二区三区四区别墅 | 午夜快播| 国产乱子伦视频一区二区三区 | 一区二区三区四区免费 | 夜夜爽天天干 | 国产激情无码一区二区 | 免费一级做a爰片蜜桃 | 成人性生交视频免费观看 | 日韩乱码在线观看 | 在教室伦流澡到高潮hnp视频 | 国产精品成人免费一区久久羞羞 | 毛片入口| 亚洲国产欧洲综合997久久, | 亚洲色图27p | 国产精品久久久久久久成人午夜 | 91福利社在线观看 | 大陆少妇xxxx做受 | 40岁干柴烈火少妇高潮不断 | 九九国产精品入口麻豆 | 欧美肥妇多毛bbw | 尤物视频网站在线观看 | av美女在线观看 | 亚洲精品午夜国产va久久成人 | 亚洲欧洲精品在线 | 成人午夜小视频 | 亚洲天码中字一区 | 射进来av影视 | jizz成熟丰满日本少妇 | 国产精品久久久久免费a∨大胸 | 欧美另类老妇 | 精品久久久av | 日韩 亚洲 中文 图片 小说 | 国产成人免费观看视频 | 日韩av图片| 九九九九热精品免费视频点播观看 | 伊人久久综合影院 | 亚洲国产成人久久综合一区,久久久国产99 | www.亚洲色图.com | 少妇被爽到高潮喷水久久欧美精品 | 一本一道久久a久久精品蜜桃 | 国内精品国产三级国产aⅴ久 | 青青青青视频 | 激情网综合 | 亚洲毛片视频 | 欧美性生交xxxxx久久久 | 亚洲国产aⅴ成人精品无吗 亚洲国产aaa | 日韩精品中文字幕一区二区 | 色视频网站在线观看一=区 色视频网址 | 长河落日电视连续剧免费观看01 | 大色综合色综合网站 | 国产成人精品免费看视频 | 黄色一级片a | 在线免费福利 | 中文字幕第15页 | 国产肉体xxxx裸体视频 | 亚洲男人天堂2023 | 国产特级黄色录像 | 亚洲精品一区二区在线 | 成人精品啪啪欧美成 | 无遮无挡三级动态图 | ts 人妖 另类 在线 | 天天午夜 | 日韩视频h| 人妻在卧室被老板疯狂进入 | 特级毛片av | 国产手机av| 久久亚洲成人 | ass亚洲肉体欣赏pics | 国产吞精囗交高潮 | 不卡的av在线免费观看 | 国产午夜精品av一区二区麻豆 | 国产cao| 成人伊人 | 在线成人精品国产区免费 | 大rb狠狠地给你这y荡的视频 | 成人动漫综合网 | 美腿丝袜亚洲色图 | 伊人色在线 | 国产在线播放一区 | 香港台湾日本三级大全 | 黄色一级免费视频 | 天天躁日日躁狠狠躁欧美老妇 | 风间由美一区二区 | 国产欧美一区二区精品秋霞影院 | 亚洲成人一区二区三区 | 国产精品69毛片高清亚洲 | 日韩欧美中文在线观看 | 日韩视频一区二区三区在线播放免费观看 | 亚洲精品国偷拍自产在线观看蜜桃 | 午夜精品久久久久久久四虎美女版 | 国产男女做爰猛烈床吻戏网站 | 7777av| 男女69视频 | 免费视频91| 天堂av亚洲 | 久久久www成人免费无遮挡大片 | 亚洲一区 亚洲二区 | 巨人精品福利官方导航 | 久久久国产一区二区三区四区 | 亚洲一区二区不卡在线观看 | 国产人妖视频 | 一级片成人| 久久99精品久久久久久动态图 | 成年网站在线播放 | 波多野结衣av一区二区三区中文 | 香蕉久久久| 国产网红主播av国内精品 | 精品久久久久久久久久久下田 | 热久久免费 | 18禁美女裸体网站无遮挡 | 亚洲插 | 九色国产精品入口 | 福利91 | 免费裸体无遮挡黄网站免费看 | 亚洲黄色免费 | 天美传媒一区二区 | 五级毛片 | 国语精品对白露脸少妇网站 | 99精品国产99久久久久久97 | 国产又粗又爽又猛又大的动漫片 | 最新网址av | 国产中文区二幕区2021 | 东方伊甸园av在线 | 日韩少妇av | www..com黄色| 97av视频在线 | 国产情人综合久久777777 | 一本一本久久a久久精品综合小说 | 久久久久国产一区二区 | 91国在线观看 | 日本大片免a费观看视频 | 青青草成人av| 黄网站色视频免费观看 | 日韩乱码人妻无码中文字幕视频 | 国产精品久久久对白 | 国产电影无码午夜在线播放 | 精品国产一区二区三区无码 | 精品一卡二卡三卡 | 欧美成人一区二区三区在线视频 | 日本黄a| 少妇精品一区 | 色妞www精品视频 | 极品白嫩丰满美女无套 | 色午夜 | 国产成人一区 | 成人动漫在线观看 | 日韩少妇内射免费播放18禁裸乳 | 新婚夫妇白天啪啪自拍 | 亚洲一区二区蜜桃 | 国产又粗又猛又爽 | 粉嫩久久久久久久极品 | 国产av无码久久精品 | 国产成人午夜视频 | 91丨九色丨蝌蚪丨老版 | 国产精品无码无卡无需播放器 | 自拍偷拍18p | 性一交一乱一色一免费无遮挡 | 久久夜色噜噜噜av一区二区 | 亚洲最大福利视频 | 国产激情无码一区二区三区 | 99热2| 国产精品视频导航 | 91在线观看视频网站 | 久久国产尿小便嘘嘘97 | 免费aaa乇片 | 国产偷窥熟女精品视频大全 | 免费福利小视频 | 国产内射老熟女aaaa | 欧美日韩高清在线观看 | 无码va在线观看 | 一本一道久久综合狠狠老精东影业 | 日韩色图片 | 九月婷婷人人澡人人添人人爽 | 男女一级黄色 | 一区二区三区网站 | 久久久久久久久免费视频 | 永久免费的av在线电影网 | 免费看成人aa片无码视频吃奶 | 中国av免费看 | 极品销魂美女少妇尤物优美 | 狠狠色综合网站久久久久久久 | 国产精品18久久久久久vr | videos另类灌满极品另类 | 国内精品久久久久久久久久久 | 91在线免费看片 | 国产性色强伦免费视频 | 天堂а√在线中文在线新版 | 绝顶高潮videos合集 | 网站黄在线观看 | japanese日本精品少妇 | 狼人av在线 | 国产伦久视频免费观看视频 | 国产成人无码一区二区三区 | 99国产精品久久 | 丁香五月缴情综合网 | 少妇一级淫片免费放 | 亚洲一二三区在线 | 中文字幕一区二区三区在线播放 | 香蕉国产在线视频 | 99精品在线 | 久久综合av色老头免费观看 | 经典毛片 | 97精品在线观看 | 亚洲成人免费网站 | 精品免费国产一区二区三区四区介绍 | 国产放荡av国产精品 | 黄色片一区 | 地下室play道具走绳结 | 日本a级片一区二区 | 天天久久综合 | 三级毛片子 | 久草在线资源总站 | 久久99一区| 国产乱淫av免费观看 | 亚洲爱色| av免费播放网站 | 久久天天躁夜夜躁狠狠85麻豆 | 天天鲁在视频在线观看 | 好吊妞视频988gao免费软件 | 亚洲日本国产精品 | 国产一区二区在线精品 | 成人视频在线观看 | 思思久久99热只有频精品66 | 少妇奶水亚洲一区二区观看 | av天堂午夜精品一区二区三区 | 在线中文字幕日韩 | 国产经典三级在线 | 国产女主播一区二区 | 再深点灬舒服灬太大的91优势 | 人人干天天干 | 日韩精品三级 | 麻豆av在线看 | 成人免费网站在线观看 | 久久精品国产亚洲 | 精品国产免费久久久久久桃子图片 | 欧美a级在线观看 | 亚洲精品高潮 | 波多野结衣乳喷高潮视频 | 国产精品igao视频网网址 | 久久99精品久久久久久不卡 | 国产sm重味一区二区三区 | 色妞ww精品视频7777 | 亚洲爱爱片 | 欧美午夜精品久久久久久浪潮 | 欧美成人不卡 | 九九热在线免费观看视频 | 天堂国产一区二区三区四区不卡 | 国产精品一区二区手机在线观看 | 免费无码av片在线观看网站 | 国内精品久久久久久 | 成年性午夜免费视频网站 | 亚洲永久在线观看 | 亚洲国产精久久久久久久 | 国产18处破外女 | 免费国产一级 | 激情一区| 国产免费乱淫av | 爱爱视频在线看 | 日韩无套无码精品 | 国产精品无码一区二区在线 | 国产精品裸体一区二区三区 | 午夜精品久久久久久久91蜜桃 | 韩国午夜理论在线观看 | 性一交一黄一片 | 久久免费播放 | 国产日产亚洲精品 | 国产精品无套呻吟在线 | 国产综合精品 | 国产成人精品午夜片在线观看 | 奴性女会所调教 | 欧美人与禽zoz0善交找视频 | 国产91久久婷婷一区二区 | 自拍av在线 | 久久精品国产99国产精品亚洲 | 亚洲综合精品视频 | 91视频第一页| 亚洲综合天堂 | 国产精品亚洲а∨无码播放麻豆 | 亚洲综合亚洲 | 夜夜高潮夜夜爽夜夜爱爱 | 萌白酱国产一区二区 | 成年无码av片在线 | 45分钟免费真人视频 | 丰满少妇人妻久久久久久 | 欧美男人又粗又长又大 | 欧美大黄视频 | 美女免费网站在线观看 | 顶级少妇mm131美女艺术 | 日本55丰满熟妇厨房伦 | 韩国av免费在线观看 | 国产一级淫片a免费播放口欧美 | 99这里有精品 | 2024av天堂手机在线观看 | 日日噜噜夜夜狠狠视频 | √天堂资源在线中文8在线最新版 | 国产乱子伦无套一区二区三区 | 久久9精品区-无套内射无码 | 久久美女av| 久久精品国产免费看久久精品 | 久久久av亚洲男天堂 | 国产无套粉嫩白浆内的人物介绍 | 国产精品污www一区二区三区 | 亚洲人成色77777在线观看 | 蜜桃视频在线观看www | 成人黄色片免费看 | 久久久精彩视频 | 亚洲激情视频网站 | 视频一区二区在线 | 免费看黄色一级大片 | 一区二区三区波多野结衣 | 麻豆91在线| www亚洲精品少妇裸乳一区二区 | 精品国产18久久久久久依依影院 | 国产999精品久久久久久绿帽 | 中文字幕在线观看视频地址二 | 国产91精| 国精产品999国精产品蜜臀 | 亚洲国产精品日本无码网站 | 北条麻妃一二三区 | 欧洲熟妇性色黄 | 天天操狠狠 | 久久午夜夜伦鲁鲁片免费无码影视 | 国内精品视频在线播放 | 善良的公与媳hd中文字 | 屁屁国产草草影院ccyycom | 亚洲欧洲日本在线 | 性欧美长视频免费观看不卡 | 日韩亚洲欧美一区 | 免费人成视频在线观看网站 | 天堂а√中文最新版在线 | japanese av在线 | 日韩性插 | 久久久久日韩精品久久久男男 | 国产精品不卡一区二区三区 | 好吊色视频988gao在线观看 | 国产a级免费 | 又污又爽又黄的网站 | 久久麻豆av| 电梯男女做爰视频 | 成人午夜福利视频 | 一区二区三区在线视频播放 | 精品人妻系列无码人妻免费视频 | 一区二区三区无码高清视频 | xox0人妖国产另类 | 日韩一区二区三区久久 | 精品免费国产一区二区三区四区 | aⅴ亚洲 日韩 色 图网站 播放 | 青青操久久 | 新狼窝色av性久久久久久 | 国产对白国语对白 | 男女下面进入的视频免费午夜 | vr成人啪啪影视 | 五月天中文字幕mv在线 | 欧美高清不卡 | 欧美色精品 | 亚洲精品9999久久久久无码 | 在线播放小视频 | 中日韩av在线 | 四虎1515hh海外永久免费 | 欧美性受xxxxx | 人体内射精一区二区三区 | 亚洲欧美国产精品久久久久久久 | 一本色道久久99精品综合蜜臀 | 国语自产少妇精品视频蜜桃 |