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

我們一起聊聊如何保證API接口安全?

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

一、背景介紹

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

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

二、方案介紹

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

  • token方案
  • 接口簽名

2.1、token方案

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

圖片圖片

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

1、用戶登錄成功之后,服務端會給用戶生成一個唯一有效的憑證,這個有效值被稱為token

2、當用戶每次請求其他的業務接口時,需要在請求頭部帶上token

3、服務端接受到客戶端業務接口請求時,會驗證token的合法性,如果不合法會提示給客戶端;如果合法,才會進入業務處理流程。

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

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

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

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

2.2、接口簽名

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

圖片圖片

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

1、appid表示應用ID,其中與之匹配的還有appsecret,表示應用密鑰,用于數據的簽名加密,不同的對接項目分配不同的appid和appsecret,保證數據安全

2、timestamp 表示時間戳,當請求的時間戳與服務器中的時間戳,差值在5分鐘之內,屬于有效請求,不在此范圍內,屬于無效請求

3、nonce 表示臨時流水號,用于防止重復提交驗證

4、signature 表示簽名字段,用于判斷接口請求是否有效。

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

  • 第一步:對請求參數進行一次md5加密簽名
//步驟一
String 參數1 = 請求方式 + 請求URL相對地址 + 請求Body字符串;
String 參數1加密結果= md5(參數1)
  • 第二步:對第一步簽名結果,再進行一次md5加密簽名
//步驟二
String 參數2 = appsecret + timestamp + nonce + 參數1加密結果;
String 參數2加密結果= md5(參數2)

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

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

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

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

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

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

二、程序實踐

2.1、token方案

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

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

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

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

首先,編寫一個jwt 工具。

public class JwtTokenUtil {
    //定義token返回頭部
    public static final String AUTH_HEADER_KEY = "Authorization";
    //token前綴
    public static final String TOKEN_PREFIX = "Bearer ";
    //簽名密鑰
    public static final String KEY = "q3t6w9z$C&F)J@NcQfTjWnZr4u7x";
    //有效期默認為 2hour
    public static final Long EXPIRATION_TIME = 1000L*60*60*2;
    /**
     * 創建TOKEN
     * @param content
     * @return
     */
    public static String createToken(String content){
        return TOKEN_PREFIX + JWT.create()
                .withSubject(content)
                .withExpiresAt(new Date(System.currentTimeMillis() + EXPIRATION_TIME))
                .sign(Algorithm.HMAC512(KEY));
    }
    /**
     * 驗證token
     * @param token
     */
    public static String verifyToken(String token) throws Exception {
        try {
            return JWT.require(Algorithm.HMAC512(KEY))
                    .build()
                    .verify(token.replace(TOKEN_PREFIX, ""))
                    .getSubject();
        } catch (TokenExpiredException e){
            throw new Exception("token已失效,請重新登錄",e);
        } catch (JWTVerificationException e) {
            throw new Exception("token驗證失敗!",e);
        }
    }
}

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

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

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

@Slf4j
public class AuthenticationInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        // 從http請求頭中取出token
        final String token = request.getHeader(JwtTokenUtil.AUTH_HEADER_KEY);
        //如果不是映射到方法,直接通過
        if(!(handler instanceof HandlerMethod)){
            return true;
        }
        //如果是方法探測,直接通過
        if (HttpMethod.OPTIONS.equals(request.getMethod())) {
            response.setStatus(HttpServletResponse.SC_OK);
            return true;
        }
        //如果方法有JwtIgnore注解,直接通過
        HandlerMethod handlerMethod = (HandlerMethod) handler;
        Method method=handlerMethod.getMethod();
        if (method.isAnnotationPresent(JwtIgnore.class)) {
            JwtIgnore jwtIgnore = method.getAnnotation(JwtIgnore.class);
            if(jwtIgnore.value()){
                return true;
            }
        }
        LocalAssert.isStringEmpty(token, "token為空,鑒權失敗!");
        //驗證,并獲取token內部信息
        String userToken = JwtTokenUtil.verifyToken(token);
        //將token放入本地緩存
        WebContextUtil.setUserToken(userToken);
        return true;
    }
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        //方法結束后,移除緩存的token
        WebContextUtil.removeUserToken();
    }
}

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

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

2.2、接口簽名

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

具體代碼實踐如下:

public class SignInterceptor implements HandlerInterceptor {

    @Autowired
    private AppSecretService appSecretService;

    @Autowired
    private RedisUtil redisUtil;

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
            throws Exception {
        //appId驗證
        final String appId = request.getHeader("appid");
        if(StringUtils.isEmpty(appId)){
            throw new CommonException("appid不能為空");
        }
        String appSecret = appSecretService.getAppSecretByAppId(appId);
        if(StringUtils.isEmpty(appSecret)){
            throw new CommonException("appid不合法");
        }
        //時間戳驗證
        final String timestamp = request.getHeader("timestamp");
        if(StringUtils.isEmpty(timestamp)){
            throw new CommonException("timestamp不能為空");
        }
        //大于5分鐘,非法請求
        long diff = System.currentTimeMillis() - Long.parseLong(timestamp);
        if(Math.abs(diff) > 1000 * 60 * 5){
            throw new CommonException("timestamp已過期");
        }
        //臨時流水號,防止重復提交
        final String nonce = request.getHeader("nonce");
        if(StringUtils.isEmpty(nonce)){
            throw new CommonException("nonce不能為空");
        }
        //驗證簽名
        final String signature = request.getHeader("signature");
        if(StringUtils.isEmpty(nonce)){
            throw new CommonException("signature不能為空");
        }
        final String method = request.getMethod();
        final String url = request.getRequestURI();
        final String body = StreamUtils.copyToString(request.getInputStream(), Charset.forName("UTF-8"));
        String signResult = SignUtil.getSignature(method, url, body, timestamp, nonce, appSecret);
        if(!signature.equals(signResult)){
            throw new CommonException("簽名驗證失敗");
        }
        //檢查是否重復請求
        String key = appId + "_" + timestamp + "_" + nonce;
        if(redisUtil.exist(key)){
            throw new CommonException("當前請求正在處理,請不要重復提交");
        }
        //設置5分鐘
        redisUtil.save(key, signResult, 5*60);
        request.setAttribute("reidsKey",key);
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
            throws Exception {
        //請求處理完畢之后,移除緩存
        String value = request.getAttribute("reidsKey");
        if(!StringUtils.isEmpty(value)){
            redisUtil.remove(value);
        }
    }

}

簽名工具類SignUtil:

public class SignUtil {

    /**
     * 簽名計算
     * @param method
     * @param url
     * @param body
     * @param timestamp
     * @param nonce
     * @param appSecret
     * @return
     */
    public static String getSignature(String method, String url, String body, String timestamp, String nonce, String appSecret){
        //第一層簽名
        String requestStr1 = method + url + body + appSecret;
        String signResult1 = DigestUtils.md5Hex(requestStr1);
        //第二層簽名
        String requestStr2 = appSecret + timestamp + nonce + signResult1;
        String signResult2 = DigestUtils.md5Hex(requestStr2);
        return signResult2;
    }
}

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

三、小結

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

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

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

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

責任編輯:武曉燕 來源: 潘志的研發筆記
相關推薦

2022-05-24 08:21:16

數據安全API

2024-10-15 08:08:13

2022-02-14 07:03:31

網站安全MFA

2023-11-10 08:04:43

Java 17Java 11JDK

2025-03-17 11:21:08

APISwagger界面

2024-02-02 09:21:57

API性能策略

2023-11-29 09:04:00

前端接口

2024-11-27 16:07:45

2024-09-30 09:33:31

2023-06-30 08:18:51

敏捷開發模式

2023-08-04 08:20:56

DockerfileDocker工具

2023-09-10 21:42:31

2023-08-10 08:28:46

網絡編程通信

2025-05-26 03:15:00

接口高可用框架

2024-09-09 00:00:00

編寫技術文檔

2023-04-03 00:09:13

2022-05-05 12:57:40

架構

2024-02-20 21:34:16

循環GolangGo

2021-08-27 07:06:10

IOJava抽象

2025-04-08 00:16:07

點贊
收藏

51CTO技術棧公眾號

欧美日韩大片| 在线观看免费黄色小视频| 亚洲一区二区电影| 大桥未久av一区二区三区| 日本一区二区三区视频在线观看| 中日韩av在线| 国产农村妇女毛片精品| 美女网站视频一区| 日韩毛片一二三区| 91视频婷婷| 久久久久久久久久成人| 一本一道久久综合狠狠老| 亚洲精品乱码久久久久久金桔影视| 中文字幕在线导航| 2018av在线| 国产精品麻豆视频| 国产视频一区二区不卡| 波多野结衣大片| 欧美 日韩 国产一区二区在线视频| 精品亚洲夜色av98在线观看| 天堂av2020| 无遮挡爽大片在线观看视频 | 欧美日韩国产中文| 免费 成 人 黄 色| 91麻豆一二三四在线| 久久一夜天堂av一区二区三区| 91超碰rencao97精品| 国产成人无码专区| 亚洲黄页一区| 欧美巨大黑人极品精男| 91精品久久久久久久久久久久| 国产一区丝袜| 日韩精品一区二区三区在线| 天堂一区在线观看| 日韩精品三区| 日韩欧美国产免费播放| www污在线观看| 激情在线小视频| 国产精品美女一区二区三区 | 男人天堂久久久| 久久久久亚洲综合| 久久国产精品免费一区| 亚洲免费一级片| 国产精品99久久久| 91免费福利视频| 91欧美日韩麻豆精品| 日韩av二区在线播放| 日本一本a高清免费不卡| 亚洲国产精一区二区三区性色| 中文字幕午夜精品一区二区三区| 北条麻妃一区二区三区中文字幕| 国产精品永久免费在线| 美女流白浆视频| 国产一区二区视频在线看| 欧美丝袜丝交足nylons图片| 香港三级韩国三级日本三级| 搞黄网站在线看| 亚洲国产成人精品视频| 蜜臀av色欲a片无码精品一区| av电影免费在线观看| 亚洲欧美日韩国产综合| 日韩中文字幕亚洲精品欧美| 18videosex性欧美麻豆| 夜色激情一区二区| 欧美成人高潮一二区在线看| а√在线中文在线新版 | 中文字幕日韩免费| 日韩精品一卡二卡三卡四卡无卡| 国产精品久久综合av爱欲tv| 亚洲天堂一区在线观看| 水野朝阳av一区二区三区| 国产精品成人观看视频国产奇米| www.亚洲激情| 激情六月婷婷综合| 国产精品xxx在线观看www| 天天操天天干天天爽| 91麻豆文化传媒在线观看| 欧美一区二区三区电影在线观看| 国产精品一二三区视频| 国产精品电影一区二区| 亚洲激情免费视频| 一根才成人网| 欧美日韩精品福利| 精品人妻二区中文字幕| 欧美女优在线视频| 久久久精品影院| 欧美福利视频一区二区| 蜜桃久久精品一区二区| 精品一区二区三区免费观看| 欧美美女18p| 国产超碰人人爽人人做人人爱| 视频一区视频二区中文| 成人亲热视频网站| 成人无码一区二区三区| 国产日韩欧美精品在线| 日本三日本三级少妇三级66| 97久久人人超碰caoprom| 在线观看免费视频综合| 手机av在线网站| 尤物tv在线精品| 欧美巨乳美女视频| 无码人妻一区二区三区线| 国产一级精品在线| 欧美日韩一区二区视频在线观看 | 欧美日韩福利电影| 亚洲不卡在线视频| 国产成人精品免费看| 日韩午夜视频在线观看| 福利成人导航| 欧美高清视频不卡网| 青青草视频成人| 欧美午夜精品| 国产精品亚洲激情| 日韩福利一区二区| 洋洋成人永久网站入口| www午夜视频| 蜜臀av免费一区二区三区| 精品中文字幕在线| 91美女精品网站| 欧美激情在线一区二区| 欧美亚洲精品一区二区| 日韩三级不卡| 久久久精品中文字幕| 小泽玛利亚一区二区三区视频| 波波电影院一区二区三区| 男人的天堂成人| 国产成人精选| 亚洲人成伊人成综合网久久久| 国产精品999久久久| 国产一区二区三区免费播放| 亚洲国产精品日韩| 欧美大胆成人| 日韩精品欧美激情| 国产无码精品在线观看| 国产成人精品三级| 少妇高潮流白浆| 亚洲图片小说区| 中文字幕av一区二区三区谷原希美| 日韩免费一级片| 成人国产一区二区三区精品| 久久男人资源站| 亚洲啊v在线免费视频| 久久亚洲私人国产精品va| 中文字幕在线观看免费| 国产蜜臀97一区二区三区| 国产成人精品视频ⅴa片软件竹菊| 欧美色图五月天| 午夜精品一区二区三区av| 亚洲欧美另类一区| 亚洲动漫第一页| 天堂www中文在线资源| 亚洲国产mv| 精品欧美国产| 欧美日韩视频网站| 国产一区二区三区精品久久久| 人人草在线观看| 国产精品污污网站在线观看| 欧美男女交配视频| 91精品国产视频| 国产精品欧美久久久久无广告 | 中文字幕亚洲天堂| 在线观看亚洲黄色| 国产精品福利一区| 男人女人拔萝卜视频| 激情视频一区二区三区| 国产在线精品二区| 欧美成人h版| 色偷偷9999www| 99在线小视频| 午夜精品视频在线观看| 野外性满足hd| 美女视频一区在线观看| 中文字幕一区二区三区精彩视频| 99tv成人影院| 国内精品免费午夜毛片| 日本电影一区二区在线观看| 欧美午夜理伦三级在线观看| 日本黄色激情视频| 国产主播一区二区三区| 日韩一级片免费视频| 亚洲三级网址| 成人美女av在线直播| wwww在线观看免费视频| 亚洲色图第三页| 国产日本精品视频| 五月婷婷另类国产| 美女福利视频网| 免费av在线| 久久久久久久免费视频了| 黄色永久免费网站| 伊人影院久久| 亚洲视频在线观看日本a| 久久综合给合| 日韩美女av在线免费观看| 爆操欧美美女| 国产亚洲成精品久久| 精品久久久免费视频| 日韩欧美精品免费在线| 亚洲xxxx3d动漫| 国产亚洲一区字幕| www.555国产精品免费| 日韩福利视频导航| 人妻无码久久一区二区三区免费| 欧洲三级视频| 国产伦精品一区二区三区视频黑人 | 国产精品入口久久| 国产91精品一区二区绿帽| 99riav视频一区二区| 97婷婷涩涩精品一区| 精精国产xxxx视频在线| 国产亚洲精品一区二555| 亚洲av无码乱码国产精品| 欧美曰成人黄网| 亚洲毛片在线观看.| 色播视频在线播放| 亚洲品质自拍视频| 日韩女同一区二区三区| 不卡视频一二三四| 伦伦影院午夜理论片| 日韩和欧美的一区| 日韩精品一区二区三区久久| 狠狠干成人综合网| 欧美日韩在线免费观看视频| av在线不卡免费观看| 精品视频一区二区| 高清欧美性猛交xxxx黑人猛| 成人福利视频网| 91综合国产| 国产精品极品在线| 超级碰碰久久| 8090成年在线看片午夜| 2020av在线| 欧美精品久久久久久久免费观看| a在线免费观看| 久久精品99久久久久久久久| 18视频免费网址在线观看| 亚洲三级 欧美三级| 日本v片在线免费观看| 亚洲国产美女精品久久久久∴| 国产成人毛毛毛片| 日韩一区二区精品葵司在线| 国产视频在线观看免费| 9191成人精品久久| 国产女人高潮毛片| 91精品国产全国免费观看| 一级黄色片视频| 欧美精品自拍偷拍动漫精品| 一本色道久久综合亚洲| 欧美日本在线播放| 国产片高清在线观看| 91精品国产一区二区| www.com欧美| 精品欧美一区二区在线观看| 高潮毛片7777777毛片| 亚洲第一视频在线观看| 婷婷婷国产在线视频| 亚洲欧美国产一区二区三区| 久香视频在线观看| 国产亚洲xxx| 欧美大黑帍在线播放| 热久久天天拍国产| 二级片在线观看| 欧美日韩免费观看一区=区三区| 男人的天堂avav| 日韩午夜av在线| 91黄色小网站| 久久99久国产精品黄毛片色诱| 久久精品亚洲天堂| 成人免费高清视频在线观看| 超碰97在线资源站| 国产三区在线成人av| 天天色天天综合| 亚洲国产精品一区二区尤物区| 国产成人在线视频观看| 精品视频一区 二区 三区| 国产普通话bbwbbwbbw| 亚洲国产精品推荐| av在线三区| 欧美国产日韩一区二区在线观看 | 国产成人午夜视频网址| 欧美美女被草| 国产精品永久入口久久久| 美女少妇全过程你懂的久久| 一道精品一区二区三区| 极品中文字幕一区| 九色91popny| 成人午夜激情影院| 性猛交娇小69hd| 亚洲一级二级三级| 在线观看国产一区二区三区| 精品久久国产老人久久综合| 男人天堂综合| 欧美丰满少妇xxxx| 精品成人免费一区二区在线播放| 91免费看片网站| 免费视频国产一区| av动漫在线免费观看| 日韩精品欧美精品| 女性生殖扒开酷刑vk| 中文字幕一区日韩精品欧美| 国产又大又黑又粗免费视频| 欧美日韩免费一区二区三区| 狠狠综合久久av一区二区| 最近2019中文字幕在线高清| 888av在线视频| 亚洲自拍偷拍在线| 日韩av在线中文字幕| 国产原创中文在线观看 | 男人舔女人下部高潮全视频| 一区二区三区毛片| 亚洲一卡二卡在线| 亚洲欧美在线x视频| 免费在线观看av电影| 国产伦精品一区二区三区精品视频| 国产精品色在线网站| 影音先锋亚洲视频| 久久资源在线| 亚洲一区二区乱码| 亚洲一二三四区不卡| 国产日韩欧美中文字幕| 中文字幕亚洲综合久久| 蜜桃视频在线观看免费视频| 99久热re在线精品996热视频| 全球成人免费直播| 日本在线视频www| 99久久99久久综合| 国产在线成人精品午夜| 欧美一激情一区二区三区| 在线观看麻豆蜜桃| 国产精品白嫩初高中害羞小美女 | 神马午夜伦理影院| 另类小说综合欧美亚洲| jizz18女人高潮| 色婷婷综合久久久| 可以在线观看的av| 日本欧美中文字幕| 久久99久久人婷婷精品综合| 18岁网站在线观看| 久久亚洲免费视频| xxxx.国产| 亚洲欧美国产精品| 蜜桃成人精品| 天堂一区二区三区| 日本成人中文字幕| www成人啪啪18软件| 欧美日韩一区精品| 午夜免费视频在线国产| 国产在线a不卡| 亚洲91视频| 中文字幕无码毛片免费看| 亚洲欧美偷拍另类a∨色屁股| 国产农村妇女毛片精品久久| 欧美另类精品xxxx孕妇| 这里视频有精品| 色欲色香天天天综合网www| 成人av网站在线| 国产一区二区三区影院| 日韩高清不卡av| 欧美1级2级| 亚洲一区二区三区在线观看视频| 久久超级碰视频| 国产盗摄一区二区三区在线| 欧美一区二区三区视频在线观看| 丝袜美女在线观看| 国内精品二区| 日韩制服丝袜av| 国产精品一区二区亚洲| 91精品国产日韩91久久久久久| 欧美性受ⅹ╳╳╳黑人a性爽| 国产精品一区二区三区在线观| 免费欧美日韩| 美女视频久久久| 亚洲第一中文字幕| 黑人巨大精品欧美一区二区桃花岛| 欧美三日本三级少妇三99| 麻豆精品新av中文字幕| 精品无码av在线| 亚洲免费视频一区二区| 亚洲ww精品| 欧美视频在线观看网站| 欧美韩日一区二区三区| 99在线观看精品视频| 91豆花精品一区| 婷婷综合五月| 五月天激情小说| 欧美日韩国产大片| ****av在线网毛片| 亚洲午夜在线观看| 懂色一区二区三区免费观看| 中文字幕黄色片| 久久99精品久久久久久青青91| 亚州综合一区| 伊人国产精品视频| 欧美视频精品一区| jizz性欧美| 秋霞毛片久久久久久久久| 国产电影一区二区三区| 色老头在线视频| 97精品国产91久久久久久| 日韩久久视频|