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

如何保證API接口安全?

安全 網站安全
當你的公司體量上來了時候,這個時候可能有一些公司開始找你進行技術對接了,轉變成由你來提供api接口,那這個時候,我們應該如何設計并保證API接口安全呢?

一、摘要

在實際的業務開發過程中,我們常常會碰到需要與第三方互聯網公司進行技術對接,例如支付寶支付對接、微信支付對接、高德地圖查詢對接等等服務,如果你是一個創業型互聯網,大部分可能都是對接別的公司api接口。

當你的公司體量上來了時候,這個時候可能有一些公司開始找你進行技術對接了,轉變成由你來提供api接口,那這個時候,我們應該如何設計并保證API接口安全呢?

二、方案介紹

最常用的方案,主要有兩種:

  • token方案
  • 接口簽名

1. token方案

其中 token 方案,是一種在web端使用最廣的接口鑒權方案,我記得在之前寫過一篇《手把手教你,使用JWT實現單點登錄》的文章,里面介紹的比較詳細,有興趣的朋友可以看一下,沒了解的也沒關系,我們在此簡單的介紹一下 token 方案。

從上圖,我們可以很清晰的看到,token 方案的實現主要有以下幾個步驟:

  • 用戶登錄成功之后,服務端會給用戶生成一個唯一有效的憑證,這個有效值被稱為token
  • 當用戶每次請求其他的業務接口時,需要在請求頭部帶上token
  • 服務端接受到客戶端業務接口請求時,會驗證token的合法性,如果不合法會提示給客戶端;如果合法,才會進入業務處理流程。

在實際使用過程中,當用戶登錄成功之后,生成的token存放在redis中時是有時效的,一般設置為2個小時,過了2個小時之后會自動失效,這個時候我們就需要重新登錄,然后再次獲取有效token。

token方案,是目前業務類型的項目當中使用最廣的方案,而且實用性非常高,可以很有效的防止黑客們進行抓包、爬取數據。

但是 token 方案也有一些缺點!最明顯的就是與第三方公司進行接口對接的時候,當你的接口請求量非常大,這個時候 token 突然失效了,會有大量的接口請求失敗。

這個我深有體會,我記得在很早的時候,跟一家中、大型互聯網公司進行聯調的時候,他們提供給我的接口對接方案就是token方案,當時我司的流量高峰期時候,請求他們的接口大量報錯,原因就是因為token失效了,當token失效時,我們會調用他們刷新token接口,刷新完成之后,在token失效與重新刷新token這個時間間隔期間,就會出現大量的請求失敗的日志,因此在實際API對接過程中,我不推薦大家采用 token方案。

2. 接口簽名

接口簽名,顧名思義,就是通過一些簽名規則對參數進行簽名,然后把簽名的信息放入請求頭部,服務端收到客戶端請求之后,同樣的只需要按照已定的規則生產對應的簽名串與客戶端的簽名信息進行對比,如果一致,就進入業務處理流程;如果不通過,就提示簽名驗證失敗。

在接口簽名方案中,主要有四個核心參數:

  • appid表示應用ID,其中與之匹配的還有appsecret,表示應用密鑰,用于數據的簽名加密,不同的對接項目分配不同的appid和appsecret,保證數據安全
  • timestamp 表示時間戳,當請求的時間戳與服務器中的時間戳,差值在5分鐘之內,屬于有效請求,不在此范圍內,屬于無效請求
  • nonce 表示臨時流水號,用于防止重復提交驗證
  • signature 表示簽名字段,用于判斷接口請求是否有效。

其中簽名的生成規則,分兩個步驟:

第一步:對請求參數進行一次md5加密簽名

  1. //步驟一 
  2. String 參數1 = 請求方式 + 請求URL相對地址 + 請求Body字符串; 
  3. String 參數1加密結果= md5(參數1) 

第二步:對第一步簽名結果,再進行一次md5加密簽名

  1. //步驟二 
  2. String 參數2 = appsecret + timestamp + nonce + 參數1加密結果; 
  3. String 參數2加密結果= md5(參數2) 

參數2加密結果,就是我們要的最終簽名串。

接口簽名方案,尤其是在接口請求量很大的情況下,依然很穩定。

換句話說,你可以將接口簽名看作成對token方案的一種補充。

但是如果想把接口簽名方案,推廣到前后端對接,答案是:不適合。

因為簽名計算非常復雜,其次,就是容易泄漏appsecret!

說了這么多,下面我們就一起來用程序實踐一下吧!

二、程序實踐

1. token方案

就像上文所說,token方案重點在于,當用戶登錄成功之后,我們只需要生成好對應的token,然后將其返回給前端,在下次請求業務接口的時候,需要把token帶上。

具體的實踐,也可以分兩種:

  • 第一種:采用uuid生成token,然后將token存放在redis中,同時設置有效期2哥小時
  • 第二種:采用JWT工具來生成token,這種token是可以跨平臺的,天然支持分布式,其實本質也是采用時間戳+密鑰,來生成一個token。

下面,我們介紹的是第二種實現方式。

首先,編寫一個jwt 工具。

  1. public class JwtTokenUtil { 
  2.     //定義token返回頭部 
  3.     public static final String AUTH_HEADER_KEY = "Authorization"
  4.     //token前綴 
  5.     public static final String TOKEN_PREFIX = "Bearer "
  6.     //簽名密鑰 
  7.     public static final String KEY = "q3t6w9z$C&F)J@NcQfTjWnZr4u7x"
  8.     //有效期默認為 2hour 
  9.     public static final Long EXPIRATION_TIME = 1000L*60*60*2; 
  10.     /** 
  11.      * 創建TOKEN 
  12.      * @param content 
  13.      * @return 
  14.      */ 
  15.     public static String createToken(String content){ 
  16.         return TOKEN_PREFIX + JWT.create() 
  17.                 .withSubject(content) 
  18.                 .withExpiresAt(new Date(System.currentTimeMillis() + EXPIRATION_TIME)) 
  19.                 .sign(Algorithm.HMAC512(KEY)); 
  20.     } 
  21.     /** 
  22.      * 驗證token 
  23.      * @param token 
  24.      */ 
  25.     public static String verifyToken(String token) throws Exception { 
  26.         try { 
  27.             return JWT.require(Algorithm.HMAC512(KEY)) 
  28.                     .build() 
  29.                     .verify(token.replace(TOKEN_PREFIX, "")) 
  30.                     .getSubject(); 
  31.         } catch (TokenExpiredException e){ 
  32.             throw new Exception("token已失效,請重新登錄",e); 
  33.         } catch (JWTVerificationException e) { 
  34.             throw new Exception("token驗證失敗!",e); 
  35.         } 
  36.     } 

接著,我們在登錄的時候,生成一個token,然后返回給客戶端。

  1. @RequestMapping(value = "/login"method = RequestMethod.POST, produces = {"application/json;charset=UTF-8"}) 
  2. public UserVo login(@RequestBody UserDto userDto, HttpServletResponse response){ 
  3.     //...參數合法性驗證 
  4.     //從數據庫獲取用戶信息 
  5.     User dbUser = userService.selectByUserNo(userDto.getUserNo); 
  6.     //....用戶、密碼驗證 
  7.     //創建token,并將token放在響應頭 
  8.     UserToken userToken = new UserToken(); 
  9.     BeanUtils.copyProperties(dbUser,userToken); 
  10.     String token = JwtTokenUtil.createToken(JSONObject.toJSONString(userToken)); 
  11.     response.setHeader(JwtTokenUtil.AUTH_HEADER_KEY, token); 
  12.     //定義返回結果 
  13.     UserVo result = new UserVo(); 
  14.     BeanUtils.copyProperties(dbUser,result); 
  15.     return result; 

最后,編寫一個統一攔截器,用于驗證客戶端傳入的token是否有效。

  1. @Slf4j 
  2. public class AuthenticationInterceptor implements HandlerInterceptor { 
  3.     @Override 
  4.     public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { 
  5.         // 從http請求頭中取出token 
  6.         final String token = request.getHeader(JwtTokenUtil.AUTH_HEADER_KEY); 
  7.         //如果不是映射到方法,直接通過 
  8.         if(!(handler instanceof HandlerMethod)){ 
  9.             return true; 
  10.         } 
  11.         //如果是方法探測,直接通過 
  12.         if (HttpMethod.OPTIONS.equals(request.getMethod())) { 
  13.             response.setStatus(HttpServletResponse.SC_OK); 
  14.             return true; 
  15.         } 
  16.         //如果方法有JwtIgnore注解,直接通過 
  17.         HandlerMethod handlerMethod = (HandlerMethod) handler; 
  18.         Method method=handlerMethod.getMethod(); 
  19.         if (method.isAnnotationPresent(JwtIgnore.class)) { 
  20.             JwtIgnore jwtIgnore = method.getAnnotation(JwtIgnore.class); 
  21.             if(jwtIgnore.value()){ 
  22.                 return true; 
  23.             } 
  24.         } 
  25.         LocalAssert.isStringEmpty(token, "token為空,鑒權失敗!"); 
  26.         //驗證,并獲取token內部信息 
  27.         String userToken = JwtTokenUtil.verifyToken(token); 
  28.         //將token放入本地緩存 
  29.         WebContextUtil.setUserToken(userToken); 
  30.         return true; 
  31.     } 
  32.     @Override 
  33.     public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { 
  34.         //方法結束后,移除緩存的token 
  35.         WebContextUtil.removeUserToken(); 
  36.     } 

在生成token的時候,我們可以將一些基本的用戶信息,例如用戶ID、用戶姓名,存入token中,這樣當token鑒權通過之后,我們只需要通過解析里面的信息,即可獲取對應的用戶ID,可以省下去數據庫查詢一些基本信息的操作。

同時,使用的過程中,盡量不要存放敏感信息,因為很容易被黑客解析!

2. 接口簽名

同樣的思路,站在服務端驗證的角度,我們可以先編寫一個簽名攔截器,驗證客戶端傳入的參數是否合法,只要有一項不合法,就提示錯誤。

具體代碼實踐如下:

  1. public class SignInterceptor implements HandlerInterceptor { 
  2.  
  3.     @Autowired 
  4.     private AppSecretService appSecretService; 
  5.  
  6.     @Autowired 
  7.     private RedisUtil redisUtil; 
  8.  
  9.     @Override 
  10.     public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) 
  11.             throws Exception { 
  12.         //appId驗證 
  13.         final String appId = request.getHeader("appid"); 
  14.         if(StringUtils.isEmpty(appId)){ 
  15.             throw new CommonException("appid不能為空"); 
  16.         } 
  17.         String appSecret = appSecretService.getAppSecretByAppId(appId); 
  18.         if(StringUtils.isEmpty(appSecret)){ 
  19.             throw new CommonException("appid不合法"); 
  20.         } 
  21.         //時間戳驗證 
  22.         final String timestamp = request.getHeader("timestamp"); 
  23.         if(StringUtils.isEmpty(timestamp)){ 
  24.             throw new CommonException("timestamp不能為空"); 
  25.         } 
  26.         //大于5分鐘,非法請求 
  27.         long diff = System.currentTimeMillis() - Long.parseLong(timestamp); 
  28.         if(Math.abs(diff) > 1000 * 60 * 5){ 
  29.             throw new CommonException("timestamp已過期"); 
  30.         } 
  31.         //臨時流水號,防止重復提交 
  32.         final String nonce = request.getHeader("nonce"); 
  33.         if(StringUtils.isEmpty(nonce)){ 
  34.             throw new CommonException("nonce不能為空"); 
  35.         } 
  36.         //驗證簽名 
  37.         final String signature = request.getHeader("signature"); 
  38.         if(StringUtils.isEmpty(nonce)){ 
  39.             throw new CommonException("signature不能為空"); 
  40.         } 
  41.         final String method = request.getMethod(); 
  42.         final String url = request.getRequestURI(); 
  43.         final String body = StreamUtils.copyToString(request.getInputStream(), Charset.forName("UTF-8")); 
  44.         String signResult = SignUtil.getSignature(method, url, body, timestamp, nonce, appSecret); 
  45.         if(!signature.equals(signResult)){ 
  46.             throw new CommonException("簽名驗證失敗"); 
  47.         } 
  48.         //檢查是否重復請求 
  49.         String key = appId + "_" + timestamp + "_" + nonce; 
  50.         if(redisUtil.exist(key)){ 
  51.             throw new CommonException("當前請求正在處理,請不要重復提交"); 
  52.         } 
  53.         //設置5分鐘 
  54.         redisUtil.save(key, signResult, 5*60); 
  55.         request.setAttribute("reidsKey",key); 
  56.     } 
  57.  
  58.     @Override 
  59.     public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) 
  60.             throws Exception { 
  61.         //請求處理完畢之后,移除緩存 
  62.         String value = request.getAttribute("reidsKey"); 
  63.         if(!StringUtils.isEmpty(value)){ 
  64.             redisUtil.remove(value); 
  65.         } 
  66.     } 
  67.  

簽名工具類SignUtil:

  1. public class SignUtil { 
  2.  
  3.     /** 
  4.      * 簽名計算 
  5.      * @param method 
  6.      * @param url 
  7.      * @param body 
  8.      * @param timestamp 
  9.      * @param nonce 
  10.      * @param appSecret 
  11.      * @return 
  12.      */ 
  13.     public static String getSignature(String method, String url, String body, String timestamp, String nonce, String appSecret){ 
  14.         //第一層簽名 
  15.         String requestStr1 = method + url + body + appSecret; 
  16.         String signResult1 = DigestUtils.md5Hex(requestStr1); 
  17.         //第二層簽名 
  18.         String requestStr2 = appSecret + timestamp + nonce + signResult1; 
  19.         String signResult2 = DigestUtils.md5Hex(requestStr2); 
  20.         return signResult2; 
  21.     } 

簽名計算,可以換成hamc方式進行計算,思路大致一樣。

三、小結

上面介紹的token和接口簽名方案,對外都可以對提供的接口起到保護作用,防止別人篡改請求,或者模擬請求。

但是缺少對數據自身的安全保護,即請求的參數和返回的數據都是有可能被別人攔截獲取的,而這些數據又是明文的,所以只要被攔截,就能獲得相應的業務數據。

對于這種情況,推薦大家對請求參數和返回參數進行加密處理,例如RSA、AES等加密工具。

同時,在生產環境,采用https方式進行傳輸,可以起到很好的安全保護作用!

 

責任編輯:趙寧寧 來源: Java極客技術
相關推薦

2024-11-27 08:47:12

2023-10-16 11:12:29

2019-04-09 10:35:14

API數據安全性

2024-03-06 08:36:36

2023-08-28 08:00:46

2022-07-07 16:48:10

API應用安全

2011-09-23 10:13:43

2024-06-17 00:02:00

線程安全HashMapJDK 1.7

2023-01-26 02:07:51

HashSet線程安全

2023-02-04 10:08:40

2010-10-08 10:17:59

Web服務安全

2010-09-06 09:27:54

社交網絡

2013-07-16 14:10:03

2012-03-07 10:00:35

2022-07-04 07:41:53

接口數據安全

2024-05-20 13:13:01

線程安全Java

2020-02-13 09:52:48

加密前后端https

2019-03-13 08:28:28

物聯網設計物聯網安全物聯網

2013-08-20 09:26:03

大數據時代hadoop

2020-11-26 12:40:26

NTSNTP系統運維
點贊
收藏

51CTO技術棧公眾號

欧美精品色视频| 一区二区三区的久久的视频| 亚洲va在线观看| 日本a口亚洲| 91精品在线免费观看| 国产爆乳无码一区二区麻豆| 亚洲精品字幕在线| 男女精品视频| 久久国产精品电影| 丰满岳乱妇一区二区| 四虎4545www国产精品| 亚洲精品乱码久久久久久| 久久精品美女| 国产v片在线观看| 久久婷婷一区| 草民午夜欧美限制a级福利片| 99久久免费看精品国产一区 | 精品按摩偷拍| 欧美三级一区二区| 阿v天堂2017| 91网在线看| 欧美激情综合在线| 精品久久久久久乱码天堂| 国产精品亚洲欧美在线播放| 久久狠狠一本精品综合网| 欧美高清自拍一区| 老司机深夜福利网站| 妖精视频一区二区三区| 精品成人佐山爱一区二区| 91精品无人成人www| 美女高潮在线观看| 亚洲欧美日韩国产另类专区 | 极品白嫩少妇无套内谢| 另类一区二区三区| 色88888久久久久久影院按摩| 国产精品igao激情视频| 免费黄网站在线播放| 欧美激情资源网| 日本一区二区在线视频| 欧美日韩在线中文字幕| 99久久99久久久精品齐齐| 99国产视频| 国产免费一区二区三区最新不卡| 欧美aaa在线| 国产精品h片在线播放| www.日本精品| 日韩午夜一区| 97成人在线视频| 日韩成人免费观看| 日韩视频中文| 2019日本中文字幕| 国产无人区码熟妇毛片多| 亚洲精品专区| 2019国产精品自在线拍国产不卡| 久久夜靖品2区| 99热免费精品| 欧美整片在线观看| 无码人妻久久一区二区三区不卡| 男女av一区三区二区色多| 欧洲成人免费aa| 一二三区免费视频| 麻豆国产91在线播放| 国产女人精品视频| 国产欧美日韩成人| 粉嫩aⅴ一区二区三区四区五区| **亚洲第一综合导航网站| 精品人妻一区二区三区三区四区 | 毛片av在线| ●精品国产综合乱码久久久久| 吴梦梦av在线| 日本无删减在线| 亚洲成人动漫在线观看| 无码人妻h动漫| 88xx成人网| 91精品国产免费| 日本不卡视频一区| 国产欧美日韩| 久久天堂av综合合色| 久久黄色免费视频| 国产精品久久久久久久久久妞妞| 国产精品2018| 999av视频| 99精品国产视频| 亚洲7777| 国产精品偷拍| 在线观看视频欧美| 久久久久久久高清| 美腿丝袜亚洲图片| 中国日韩欧美久久久久久久久| 国产三级国产精品国产国在线观看| 欧美久久一区| 国产精品久久久久77777| av加勒比在线| 国产亚洲欧洲997久久综合| 午夜久久久久久久久久久| 性欧美xxx69hd高清| 欧美肥胖老妇做爰| 噜噜噜在线视频| 99视频精品视频高清免费| 孩xxxx性bbbb欧美| 最近日韩免费视频| av一二三不卡影片| 欧美h视频在线观看| 成人影院大全| 精品国内二区三区| 污污视频网站在线免费观看| 亚洲国产精品一区| 成人自拍性视频| 清纯唯美亚洲色图| 亚洲一区免费观看| www.se五月| 国产一卡不卡| 98精品在线视频| www.综合色| 国产精品美女www爽爽爽| 青青青国产在线观看| 国产精品一站二站| 中文字幕日韩av电影| 欧美精品二区三区| 成人免费三级在线| 2021国产视频| 97久久中文字幕| 中国china体内裑精亚洲片| 99久久精品国产亚洲| 成人动漫一区二区| 超级碰在线观看| 日韩欧国产精品一区综合无码| 亚洲欧美制服丝袜| 日韩乱码在线观看| 国产99久久久久| 特大黑人娇小亚洲女mp4| 日韩第二十一页| 中日韩美女免费视频网址在线观看 | 毛片免费在线| 亚洲a一区二区| 亚洲最大视频网| 国产伊人精品| 成人动漫视频在线观看免费| 暖暖日本在线观看| 欧美二区乱c少妇| 制服丨自拍丨欧美丨动漫丨| 美日韩一级片在线观看| 亚洲一区二区三区色| 欧美黄色a视频| 久久亚洲综合国产精品99麻豆精品福利| 中文字幕日韩第一页| 中文文精品字幕一区二区| 人人爽人人av| 久久国产成人精品| 91色视频在线导航| 国产日产一区二区| 日韩欧美精品在线视频| 精品一区免费观看| 99精品欧美一区二区蜜桃免费| 99精品在线免费视频| 五月国产精品| 国产精品扒开腿做爽爽爽男男| 国产小视频免费在线网址| 狠狠色香婷婷久久亚洲精品| 欧美激情aaa| 欧美aa在线视频| 国内外成人激情免费视频| 亚洲经典视频| 91av在线播放视频| 国产高清在线看| 91精品国产色综合久久不卡蜜臀 | 自拍视频一区二区| 日日摸夜夜添夜夜添国产精品 | 最新国产拍偷乱拍精品| 久久婷婷国产综合尤物精品| 日韩欧美一区二区三区在线观看 | 欧美h片在线观看| 国产一区二区不卡老阿姨| 无码熟妇人妻av在线电影| 亚洲成人一品| 成人av在线亚洲| 久久不射影院| 亚洲视频在线看| 99草在线视频| 欧美日韩激情小视频| 国产日韩精品中文字无码| 国产福利91精品一区| 日日鲁鲁鲁夜夜爽爽狠狠视频97| 黑人操亚洲人| 国产91视觉| 国产成人a视频高清在线观看| 欧美第一黄网免费网站| 国产福利在线| 精品久久久久久久人人人人传媒 | 久久久久久久久久久一区| ww久久综合久中文字幕| 欧美国产日韩精品| 国产1区2区3区在线| 日韩欧美国产系列| 天天射天天干天天| 亚洲自拍偷拍麻豆| 国产午夜精品久久久久久久久| 国产成人免费网站| 成人午夜激情av| 在线观看一区视频| 中国成人亚色综合网站| 亚洲色图丝袜| 国产精品v欧美精品∨日韩| 亚洲四虎影院| 欧美一区深夜视频| 污污的网站在线看| 中文字幕v亚洲ⅴv天堂| 性xxxxbbbb| 欧美大片在线观看| 中文字幕视频二区| 欧美性猛交xxxx乱大交3| 欧美成人精品一区二区免费看片| 国产欧美日韩中文久久| 国产视频精品视频| 国产美女精品一区二区三区| 亚洲色欲综合一区二区三区| 亚洲一级高清| 日韩精品一区二区三区电影| 偷拍自拍亚洲色图| 91网站在线看| 精品三级在线| 国产精品福利在线观看网址| 手机av在线| 高清欧美性猛交xxxx| av免费在线免费观看| 日韩在线不卡视频| 成人p站proumb入口| 亚洲欧美在线一区| 亚洲 另类 春色 国产| 亚洲精品一区二区三区在线观看| 国产女18毛片多18精品| 欧美日韩综合在线免费观看| 免费黄色片视频| 色狠狠av一区二区三区| 国产无遮挡呻吟娇喘视频| 午夜av一区二区三区| 国产一二三四在线| 一级精品视频在线观看宜春院 | 欧美在线小视频| 超碰在线观看91| 一本到不卡免费一区二区| 国产www在线| 欧美特黄级在线| www.国产毛片| 91国偷自产一区二区三区观看| 日本中文字幕久久| 日本韩国一区二区| 亚洲成人av网址| 欧美视频一区二区三区| 怡春院在线视频| 欧美理论电影在线| 国产日产亚洲系列最新| 日韩视频国产视频| 六月婷婷综合网| 亚洲激情国产精品| 内衣办公室在线| 中文字幕av一区二区三区谷原希美| 成年人免费在线视频| 中文一区二区视频| 91麻豆免费在线视频| 国模叶桐国产精品一区| 625成人欧美午夜电影| 国产精品久久网| 精品99re| 精品人伦一区二区三区| 国产一区99| 成人性做爰片免费视频| 国产综合亚洲精品一区二| 久久久久免费看黄a片app| 老司机亚洲精品| 中文字幕永久有效| 成人综合在线网站| 天天躁日日躁aaaa视频| 自拍偷拍欧美激情| 色播视频在线播放| 欧美人牲a欧美精品| 囯产精品久久久久久| 亚洲欧洲在线免费| 二区三区在线观看| **欧美日韩vr在线| 亚洲综合视频| 久久精品国产精品国产精品污 | 日韩一区二区av| 欧美家庭影院| 国产精品久久久久久久电影| 亚洲高清999| 日韩欧美精品在线不卡| 欧美性久久久| 国产又猛又黄的视频| 国产成人激情av| 中国1级黄色片| 午夜精品视频在线观看| 91久久精品无码一区二区| 亚洲精品白浆高清久久久久久| 最新电影电视剧在线观看免费观看| 欧美国产欧美亚洲国产日韩mv天天看完整| 肉色欧美久久久久久久免费看| 91日本在线视频| 国产中文精品久高清在线不| 久久亚洲a v| 另类小说欧美激情| 久久精品一区二区免费播放| 樱桃国产成人精品视频| 波多野结衣人妻| 亚洲高清一二三区| 国产成人无吗| 国产精品免费在线免费 | 欧美一级做一级爱a做片性| 国产女主播一区二区三区| 久久精品免费一区二区三区| 丁香啪啪综合成人亚洲| 大美女一区二区三区| 黑人操日本美女| 欧美三级视频在线播放| 久久精品a一级国产免视看成人 | 日韩欧美一区二区三区在线观看| 国产精品欧美久久| 亚洲九九视频| 中文av一区二区三区| 久久精品在线观看| 国产成人精品一区二三区| 欧美大片国产精品| 成人福利网站| 成人久久久久爱| 久久综合成人| 在线免费视频a| 国产亚洲欧洲一区高清在线观看| 成年人视频在线免费看| 亚洲国产精品免费| 成人在线免费观看黄色| 成人av影视在线| 亚洲精品喷潮一区二区三区| 亚洲国产另类av| av中文在线观看| 日韩在线免费视频| 素人啪啪色综合| 日韩欧美第二区在线观看| 美女精品在线观看| 国产ts在线播放| 欧美性猛交xxxx偷拍洗澡| 五月天激情开心网| 96精品视频在线| 色先锋久久影院av| 女人和拘做爰正片视频| 2024国产精品| 中文字幕在线看人| 在线丨暗呦小u女国产精品| av亚洲一区| 人人妻人人澡人人爽精品欧美一区| 激情文学综合丁香| 欧美精品一级片| 日韩欧美黄色影院| 免费毛片在线看片免费丝瓜视频| 91久久精品一区二区别| 在线观看的日韩av| 中文字幕丰满孑伦无码专区| 色婷婷综合激情| 午夜视频在线| 亚洲在线观看视频网站| 国内成人在线| 亚洲专区区免费| 欧美亚洲精品一区| 免费av网站在线观看| 99在线观看视频| 亚洲一区免费| 国产91在线高潮白浆在线观看| 免费看成人哺乳视频网站| 香蕉视频网站入口| 亚洲色图都市小说| 色呦呦中文字幕| 国产精品99免视看9| 亚洲国产精品91| 国产精品伦子伦| 欧美伊人久久久久久午夜久久久久| 日韩精品毛片| 国产精品毛片一区视频| 可以免费看不卡的av网站| 女同久久另类69精品国产| 日韩亚洲欧美在线| 特黄毛片在线观看| 中文字幕成人一区| 成人久久视频在线观看| 中文字幕一区二区三区四区欧美| 久久久精品视频在线观看| 国产精品一线| 五月婷婷六月丁香激情| 五月综合激情网| 蜜桃视频网站在线观看| 激情视频在线观看一区二区三区| 日产国产高清一区二区三区| 欧美日韩激情在线观看| 亚洲天堂av在线播放| 日韩精品一级| 日本久久精品一区二区| 亚洲网友自拍偷拍| 98在线视频| 九色一区二区| 国产精品亚洲一区二区三区妖精| 久久久精品视频网站| 欧美裸身视频免费观看|