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

Spring Boot 記錄請求響應日志的常用手段

開發 架構
某些業務需求需要追蹤我們的接口訪問情況,也就是把請求和響應記錄下來。基本的記錄維度包含了請求入參(路徑query參數,請求體)、請求路徑(uri)、請求方法(method)、請求頭(headers)以及響應狀態、響應頭、甚至包含了敏感的響應體等等。今天總結了幾種方法,你可以按需選擇。

[[416714]]

某些業務需求需要追蹤我們的接口訪問情況,也就是把請求和響應記錄下來。基本的記錄維度包含了請求入參(路徑query參數,請求體)、請求路徑(uri)、請求方法(method)、請求頭(headers)以及響應狀態、響應頭、甚至包含了敏感的響應體等等。今天總結了幾種方法,你可以按需選擇。

請求追蹤的實現方式

網關層

很多網關設施都具有httptrace的功能,可以幫助我們集中記錄請求流量的情況。Orange、Kong、Apache Apisix這些基于Nginx的網關都具有該能力,就連Nginx本身也提供了記錄httptrace日志的能力。

優點是可以集中的管理httptrace日志,免開發;缺點是技術要求高,需要配套的分發、存儲、查詢的設施。

Spring Boot Actuator

在Spring Boot中,其實提供了簡單的追蹤功能。你只需要集成:

  1. <dependency> 
  2.     <groupId>org.springframework.boot</groupId> 
  3.     <artifactId>spring-boot-starter-actuator</artifactId> 
  4. </dependency> 

開啟/actuator/httptrace:

  1. management: 
  2.   endpoints: 
  3.     web: 
  4.       exposure: 
  5.         include: 'httptrace' 

就可以通過http://server:port/actuator/httptrace獲取最近的Http請求信息了。

不過在最新的版本中可能需要顯式的聲明這些追蹤信息的存儲方式,也就是實現HttpTraceRepository接口并注入Spring IoC。

例如放在內存中并限制為最近的100條(不推薦生產使用):

  1. @Bean 
  2. public HttpTraceRepository httpTraceRepository(){ 
  3.     return new InMemoryHttpTraceRepository(); 

追蹤日志以json格式呈現:

Spring Boot Actuator記錄的httptrace

記錄的維度不多,當然如果夠用的話可以試試。

優點在于集成起來簡單,幾乎免除開發;缺點在于記錄的維度不多,而且需要搭建緩沖消費這些日志信息的設施。

CommonsRequestLoggingFilter

Spring Web模塊還提供了一個過濾器CommonsRequestLoggingFilter,它可以對請求的細節進行日志輸出。配置起來也比較簡單:

  1. @Bean 
  2. CommonsRequestLoggingFilter  loggingFilter(){ 
  3.     CommonsRequestLoggingFilter loggingFilter = new CommonsRequestLoggingFilter(); 
  4.     // 記錄 客戶端 IP信息 
  5.     loggingFilter.setIncludeClientInfo(true); 
  6.     // 記錄請求頭 
  7.     loggingFilter.setIncludeHeaders(true); 
  8.     // 如果記錄請求頭的話,可以指定哪些記錄,哪些不記錄 
  9.     // loggingFilter.setHeaderPredicate(); 
  10.     // 記錄 請求體  特別是POST請求的body參數 
  11.     loggingFilter.setIncludePayload(true); 
  12.     // 請求體的大小限制 默認50 
  13.     loggingFilter.setMaxPayloadLength(10000); 
  14.     //記錄請求路徑中的query參數  
  15.     loggingFilter.setIncludeQueryString(true); 
  16.     return loggingFilter; 

而且必須開啟對CommonsRequestLoggingFilter的debug日志:

  1. logging: 
  2.   level
  3.     org: 
  4.       springframework: 
  5.         web: 
  6.           filter: 
  7.             CommonsRequestLoggingFilter: debug 

一次請求會輸出兩次日志,一次是在第一次經過過濾器前;一次是完成過濾器鏈后。

CommonsRequestLoggingFilter記錄請求日志

這里多說一句其實可以改造成輸出json格式的。

優點是靈活配置、而且對請求追蹤的維度全面,缺點是只記錄請求而不記錄響應。

ResponseBodyAdvice

Spring Boot統一返回體其實也能記錄,需要自行實現。這里借鑒了CommonsRequestLoggingFilter解析請求的方法。響應體也可以獲取了,不過響應頭和狀態因為生命周期還不清楚,這里獲取還不清楚是否合適,不過這是一個思路。

  1. /** 
  2.  * @author felord.cn 
  3.  * @since 1.0.8.RELEASE 
  4.  */ 
  5. @Slf4j 
  6. @RestControllerAdvice(basePackages = {"cn.felord.logging"}) 
  7. public class RestBodyAdvice implements ResponseBodyAdvice<Object> { 
  8.     private static final int DEFAULT_MAX_PAYLOAD_LENGTH = 10000; 
  9.     public static final String REQUEST_MESSAGE_PREFIX = "Request ["
  10.     public static final String REQUEST_MESSAGE_SUFFIX = "]"
  11.     private ObjectMapper objectMapper = new ObjectMapper(); 
  12.  
  13.     @Override 
  14.     public boolean supports(MethodParameter returnType, Class<? extends HttpMessageConverter<?>> converterType) { 
  15.         return true
  16.     } 
  17.  
  18.     @SneakyThrows 
  19.     @Override 
  20.     public Object beforeBodyWrite(Object body, 
  21.                                   MethodParameter returnType, 
  22.                                   MediaType selectedContentType, 
  23.                                   Class<? extends HttpMessageConverter<?>> selectedConverterType, 
  24.                                   ServerHttpRequest request, 
  25.                                   ServerHttpResponse response) { 
  26.  
  27.         ServletServerHttpRequest servletServerHttpRequest = (ServletServerHttpRequest) request; 
  28.  
  29.         log.debug(createRequestMessage(servletServerHttpRequest.getServletRequest(), REQUEST_MESSAGE_PREFIX, REQUEST_MESSAGE_SUFFIX)); 
  30.         Rest<Object> objectRest; 
  31.         if (body == null) { 
  32.             objectRest = RestBody.okData(Collections.emptyMap()); 
  33.         } else if (Rest.class.isAssignableFrom(body.getClass())) { 
  34.             objectRest = (Rest<Object>) body; 
  35.         } 
  36.         else if (checkPrimitive(body)) { 
  37.             return RestBody.okData(Collections.singletonMap("result", body)); 
  38.         }else { 
  39.             objectRest = RestBody.okData(body); 
  40.         } 
  41.         log.debug("Response Body ["+ objectMapper.writeValueAsString(objectRest) +"]"); 
  42.         return objectRest; 
  43.     } 
  44.  
  45.  
  46.     private boolean checkPrimitive(Object body) { 
  47.         Class<?> clazz = body.getClass(); 
  48.         return clazz.isPrimitive() 
  49.                 || clazz.isArray() 
  50.                 || Collection.class.isAssignableFrom(clazz) 
  51.                 || body instanceof Number 
  52.                 || body instanceof Boolean 
  53.                 || body instanceof Character 
  54.                 || body instanceof String; 
  55.     } 
  56.  
  57.  
  58.     protected String createRequestMessage(HttpServletRequest request, String prefix, String suffix) { 
  59.         StringBuilder msg = new StringBuilder(); 
  60.         msg.append(prefix); 
  61.         msg.append(request.getMethod()).append(" "); 
  62.         msg.append(request.getRequestURI()); 
  63.  
  64.  
  65.         String queryString = request.getQueryString(); 
  66.         if (queryString != null) { 
  67.             msg.append('?').append(queryString); 
  68.         } 
  69.  
  70.  
  71.         String client = request.getRemoteAddr(); 
  72.         if (StringUtils.hasLength(client)) { 
  73.             msg.append(", client=").append(client); 
  74.         } 
  75.         HttpSession session = request.getSession(false); 
  76.         if (session != null) { 
  77.             msg.append(", session=").append(session.getId()); 
  78.         } 
  79.         String user = request.getRemoteUser(); 
  80.         if (user != null) { 
  81.             msg.append(", user=").append(user); 
  82.         } 
  83.  
  84.         HttpHeaders headers = new ServletServerHttpRequest(request).getHeaders(); 
  85.         msg.append(", headers=").append(headers); 
  86.  
  87.         String payload = getMessagePayload(request); 
  88.         if (payload != null) { 
  89.             msg.append(", payload=").append(payload); 
  90.         } 
  91.  
  92.         msg.append(suffix); 
  93.         return msg.toString(); 
  94.     } 
  95.  
  96.     protected String getMessagePayload(HttpServletRequest request) { 
  97.         ContentCachingRequestWrapper wrapper = 
  98.                 WebUtils.getNativeRequest(request, ContentCachingRequestWrapper.class); 
  99.         if (wrapper != null) { 
  100.             byte[] buf = wrapper.getContentAsByteArray(); 
  101.             if (buf.length > 0) { 
  102.                 int length = Math.min(buf.length, DEFAULT_MAX_PAYLOAD_LENGTH); 
  103.                 try { 
  104.                     return new String(buf, 0, length, wrapper.getCharacterEncoding()); 
  105.                 } catch (UnsupportedEncodingException ex) { 
  106.                     return "[unknown]"
  107.                 } 
  108.             } 
  109.         } 
  110.         return null
  111.     } 

別忘記配置ResponseBodyAdvice的logging級別為DEBUG。

logstash-logback-encoder

這個是logstash的logback編碼器,可以結構化輸出httptrace為json。引入:

  1. <dependency> 
  2.     <groupId>net.logstash.logback</groupId> 
  3.     <artifactId>logstash-logback-encoder</artifactId> 
  4.     <version>6.6</version> 
  5. </dependency> 

配置logback的ConsoleAppender為LogstashEncoder:

  1. <configuration> 
  2.     <appender name="jsonConsoleAppender" class="ch.qos.logback.core.ConsoleAppender"
  3.         <encoder class="net.logstash.logback.encoder.LogstashEncoder"/> 
  4.     </appender> 
  5.     <root level=" INFO"
  6.         <appender-ref ref="jsonConsoleAppender"/> 
  7.     </root> 
  8. </configuration> 

然后同樣實現一個解析的Filter:

  1. import org.slf4j.Logger; 
  2. import org.slf4j.LoggerFactory; 
  3. import org.slf4j.MDC; 
  4. import org.springframework.core.annotation.Order
  5. import org.springframework.stereotype.Component; 
  6.  
  7. import javax.servlet.*; 
  8. import javax.servlet.http.HttpServletRequest; 
  9. import javax.servlet.http.HttpServletResponse; 
  10. import java.io.IOException; 
  11. import java.util.UUID; 
  12.  
  13. /** 
  14.  * @author felord.cn 
  15.  * @since 1.0.8.RELEASE 
  16.  */ 
  17. @Order(1) 
  18. @Component 
  19. public class MDCFilter implements Filter { 
  20.  
  21.     private final Logger LOGGER = LoggerFactory.getLogger(MDCFilter.class); 
  22.     private final String X_REQUEST_ID = "X-Request-ID"
  23.  
  24.     @Override 
  25.     public void doFilter(ServletRequest request, 
  26.                          ServletResponse response, 
  27.                          FilterChain chain) throws IOException, ServletException { 
  28.         HttpServletRequest req = (HttpServletRequest) request; 
  29.         HttpServletResponse res = (HttpServletResponse) response; 
  30.         try { 
  31.             addXRequestId(req); 
  32.             LOGGER.info("path: {}, method: {}, query {}"
  33.                     req.getRequestURI(), req.getMethod(), req.getQueryString()); 
  34.             res.setHeader(X_REQUEST_ID, MDC.get(X_REQUEST_ID)); 
  35.             chain.doFilter(request, response); 
  36.         } finally { 
  37.             LOGGER.info("statusCode {}, path: {}, method: {}, query {}"
  38.                     res.getStatus(), req.getRequestURI(), req.getMethod(), req.getQueryString()); 
  39.             MDC.clear(); 
  40.         } 
  41.     } 
  42.  
  43.     private void addXRequestId(HttpServletRequest request) { 
  44.         String xRequestId = request.getHeader(X_REQUEST_ID); 
  45.         if (xRequestId == null) { 
  46.             MDC.put(X_REQUEST_ID, UUID.randomUUID().toString()); 
  47.         } else { 
  48.             MDC.put(X_REQUEST_ID, xRequestId); 
  49.         } 
  50.     } 
  51.  

這里解析方式其實還可以更加精細一些。

然后所有的日志都可以結構化為json了:

  1. {"@timestamp":"2021-08-10T23:48:51.322+08:00","@version":"1","message":"statusCode 200, path: /log/get, method: GET, query foo=xxx&bar=ooo","logger_name":"cn.felord.logging.MDCFilter","thread_name":"http-nio-8080-exec-1","level":"INFO","level_value":20000,"X-Request-ID":"7c0db56c-b1f2-4d85-ad9a-7ead67660f96"

總結

今天介紹了不少記錄追蹤接口請求響應的方法,總有一款適合你。

本文轉載自微信公眾號「碼農小胖哥」,可以通過以下二維碼關注。轉載本文請聯系碼農小胖哥公眾號。

 

責任編輯:武曉燕 來源: 碼農小胖哥
相關推薦

2025-06-17 07:37:53

2021-03-01 23:26:41

日志Spring BootAOP

2025-10-14 07:59:41

2024-06-04 10:05:48

微服務網關日志

2022-02-08 17:07:54

Spring BooSpring Aop日志記錄

2018-11-19 14:29:17

Spring BootXML支持

2010-09-30 14:38:13

2020-10-08 14:52:37

數據網絡威脅安全

2009-07-05 21:04:02

2009-11-27 09:34:38

VS2003命令

2022-11-18 08:31:56

Spring日志工具

2023-03-01 13:54:53

Springpostion?繼承

2025-02-03 09:00:00

API接口性能

2022-05-12 11:38:26

Java日志Slf4j

2023-09-13 08:56:51

2020-09-27 11:35:16

Spring BootStarterJava

2019-04-15 08:32:25

Spring Boot日志門面模式

2024-08-01 09:10:03

2021-03-26 06:01:45

日志MongoDB存儲

2023-09-19 22:41:30

控制器HTTP
點贊
收藏

51CTO技術棧公眾號

91视频在线免费| 少妇大叫太大太粗太爽了a片小说| 国产一区二区三区四区在线| 日本成人福利| 中文字幕制服丝袜成人av| 成人欧美一区二区三区黑人免费| 中国特黄一级片| 日本一区二区三区播放| 色综合久久88色综合天天6 | 欧美激情精品久久久久久免费 | 午夜精品成人在线| 亚洲欧美日韩在线综合| 日韩在线观看视频网站| 欧美aaaaaa午夜精品| 亚洲色图25p| 中文字幕亚洲日本| 久久精品xxxxx| 五月婷婷欧美视频| 男女激烈动态图| 91亚洲精选| av不卡在线观看| 91九色蝌蚪成人| 在线免费观看高清视频| 久久精品亚洲一区二区| 欧美极品美女电影一区| 男人晚上看的视频| 综合综合综合综合综合网| 欧美成人一区二区三区| 亚洲精品久久久久久宅男| 亚洲电影观看| 亚洲国产中文字幕在线视频综合| 成人性色av| 91欧美日韩麻豆精品| 石原莉奈在线亚洲三区| 按摩亚洲人久久| 亚洲综合色一区| 久久久久高潮毛片免费全部播放| 在线观看一区二区视频| 伊人情人网综合| 亚洲高清在线观看视频| 久久精品99国产精品| 九九精品在线观看| 岛国毛片在线观看| 围产精品久久久久久久| 中文字幕亚洲二区| 在线精品视频播放| 日本精品在线观看| 91精品国产综合久久国产大片| 成人午夜精品久久久久久久蜜臀| 浮生影视网在线观看免费| 91麻豆国产福利精品| 极品日韩久久| 亚洲三级黄色片| 91蜜桃在线免费视频| 久久精品第九区免费观看 | 欧美成人久久| 欧美成人sm免费视频| 日韩在线视频网址| 欧美国产免费| 久久91精品国产91久久跳| 欧美黄片一区二区三区| 精品国产一区二区三区| 精品剧情在线观看| 日本高清久久久| 97色婷婷成人综合在线观看| 在线播放中文一区| www.久久com| 国产一区二区三区朝在线观看| 一区二区三区在线高清| 亚洲精品人成| 黄视频网站在线| 一区二区三区四区高清精品免费观看| 日韩激情视频| 黄色网页在线观看| 亚洲一区二区三区自拍| www.中文字幕在线| 69堂免费精品视频在线播放| 欧美另类videos死尸| 亚洲美女爱爱视频| 一区二区三区欧洲区| 日韩电影大全免费观看2023年上| 一本之道在线视频| 欧美有码在线| 日韩在线欧美在线国产在线| 麻豆成人在线视频| 亚洲成人最新网站| 91国产美女视频| 中文字幕观看视频| 大尺度一区二区| 欧美日韩一区在线视频| 国产在线观看a视频| 亚洲动漫第一页| 女人被男人躁得好爽免费视频| 国产素人视频在线观看| 亚洲综合免费观看高清完整版| 日本老太婆做爰视频| 亚洲天堂电影| 欧美一区二区视频观看视频| 特黄特黄一级片| 四虎影视精品| 欧美精品免费在线| 亚洲欧美一区二区三区在线观看| 亚洲精品1234| 国产在线精品播放| 五十路在线视频| 亚洲蜜臀av乱码久久精品 | 杨幂一区二区国产精品| 亚洲黄色录像| 欧美国产高跟鞋裸体秀xxxhd| 黄色一级视频免费观看| 日韩不卡免费视频| 精品亚洲一区二区三区四区五区高| 天天干天天爽天天操| 国产精品传媒入口麻豆| 国产亚洲综合视频| 1204国产成人精品视频| 视频直播国产精品| 欧美成人精品欧美一| 日本v片在线高清不卡在线观看| 国产精品夜间视频香蕉| 五月婷婷在线播放| 国产欧美一区二区精品秋霞影院| 午夜精品一区二区三区四区| 9999在线视频| 日韩你懂的在线播放| 亚洲色图日韩精品| 欧美午夜不卡| 热草久综合在线| 女人18毛片水真多18精品| 亚洲人成网站精品片在线观看| 国产美女永久无遮挡| 亚洲成人1区| 伊人久久综合97精品| 伊人手机在线视频| 91在线精品秘密一区二区| 国产免费一区二区视频| 电影一区二区在线观看| 欧美日韩国产123| 成 人片 黄 色 大 片| 亚洲人成网站精品片在线观看| 五十路熟女丰满大屁股| 97成人在线| 欧美日韩xxx| 精品人妻无码一区二区色欲产成人| 91尤物视频在线观看| 大西瓜av在线| 北条麻妃在线一区二区免费播放| 亚洲欧美中文另类| 欧美黄色aaa| 国产精品77777| 视频一区视频二区视频| 免费观看成人性生生活片| 日韩三级高清在线| 精品99久久久久成人网站免费| 日韩专区一卡二卡| 色一情一区二区三区四区| 天堂久久午夜av| 久久精品国产亚洲7777| 国产成人毛毛毛片| 亚洲电影一区二区| 少妇真人直播免费视频| 免费成人性网站| 亚洲第一精品区| 亚洲国产aⅴ精品一区二区| 欧美—级a级欧美特级ar全黄| 亚洲视频在线免费播放| 中文字幕制服丝袜成人av | 在线观看黄av| 91精品免费观看| 国产一二三四在线| www国产精品av| 欧美黑人在线观看| 日韩电影精品| 亚洲欧洲日本专区| 亚洲熟妇无码久久精品| 国产日产欧美精品一区二区三区| 999在线观看视频| 中文字幕精品影院| 欧美最猛性xxxxx(亚洲精品)| 韩国av免费在线观看| 精品美女国产在线| 三区四区在线观看| 国产乱妇无码大片在线观看| 男女激情无遮挡| 日韩在线视频精品| 国内精品久久国产| 8x8ⅹ拨牐拨牐拨牐在线观看| 日韩你懂的在线播放| 全网免费在线播放视频入口| 激情综合色综合久久| 成人午夜视频在线观看免费| 不卡视频在线| 97人摸人人澡人人人超一碰| 午夜伦理福利在线| 久久色精品视频| 亚洲第一国产精品| 免费网站在线高清观看| 国产麻豆视频一区| 日本久久久精品视频| 亚洲午夜精品一区 二区 三区| 国产成人精品在线| jizz性欧美| 亚洲欧美国产制服动漫| 国产美女免费看| 91福利视频在线| 日韩伦人妻无码| 亚洲欧美一区二区三区国产精品 | 麻豆国产一区二区| www.av毛片| 一区二区三区国产精华| 欧美一区视久久| 精品福利一区| 91久久久久久久久久| 日韩视频网站在线观看| 午夜精品久久久久久久白皮肤 | 亚洲女同志freevdieo| 国产视频精品一区二区三区| 中文字幕在线观看视频一区| 精品久久久香蕉免费精品视频| 中文字幕免费看| 成人深夜福利app| 五月天激情播播| 青青国产91久久久久久| 亚洲 高清 成人 动漫| 韩日视频一区| 成年丰满熟妇午夜免费视频 | 黄色工厂在线观看| 粉嫩aⅴ一区二区三区四区五区| 亚洲熟妇国产熟妇肥婆| 亚州国产精品| 国产一区二区免费在线观看| 欧美国产亚洲精品| 国产欧美日韩精品在线观看| www.久久ai| 亚洲欧美日韩网| 无码精品一区二区三区在线| 精品久久国产字幕高潮| www.爱爱.com| 日韩欧美国产综合一区| 国产哺乳奶水91在线播放| 欧美精品v国产精品v日韩精品| 国产精品1区2区3区4区| 日本一区二区免费在线观看视频 | 亚洲国产精品黑人久久久| 亚洲制服丝袜在线播放| 成人午夜视频网站| 国产女主播在线播放| 国产91高潮流白浆在线麻豆| 99久久综合网| 岛国精品一区二区| 污污免费在线观看| 99精品视频在线免费观看| 玖玖爱视频在线| 国产一区二区三区免费在线观看| 无码人妻h动漫| 国内精品久久久久久久97牛牛| 日韩黄色影视| 久久在线电影| 精品国产三级a∨在线| 欧美99在线视频观看| 亚洲成人午夜在线| 欧美电影在线观看免费| 精品欧美一区二区精品久久| 国产精品亚洲片在线播放| 日韩激情视频| 欧美99在线视频观看| 伊人久久婷婷色综合98网| 亚洲精品国产偷自在线观看| 日韩精品久久一区二区| 久久国产电影| 欧美大片免费播放| 亚洲欧洲另类| 熟女少妇精品一区二区| 韩国一区二区在线观看| 精品少妇人妻av一区二区三区| 狠狠色丁香久久婷婷综合丁香| 成人小视频在线看| 亚洲一区自拍| www.亚洲高清| 国产99久久久精品| 欧美成人国产精品一区二区| 国产精品九色蝌蚪自拍| 国产熟女一区二区| 亚洲精品久久嫩草网站秘色| 日韩黄色在线视频| 欧美色精品在线视频| japanese国产在线观看| 正在播放亚洲一区| 婷婷国产在线| 日韩av在线免费播放| 国产一区二区三区福利| 久久影院资源网| jizz内谢中国亚洲jizz| 91青草视频久久| 美女主播精品视频一二三四| 亚洲欧洲一区二区福利| 加勒比久久综合| 日韩欧美精品一区二区三区经典| 亚洲成在人线免费观看| 视频一区二区视频| 国产综合网站| 日韩一级免费片| 91一区二区在线| 放荡的美妇在线播放| 欧美性猛交xxxx乱大交3| 乱人伦精品视频在线观看| 日本午夜精品电影| 欧美一区二区三区久久| 在线视频不卡一区二区| 久久精品高清| 一区二区传媒有限公司| 久久高清免费观看| 成年人看片网站| 国产精品久久久久毛片软件| 国产精品免费人成网站酒店| 色综合天天综合狠狠| 夜夜躁日日躁狠狠久久av| 亚洲第五色综合网| 国产美女福利在线| 国产精品白嫩初高中害羞小美女 | 亚洲va欧美va国产综合剧情| 久久伊人久久| 亚洲一区综合| 日韩精品免费专区| 亚洲精品国产久| 亚洲国产电影在线观看| 国产精品777777| 亚洲国产黄色片| 国产在线拍揄自揄拍视频| 91精品综合久久久久久五月天| 国产成人tv| av 日韩 人妻 黑人 综合 无码| 亚洲国产专区校园欧美| 国产精品一级无码| 亚洲精品写真福利| 国产aⅴ一区二区三区| 日韩中文字幕在线视频| 国产美女久久| 亚洲欧洲精品一区| 免费在线观看不卡| 日韩av片在线| 欧美日韩精品一区二区三区蜜桃 | 日韩精品久久久久久久玫瑰园| 国产高清自拍视频在线观看| 欧美亚洲激情在线| 日本午夜精品| 国产偷人视频免费| 久久亚洲春色中文字幕久久久| 三级黄色免费观看| 欧美日韩精品一区二区在线播放 | 日本免费在线一区| 亚洲三区四区| 精品亚洲免费视频| 日韩一级片av| 精品福利一区二区三区免费视频| 午夜视频在线观看网站| 国产欧美日韩中文字幕| 伊人春色精品| 九色91popny| 国产精品传媒视频| 成人激情四射网| 中文字幕一精品亚洲无线一区| 黄色在线免费观看网站| 91在线色戒在线| 国产精品草草| 熟女少妇一区二区三区| 欧美亚洲一区二区在线| 无遮挡的视频在线观看 | 久草视频在线资源站| 日韩欧美久久久| 樱花草涩涩www在线播放| 日本免费高清一区二区| 久久99热狠狠色一区二区| 色欲一区二区三区精品a片| 欧美成人免费网站| 91麻豆一二三四在线| 国产精品日韩二区| 日日摸夜夜添夜夜添亚洲女人| 野花社区视频在线观看| 亚洲成人综合网站| 国产一级二级三级在线观看| 成人黄色免费片| 国产日韩免费| 人人艹在线视频| 欧美精品一区二区三区蜜桃视频| 日本动漫同人动漫在线观看| 激情小说综合区| 久久国产视频网| 日韩欧美性视频| 日韩一级黄色av| 欧美大片网站| 欧美人xxxxx| 国产一区二区女| 国产精品一区二区三区四| 久久久91精品国产一区不卡| 久久porn| 中文字幕一区二区在线观看视频| 亚洲日韩欧美一区二区在线| 天堂在线中文网| 成人黄色中文字幕|